首页 > 其他 > 详细

实现Toolbar滑动隐藏问题与解决

时间:2020-03-11 22:33:52      阅读:100      评论:0      收藏:0      [点我收藏+]

目录

前言

实现

相关文章

前言

前些天看了很多app都有toolbar随滑动隐藏或显示,比如酷安。

技术分享图片

效果挺棒的,想到了我之前的ListView Demo ,添加一个这样的toolbar会是什么效果呢? 【之前的Demo_ListView

为了增加点东西,在listview的基础上嵌套一个PagerView在外部。

实现

开始来添加toolbar,AppBar包裹的toolbar,这里用的包是androidx,如果你想用support,应使用android.support.v7.widget.Toolbarandroid.support.design.widget.AppBarLayout

      <?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:layout_width="match_parent"
  android:layout_height="match_parent">


  <com.google.android.material.appbar.AppBarLayout
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:theme="@style/AppTheme.AppBarOverlay">

      <androidx.appcompat.widget.Toolbar
          android:id="@+id/toolbar"
          android:layout_width="match_parent"
          android:layout_height="40dp"
          android:background="?attr/colorPrimary"
          android:minHeight="40dp"
          app:layout_scrollFlags="scroll|enterAlways"
          app:maxButtonHeight="25dp"
          app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />


  </com.google.android.material.appbar.AppBarLayout>


  <androidx.core.widget.NestedScrollView
      android:id="@+id/nscroll_view"
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:fillViewport="true"
      app:layout_behavior="@string/appbar_scrolling_view_behavior">


      <androidx.viewpager.widget.ViewPager
          android:id="@+id/activityViewPager"
          android:layout_width="match_parent"
          android:layout_height="wrap_content"
          android:descendantFocusability="blocksDescendants" />

  </androidx.core.widget.NestedScrollView>

  <include layout="@layout/ite_tool_bar" />

</androidx.coordinatorlayout.widget.CoordinatorLayout>

遇到的问题和解决办法

NestedScrollView下的ViewPager视图被压缩不显示


   **NestedScrollView** 设置 **android:fillViewport="true"**

ViewPager上部分被Toolba遮挡

   **NestedScrollView** 设置了 **app:layout_behavior="@string/appbar_scrolling_view_behavior"** toolbar就不会把ViewPager遮挡住。

修改好main_activity.xml之后效果是这样的:
技术分享图片

NestedScrollView与ListView滑动冲突

技术分享图片
滑动ListView时出现了很影响体验的问题,查找了许多文章,最后再这里找到了解决办法【Android CoordinatorLayout实战案例学习《一》

 listView.setNestedScrollingEnabled(true);

文章的博主也说了另外一种方法是弃用ListView改为RecyclerView

完成后效果:
技术分享图片

在解决问题时阅读到的相关优秀文章

Material Design系列教程(5) - NestedScrollView

Android CoordinatorLayout实战案例学习《一》

Android 详细分析AppBarLayout的五种ScrollFlags

Toolbar基本使用

Toolbar+TabLayout+ViewPager达成Android最优导航栏

实现Toolbar滑动隐藏问题与解决

原文:https://www.cnblogs.com/zzerx/p/12465168.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!