相信经常使用掘金APP的用户来说应该会很熟悉掘金客户端的滑动效果,滑动时适时的隐藏掉Title和底部导航栏,使得更多的内容显示在用户的界面上,从而增加用户的阅读体验。
在本文中将带你使用第三方库来简单的实现掘金的导航栏+悬浮按钮效果
先贴下 ByeBurger库的github地址 :github.com/githubwing/…
以及实现的最终效果图:
看着还挺不错的样子,进入正题。
1.首先理所当然的是引入编译库
allprojects {
repositories {
jcenter()
maven { url "https://jitpack.io" }
}
}
dependencies {
compile 'com.github.githubwing:ByeBurger:1.2.3'
compile 'com.android.support:design:25.0.0'
}
2. 在你的页面布局中使用CoordinatorLayout 作为页面布局的根节点,将需要控制隐藏与显示的View作为CoordinatorLayout 的直接子View,并添加 app:layout_behavior属性,布局格式如下:
<!--这里放置你的Viewpager -->
这里的布局,你的TitleView可以是一个RelativeLayout,ToolBar,也可以是TabLayout,BottomView同理。
在以上的效果图中,博主使用的是TabLayout,有小伙伴说Tab中的英文字母会变成大写,但没关系,可以使用以下方式来设置
<item name="textAllCaps">false</item>
<item name="tabTextAppearance">@style/MyTabStyle</item>
然后在TabLayout 中使用该样式。 3. 控制TitleView和底部导航栏以及悬浮按钮的显示与隐藏
ByeBurgerBehavior.from(mTitleView).hide()
ByeBurgerBehavior.show(mBottomView).show()
需要注意的是: 1). 如果TitleView使用的是ToolBar的控件,别忘了将Theme改为NoActionBar
android:theme="@style/Theme.AppCompat.Light.NoActionBar"
2). 注意布局的层级问题,需要控制显隐的控件,一定是CoordinatorLayout 的直接子View 基本上到这里就完成使用ByeBurger库所具备的东西,剩下工作就只是实现你的Fragmen逻辑,在本文中由于TabLayout切换碎片的功能跟底部的导航栏类似,所以并未去实现切换逻辑。
最后是该demo的github地址:github.com/shanerou/Wi…