BottomSheets的简单使用

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种:

  • STATE_HIDDEN: 隐藏状态。默认是false,可通过app:behavior_hideable属性设置。
  • STATE_COLLAPSED: 折叠关闭状态。可通过app:behavior_peekHeight来设置显示的高度,peekHeight默认是0。
  • STATE_DRAGGING: 被拖拽状态
  • STATE_SETTLING: 拖拽松开之后到达终点位置(collapsed or expanded)前的状态。
  • STATE_EXPANDED: 完全展开的状态。

最后开关控制代码

if(behavior.getState() == BottomSheetBehavior.STATE_EXPANDED) {
    behavior.setState(BottomSheetBehavior.STATE_COLLAPSED);
}else {
    behavior.setState(BottomSheetBehavior.STATE_EXPANDED);
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 伫立在边关的城墙上 以大漠孤烟为友 与长河落日为伴 瘦马在啃食枯草 野犬在远处哀嚎 大雪覆盖万仞山 飞鸿茕茕复盘旋...
    岩子花阅读 154评论 0 1
  • 她清秀的脸颊上架着一副半框的眼镜,一双不大不小的眼睛与脸庞和身材都搭配的恰到好处,浑然天成的书卷气,典型的...
    缤纷生活创作者阅读 159评论 0 0
  • 你的脾气 决定你的人生 1、 古语云:水深则流缓,语迟则人贵。 脾气慢不等于迟钝,话在心里晚一会儿再说也并非胆怯,...
    雨林大大阅读 168评论 0 0
  • 第二十一章 凤九想起那日在太晨宫的情形,心里十分难受,便一手幻化出一颗璀璨的夜明珠,双手递到帝君的胸前,冷冷的说:...
    琳达_linda阅读 31,935评论 10 75