這篇文章主要介紹android怎么實現(xiàn)上滑屏幕隱藏底部菜單欄,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
創(chuàng)新互聯(lián)公司于2013年創(chuàng)立,先為香河等服務建站,香河等地企業(yè),進行企業(yè)商務咨詢服務。為香河企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。引用github上一個仿今日頭條項目,項目地址: https://github.com/iMeiji/Toutiao ,主要實現(xiàn)的功能是底部菜單欄隨用戶手勢滑動而變化可見狀態(tài)
布局代碼
這個功能實現(xià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" 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的布局代碼,第一個是菜單欄,第二個是內(nèi)容界面,第三個是bottom。bottom導航欄這里采用是BottomNavigationView,具體用法不在介紹。
這里主要看一下BottomNavigationView的 app:layout_behavior 屬性,該屬性是協(xié)調布局特有的。網(wǎng)上的一版用法是app:layout_behavior="@string/appbar_scrolling_view_behavior"
雖然表面上看是一個字符串,其實在里面調用的也是一個view類。這次我們通過自定義這個behavior類,實現(xiàn)底部菜單欄的顯隱性。
java實現(xiàn)類
public class BottomNavigationBehavior extends CoordinatorLayout.Behavior<View> { private ObjectAnimator outAnimator, inAnimator; public BottomNavigationBehavior(Context context, AttributeSet attrs) { super(context, attrs); } // 垂直滑動 @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(); } } } }
這個類的就是剛剛那個 app:layout_behavior="com.meiji.toutiao.widget.behavior.BottomNavigationBehavior" 屬性標明的類,看起來很簡單,繼承了Behavior抽象類,然后實現(xiàn)了兩個方法。來看一下源碼如何解釋:
onStartNestedScroll:這個方法主要用于監(jiān)聽協(xié)調布局的子view的滾動事件,當此方法返回true,表示要消耗此動作,繼而執(zhí)行下面的 onNestedPreScroll 方法,我們在代碼中返回的是,滾動軸是不是豎直滾動軸。如果是的話,就返回true
onNestedPreScroll:這個方法就比較簡單了,當用戶上滑的時候,隱藏底部菜單欄,這里使用了動畫退出,使用了 ObjectAnimator.ofFloat 方法,第一個是view對象,指的就是bottom,第二個是Y軸的變化,第三個是Y軸變化的多少,接下來設置動畫秒數(shù)。
以上是“android怎么實現(xiàn)上滑屏幕隱藏底部菜單欄”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
文章名稱:android怎么實現(xiàn)上滑屏幕隱藏底部菜單欄-創(chuàng)新互聯(lián)
新聞來源:http://chinadenli.net/article26/cdjscg.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供關鍵詞優(yōu)化、域名注冊、云服務器、定制網(wǎng)站、軟件開發(fā)、網(wǎng)站收錄
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容