BottomSheets的简单使用

2018-08-31  本文已影响0人  柏林billy

BottomSheets的简单使用

一. 添加依赖

compile 'com.android.support:design:24.2.1'

二.布局代码添加

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    android:id="@+id/cl"
    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"
    android:fitsSystemWindows="true">

    <android.support.v4.widget.NestedScrollView
        android:id="@+id/bottom_sheet"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:behavior_hideable="true"
        app:behavior_peekHeight="50dp"
        app:layout_behavior="@string/bottom_sheet_behavior">

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical">
            <!-- 你的布局代码-->
        </LinearLayout>
    </android.support.v4.widget.NestedScrollView>
</android.support.design.widget.CoordinatorLayout>

app:behavior_hideable="true" 当我们拖拽下来的时候,bottom sheet能否全部隐藏

app:behavior_peekHeight="50dp" 当Bottom关闭的时候,底部最低高度,0表示最低为0就是是关闭后完全隐藏

app:layout_behavior="@string/bottom_sheet_behavior" 代表这是一个bottom Sheets

三.java代码的添加

BottomSheetBehavior behavior;
@Override
protected void onCreate(Bundle savedInstanceState)
{
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_bottom_sheet);
    View bottomSheet = findViewById(R.id.bottom_sheet);
    behavior = BottomSheetBehavior.from(bottomSheet);
    behavior.setBottomSheetCallback(new BottomSheetBehavior.BottomSheetCallback() {
        @Override
        public void onStateChanged(@NonNull View bottomSheet, int newState)
        {
            //这里是bottomSheet状态的改变
        }

        @Override
        public void onSlide(@NonNull View bottomSheet, float slideOffset)
        {
            //这里是拖拽中的回调,根据slideOffset可以做一些动画
        }
    });
     //监听添加界面的滑动,让他不能被滑动
    bottomSheet.setOnTouchListener(new View.OnTouchListener() {
        @Override
        public boolean onTouch(View v, MotionEvent event) {
            return true;
        }
    });
}

setBottomSheetCallback可以监听回调的状态,onStateChanged监听状态的改变,onSlide是拖拽的回调,onStateChanged可以监听到的回调一共有5种:

最后开关控制代码

if(behavior.getState() == BottomSheetBehavior.STATE_EXPANDED) {
    behavior.setState(BottomSheetBehavior.STATE_COLLAPSED);
}else {
    behavior.setState(BottomSheetBehavior.STATE_EXPANDED);
}
上一篇下一篇

猜你喜欢

热点阅读