Android開發(fā)之BottomSheetDialog組件的使用
Bottom Sheet
Bottom Sheet 是 Design Support Library 23.2 版本引入的一個類似于對話框的控件,可以暫且叫做底部彈出框。Bottom Sheet 中的內(nèi)容默認(rèn)是隱藏起來的,只顯示很小一部分,可以通過在代碼中設(shè)置其狀態(tài)或者手勢操作將其完全展開,或者完全隱藏,或者部分隱藏。
有兩種類型的 Bottom Sheet:
1. Persistent bottom sheet: 通常用于顯示主界面之外的額外信息,它是主界面的一部分,只不過默認(rèn)被隱藏了,其深度(elevation)跟主界面處于同一級別;還有一個重要特點是在 Persistent bottom sheet 打開的時候,主界面仍然是可操作的,其實 Persistent bottom sheet 不能算是一個控件,因為它只是一個普通的布局在 CoordinatorLayout 這個布局之下所表現(xiàn)出來的特殊行為。所以其使用方式跟普通的控件也很不一樣,它必須在CoordinatorLayout 中,并且是CoordinatorLayout 的直接子 View 。
- app:layout_behavior="@string/bottom_sheet_behavior", 定義了這個屬性就相當(dāng)于告訴了 CoordinatorLayout 該布局是一個 bottom sheet, 它的顯示和交互和普通的 view 不同。@string/bottom_sheet_behavior 是一個定義在支持庫中的字符串,等效于 android.support.design.widget.BottomSheetBehavior 。
Bottom Sheets 具有物種狀態(tài):
- STATE_COLLAPSED: Bottom Sheets 是可見的,但只顯示可視高度(即部分可見)。此狀態(tài)通 常是底部工作表的“靜止位置”。可視高度由開發(fā)人員選擇,應(yīng)足以表明有額外的內(nèi)容,允許用 戶觸發(fā)某個動作或擴展 Bottom Sheets;
- STATE_EXPANDED: Bottom Sheets 是可見的并且它是最大高度并且不是拖拽或沉降;
- STATE_DRAGGING: 用戶主動向上或向下拖動 Bottom Sheets;
- STATE_SETTLING: 拖動/輕掃手勢后,Bottom Sheets 將調(diào)整到特點高度。這將是可視高 度,展開高度或0,以防用戶操作導(dǎo)致底部表單隱藏;
- STATE_HIDDEN: Bottom Sheets 隱藏;
如果已經(jīng)在 Activity 使用 CoordinatorLayout,添加底部表單很簡單:
1. 將任何視圖添加為 CoordinatorLayout 的直接子視圖。
2. 通過在 xml 里添加如下屬性:
app:layout_behavior="@string/bottom_sheet_behavior"
"@string/bottom_sheet_behavior" == "com.google.android.material.bottomsheet.BottomSheetBehavior",是定義在支持庫中的字符串。
3. 設(shè)置所需的行為標(biāo)志:
- app:behavior_hideable: 是否可以通過拖拽隱藏底部表單。
- app:behavior_peekHeight: 折疊狀態(tài)的窺視高度。
- app:behavior_skipCollapsed: 如果底部表單可隱藏,并且設(shè)置為 true, 則表單不會處于折疊 狀態(tài)。
BottomSheetBehavior
bottom sheet 的狀態(tài)是通過 BottomSheetBehavior 來設(shè)置的,因此需要先得到 BottomSheetBehavior 對象,然后調(diào)用 BottomSheetBehavior.setState() 來設(shè)置狀態(tài),比如設(shè)置為折疊狀態(tài)。當(dāng)然也可以使用 getState() 來獲取當(dāng)前狀態(tài)。
// TODO 得到 BottomSheetBehavior 對象 bottomSheetBehavior = BottomSheetBehavior.from(binding.bottomSheet);
// TODO 設(shè)置為折疊狀態(tài) bottomSheetBehavior.setState(BottomSheetBehavior.STATE_COLLAPSED);
// TODO 獲取當(dāng)前 BottomSheetBehavior 的狀態(tài) bottomSheetBehavior.getState()
要監(jiān)聽 Bottom Sheet 的狀態(tài)變化則要使用 addBottomSheetCallback() 方法,之所以要監(jiān)聽是因為 Bottom Sheet 的狀態(tài)還可以通過手勢來改變。
bottomSheetBehavior.addBottomSheetCallback(new BottomSheetBehavior.BottomSheetCallback() { @Override public void onStateChanged(@NonNull View bottomSheet, int newState) { Log.i("HL", "newState" + newState); } @Override public void onSlide(@NonNull View bottomSheet, float slideOffset) { Log.i("HL", "sdeOffset: " + slideOffset); } });
2. 模態(tài) bottom sheet: 顧名思義,模態(tài)的 bottom sheet 在打開的時候會阻止和主界面的交互,并且在視覺上會在 bottom sheet 背后加一層半透明的陰影,使得看上去深度(evelation)更深。
BottomSheetDialog
BottomSheetDialog 是擁有 MD 風(fēng)格的底部彈出框樣式的 Dialog,其基本的使用為:
// TODO 創(chuàng)建 View 作為 BottomSheetDialog 的內(nèi)容展示, View bt = getLayoutInflater().inflate(R.layout.dialog_bottom_sheet, null); // TODO 將 View 添加進來 mBottomSheetDialog.setContentView(bt); mBottomSheetDialog.show();
完整 Demo
鏈接: https://pan.baidu.com/s/1ozPLg2j8pByY4lk0XnSI2Q
提取碼: bsu8
到此這篇關(guān)于Android開發(fā)之BottomSheetDialog組件的使用的文章就介紹到這了,更多相關(guān)Android BottomSheetDialog內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android取消EditText自動獲取默認(rèn)焦點
本文主要介紹了Android取消EditText自動獲取焦點默認(rèn)行為的方法,具有很好的參考價值。下面跟著小編一起來看下吧2017-03-03android實現(xiàn)手機App實現(xiàn)拍照功能示例
本篇文章主要介紹了android實現(xiàn)手機App實現(xiàn)拍照功能示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02另外兩種Android沉浸式狀態(tài)欄實現(xiàn)思路
這篇文章主要為大家介紹了另外兩種Android沉浸式狀態(tài)欄實現(xiàn)思路,android5.0及以后版本都支持給狀態(tài)欄著色,而目前android主流版本還是4.4,想要深入了解的朋友可以參考一下2016-01-01詳解Android中提示對話框(ProgressDialog和DatePickerDialog和TimePickerDi
這篇文章主要介紹了詳解Android中提示對話框(ProgressDialog和DatePickerDialog和TimePickerDialog&PopupWindow)的相關(guān)資料,需要的朋友可以參考下2016-01-01Android實現(xiàn)頁面跳轉(zhuǎn)的全過程記錄
對于android軟件開發(fā)初級學(xué)習(xí)者來說,簡單的頁面跳轉(zhuǎn)是必學(xué)的,這篇文章主要給大家介紹了關(guān)于Android實現(xiàn)頁面跳轉(zhuǎn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-10-10