Android bc信用盤搭建自訂behavior 實現上滑 隱藏底部view

來源:互聯網
上載者:User

標籤:是的   tor   內容   round   nes   att   http   導航   col   

布局

<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"/>

Android bc信用盤搭建 dsluntan.com VX:17061863513自訂behavior 實現上滑 隱藏底部view

bc信用盤搭建 dsluntan.com VX:17061863513

上面是activity_main的布局代碼,第一個是功能表列,第二個是內容介面,第三個是bottom。bottom導覽列這裡採用是BottomNavigationView,具體用法不在介紹。

這裡主要看一下BottomNavigationView的 app:layout_behavior 屬性,該屬性是協調布局特有的。網上的一版用法是app:layout_behavior="@string/appbar_scrolling_view_behavior"

雖然表面上看是一個字串,其實在裡面調用的也是一個view類。這次我們通過自訂這個behavior類,實現底部功能表列的顯隱性。

java實作類別

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抽象類別,然後實現了兩個方法。來看一下源碼如何解釋

onStartNestedScroll:這個方法主要用於監聽協調布局的子view的滾動事件,當此方法返回true,表示要消耗此動作,繼而執行下面的 onNestedPreScroll 方法,我們在代碼中返回的是,捲軸是不是豎直捲軸。如果是的話,就返回true

onNestedPreScroll:這個方法就比較簡單了,當使用者上滑的時候,隱藏底部功能表列,這裡使用了動畫退出,使用了 ObjectAnimator.ofFloat 方法,第一個是view對象,指的就是bottom,第二個是Y軸的變化,第三個是Y軸變化的多少,接下來設定動畫秒數。

Android bc信用盤搭建自訂behavior 實現上滑 隱藏底部view

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.