android實(shí)現(xiàn)上滑屏幕隱藏底部菜單欄的示例
本篇文章引用github上一個(gè)仿今日頭條項(xiàng)目,項(xiàng)目地址: https://github.com/iMeiji/Toutiao ,主要實(shí)現(xiàn)的功能是底部菜單欄隨用戶手勢(shì)滑動(dòng)而變化可見狀態(tài)
布局代碼
這個(gè)功能實(shí)現(xiàn)起來比較簡(jiǎn)單,主要利用了CoordinatorLayout的 layout_behavior 的屬性。具體代碼如下:
<android.support.design.widget.CoordinatorLayout android:layout_width="match_parent" android:layout_height="match_parent"> <include layout="@layout/toolbar"/> <include layout="@layout/container"/> <android.support.design.widget.BottomNavigationView android:id="@+id/bottom_navigation" style="@style/Widget.Design.BottomNavigationView" android:layout_width="match_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true" android:layout_gravity="bottom" android:background="@color/viewBackground" app:elevation="16dp" app:itemIconTint="@drawable/nav_item_color_state" app:itemTextColor="@drawable/nav_item_color_state" app:layout_behavior="com.meiji.toutiao.widget.behavior.BottomNavigationBehavior" app:menu="@menu/bottom_navigation_main"/>
上面是activity_main的布局代碼,第一個(gè)是菜單欄,第二個(gè)是內(nèi)容界面,第三個(gè)是bottom。bottom導(dǎo)航欄這里采用是BottomNavigationView,具體用法不在介紹。
這里主要看一下BottomNavigationView的 app:layout_behavior 屬性,該屬性是協(xié)調(diào)布局特有的。網(wǎng)上的一版用法是app:layout_behavior="@string/appbar_scrolling_view_behavior"
雖然表面上看是一個(gè)字符串,其實(shí)在里面調(diào)用的也是一個(gè)view類。這次我們通過自定義這個(gè)behavior類,實(shí)現(xiàn)底部菜單欄的顯隱性。
java實(shí)現(xiàn)類
public class BottomNavigationBehavior extends CoordinatorLayout.Behavior<View> { private ObjectAnimator outAnimator, inAnimator; public BottomNavigationBehavior(Context context, AttributeSet attrs) { super(context, attrs); } // 垂直滑動(dòng) @Override public boolean onStartNestedScroll(CoordinatorLayout coordinatorLayout, View child, View directTargetChild, View target, int nestedScrollAxes) { return nestedScrollAxes == ViewCompat.SCROLL_AXIS_VERTICAL; } @Override public void onNestedPreScroll(CoordinatorLayout coordinatorLayout, View child, View target, int dx, int dy, int[] consumed) { if (dy > 0) {// 上滑隱藏 if (outAnimator == null) { outAnimator = ObjectAnimator.ofFloat(child, "translationY", 0, child.getHeight()); outAnimator.setDuration(200); } if (!outAnimator.isRunning() && child.getTranslationY() <= 0) { outAnimator.start(); } } else if (dy < 0) {// 下滑顯示 if (inAnimator == null) { inAnimator = ObjectAnimator.ofFloat(child, "translationY", child.getHeight(), 0); inAnimator.setDuration(200); } if (!inAnimator.isRunning() && child.getTranslationY() >= child.getHeight()) { inAnimator.start(); } } } }
這個(gè)類的就是剛剛那個(gè) app:layout_behavior="com.meiji.toutiao.widget.behavior.BottomNavigationBehavior" 屬性標(biāo)明的類,看起來很簡(jiǎn)單,繼承了Behavior抽象類,然后實(shí)現(xiàn)了兩個(gè)方法。來看一下源碼如何解釋:
onStartNestedScroll:這個(gè)方法主要用于監(jiān)聽協(xié)調(diào)布局的子view的滾動(dòng)事件,當(dāng)此方法返回true,表示要消耗此動(dòng)作,繼而執(zhí)行下面的 onNestedPreScroll 方法,我們?cè)诖a中返回的是,滾動(dòng)軸是不是豎直滾動(dòng)軸。如果是的話,就返回true
onNestedPreScroll:這個(gè)方法就比較簡(jiǎn)單了,當(dāng)用戶上滑的時(shí)候,隱藏底部菜單欄,這里使用了動(dòng)畫退出,使用了 ObjectAnimator.ofFloat 方法,第一個(gè)是view對(duì)象,指的就是bottom,第二個(gè)是Y軸的變化,第三個(gè)是Y軸變化的多少,接下來設(shè)置動(dòng)畫秒數(shù)。
后記
還可以通過監(jiān)聽appbar來實(shí)現(xiàn)bottom的動(dòng)畫。可以參考這篇文章 http://www.dbjr.com.cn/article/134141.htm
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Flutter+Metal實(shí)現(xiàn)圖像處理詳細(xì)流程
Flutter使用CVPixelBuffer和iOS交互,我們可以直接使用CVPixelBuffer創(chuàng)建MTLTexture,然后將MTLTexture設(shè)置為渲染目標(biāo),這篇文章主要介紹了Flutter+Metal實(shí)現(xiàn)圖像處理,需要的朋友可以參考下2022-06-06使用Android Studio 開發(fā)自己的SDK教程
很多時(shí)候我們要將自己開發(fā)一個(gè)類庫打包成jar包以供他調(diào)用,這個(gè)jar包也叫你自己的SDK或者叫l(wèi)ibrary。android studio生成jar包的方法與eclipse有所不同。在studio中l(wèi)ibrary其實(shí)是module的概念。2017-10-10Crashlytics Android 異常報(bào)告統(tǒng)計(jì)管理(詳解)
下面小編就為大家?guī)硪黄狢rashlytics Android 異常報(bào)告統(tǒng)計(jì)管理(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05Android 圓角邊框的實(shí)現(xiàn)方式匯總
這篇文章主要介紹了Android 圓角邊框的實(shí)現(xiàn)方式匯總的相關(guān)資料,需要的朋友可以參考下2016-03-03android自定義開關(guān)控件-SlideSwitch的實(shí)例
本篇文章主要介紹了android自定義開關(guān)控件-SlideSwitch的實(shí)例,實(shí)現(xiàn)了手機(jī)控件開關(guān)的功能,感興趣的小伙伴們可以參考一下。2016-11-11Android開發(fā)實(shí)現(xiàn)的ViewPager引導(dǎo)頁功能(動(dòng)態(tài)加載指示器)詳解
這篇文章主要介紹了Android開發(fā)實(shí)現(xiàn)的ViewPager引導(dǎo)頁功能(動(dòng)態(tài)加載指示器),結(jié)合實(shí)例形式詳細(xì)分析了Android使用ViewPager引導(dǎo)頁的具體步驟,相關(guān)布局、功能使用技巧,需要的朋友可以參考下2017-11-11以一個(gè)著色游戲展開講解Android中區(qū)域圖像填色的方法
這篇文章主要介紹了Android中實(shí)現(xiàn)區(qū)域圖像顏色填充的方法,文中以一個(gè)著色游戲?yàn)槔v解了邊界的填充等各種填色操作,需要的朋友可以參考下2016-02-02動(dòng)態(tài)添加LinearLayout的高度實(shí)例
下面小編就為大家?guī)硪黄獎(jiǎng)討B(tài)添加LinearLayout的高度實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04Android使用Intent顯示實(shí)現(xiàn)頁面跳轉(zhuǎn)
這篇文章主要為大家詳細(xì)介紹了Android使用Intent顯示實(shí)現(xiàn)頁面跳轉(zhuǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08