亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

android BottomSheetDialog新控件解析實(shí)現(xiàn)知乎評論列表效果(實(shí)例代碼)

瀏覽:88日期:2022-06-07 14:07:03

BottomSheetDialog使用解析

Android Support Library 23.2里的 Design Support Library新加了一個(gè)Bottom Sheets控件,Bottom Sheets顧名思義就是底部操作控件,用于在屏幕底部創(chuàng)建一個(gè)可滑動關(guān)閉的視圖,可以替代對話框和菜單。其中包含BottomSheets、BottomSheetDialog和BottomSheetDialogFragment三種可以使用。其中應(yīng)用較多的控件是BottomSheetDialog,主要運(yùn)用在界面底部分享列表,評論列表等,最近在知乎評論列表界面看到知乎運(yùn)用到了這個(gè)效果,所有在這里詳細(xì)介紹一下該控件的使用,以及簡單實(shí)現(xiàn)知乎評論列表功能。本文實(shí)現(xiàn)效果如下:

android BottomSheetDialog新控件解析實(shí)現(xiàn)知乎評論列表效果(實(shí)例代碼)

首先我們想要使用BottomSheets相關(guān)控件,需要先在build.gradle中添加design依賴,本文中使用的是:

compile ’com.android.support:design:25.3.0’

BottomSheetDialog可以替代大多數(shù)網(wǎng)格顯示和列表展示的dialog和popupwindow,默認(rèn)寬度撐滿,并且在BottomSheetDialog 區(qū)域中向下滑動也讓對話框消失。

接下來創(chuàng)建BottomSheetDialog的布局文件dialog_bottomsheet.xml,布局文件如下:

<?xml version='1.0' encoding='utf-8'?><RelativeLayout xmlns:android='http://schemas.android.com/apk/res/android' android:layout_width='match_parent' android:layout_height='wrap_content'> <RelativeLayout android: android:layout_width='match_parent' android:layout_height='45dp' android:background='@drawable/dialog_bottomsheet_shape'> <ImageView android: android:layout_width='45dp' android:layout_height='45dp' android:layout_centerVertical='true' android:layout_marginLeft='5dp' android:padding='5dp' android:src='http://www.aoyou183.cn/bcjs/@drawable/img_close' /> <TextView android:layout_width='wrap_content' android:layout_height='wrap_content' android:layout_centerVertical='true' android:layout_marginLeft='10dp' android:layout_toRightOf='@id/dialog_bottomsheet_iv_close' android:text='評論' android:textColor='#333' android:textSize='16sp' /> </RelativeLayout> <android.support.v7.widget.RecyclerView android: android:layout_width='match_parent' android:layout_height='match_parent' android:layout_below='@id/dialog_bottomsheet_rl_title' android:background='#fff' /></RelativeLayout>

布局文件中,主要包含一個(gè)RecyclerView和一個(gè)頭布局。

然后,我們在Activity界面添加BottomSheetDailog初始化方法,

private void showSheetDialog() { View view = View.inflate(BottomSheetDialogActivity.this, R.layout.dialog_bottomsheet, null); iv_dialog_close = (ImageView) view.findViewById(R.id.dialog_bottomsheet_iv_close); rv_dialog_lists = (RecyclerView) view.findViewById(R.id.dialog_bottomsheet_rv_lists); iv_dialog_close.setOnClickListener(this); bottomSheetAdapter = new BottomSheetAdapter(BottomSheetDialogActivity.this, list_strs); rv_dialog_lists.setHasFixedSize(true); rv_dialog_lists.setLayoutManager(new LinearLayoutManager(BottomSheetDialogActivity.this)); rv_dialog_lists.setItemAnimator(new DefaultItemAnimator()); rv_dialog_lists.setAdapter(bottomSheetAdapter); bottomSheetDialog = new BottomSheetDialog(BottomSheetDialogActivity.this, R.style.dialog); bottomSheetDialog.setContentView(view); }

在改方法中,我們首先獲取BottomSheetDialog的布局文件,獲取該布局文件中相關(guān)控件,通過創(chuàng)建模擬列表數(shù)據(jù),為RecyclerView添加適配器

for (int i=0; i<20; i++) { list_strs.add('評論' + i); }

通過如下代碼,創(chuàng)建BottomSheetDialog對象

bottomSheetDialog = new BottomSheetDialog(BottomSheetDialogActivity.this, R.style.dialog);bottomSheetDialog.setContentView(view);

至此,我們即可以通過調(diào)用

bottomSheetDialog.show();

方法來查看BottomSheetDialog顯示效果

使用過程中出現(xiàn)的問題

當(dāng)我們向下滑動BottomSheetDialog隱藏Dialog后,無法用bottomSheetDialog.show()再次打開,為什么呢?我們先看下源碼的實(shí)現(xiàn):

@Overridepublic void setContentView(View view, ViewGroup.LayoutParams params) { super.setContentView(wrapInBottomSheet(0, view, params));}private View wrapInBottomSheet(int layoutResId, View view, ViewGroup.LayoutParams params) { final CoordinatorLayout coordinator = View.inflate(getContext(),R.layout...., null); FrameLayout bottomSheet = (FrameLayout) coordinator.findViewById(R.id.design_bottom_sheet); BottomSheetBehavior.from(bottomSheet).setBottomSheetCallback(mBottomSheetCallback); ... return coordinator;}private BottomSheetCallback mBottomSheetCallback = new BottomSheetCallback() { @Override public void onStateChanged(@NonNull View bottomSheet, int newState) { if (newState == BottomSheetBehavior.STATE_HIDDEN) { dismiss(); //關(guān)鍵代碼 } } @Override public void onSlide(@NonNull View bottomSheet, float slideOffset) { }};

通過源碼文件我們可以看出,系統(tǒng)的BottomSheetDialog是基于BottomSheetBehavior封裝的,當(dāng)我們滑動隱藏了BottomSheetBehavior中的View后,內(nèi)部是設(shè)置了BottomSheetBehavior的狀態(tài)為STATE_HIDDEN,接著它替我們關(guān)閉了Dialog,所以我們再次調(diào)用show()的時(shí)候Dialog沒法再此打開狀態(tài)為HIDE的Dialog了。 查看了源文件,我們就通過復(fù)寫B(tài)ottomSheetCallback的回調(diào)方法,來實(shí)現(xiàn)我們的效果,這里就引入了BottomSheetBehavior,下面先介紹BottomSheetBehavior的使用。

BottomSheetBehavior的作用

根據(jù)官方Api,BottomSheetBehavior有一個(gè)靜態(tài)方法BottomSheetBehavior.from(View),會返回這個(gè)View引用的BottomSheetBehavior,這個(gè)方法會檢查這個(gè)View是否是CoordinatorLayout的子View,如果是就會得到這個(gè)View的Behavior。通過BottomSheetBehavior,我們可以通過setPeekHeight(int height)設(shè)置dialog的顯示高度,通過setBottomSheetCallback(callback)實(shí)現(xiàn)BottomSheetDialog的狀態(tài)監(jiān)聽。其中,在BottomSheetCallback回調(diào)方法中,onStateChanged監(jiān)聽狀態(tài)的改變,onSlide是拖拽的回調(diào),onStateChanged可以監(jiān)聽到的回調(diào)一共有五種:

STATE_HIDDEN: 隱藏狀態(tài)。默認(rèn)是false,可通過app:behavior_hideable屬性設(shè)置。 STATE_COLLAPSED: 折疊關(guān)閉狀態(tài)。可通過app:behavior_peekHeight來設(shè)置顯示的高度,peekHeight默認(rèn)是0。 STATE_DRAGGING: 被拖拽狀態(tài) STATE_SETTLING: 拖拽松開之后到達(dá)終點(diǎn)位置(collapsed or expanded)前的狀態(tài)。 STATE_EXPANDED: 完全展開的狀態(tài)。

那么如何獲取到BottomSheetDialog的BottomSheetBehavior呢?

第一種:在BottomSheetDialog調(diào)用setContentView方法之后,調(diào)用

BottomSheetBehavior mDialogBehavior = BottomSheetBehavior.from((View) mContentView.getParent());

第二種:在BottomSheetDialog調(diào)用setContentView方法之后,調(diào)用

final FrameLayout frameLayout = (FrameLayout) dialog.findViewById(android.support.design.R.id.design_bottom_sheet);frameLayout.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() { @Override public void onGlobalLayout() { frameLayout.getViewTreeObserver().removeGlobalOnLayoutListener(this); BottomSheetBehavior behavior = BottomSheetBehavior.from(frameLayout); //調(diào)用behavior相關(guān)方法 ... frameLayout.forceLayout();}

通過上面的介紹,修改上文中的showSheetDialog()用于解決上文中出現(xiàn)的問題,代碼如下:

private void showSheetDialog() { View view = View.inflate(BottomSheetDialogActivity.this, R.layout.dialog_bottomsheet, null); iv_dialog_close = (ImageView) view.findViewById(R.id.dialog_bottomsheet_iv_close); rv_dialog_lists = (RecyclerView) view.findViewById(R.id.dialog_bottomsheet_rv_lists); iv_dialog_close.setOnClickListener(this); bottomSheetAdapter = new BottomSheetAdapter(BottomSheetDialogActivity.this, list_strs); rv_dialog_lists.setHasFixedSize(true); rv_dialog_lists.setLayoutManager(new LinearLayoutManager(BottomSheetDialogActivity.this)); rv_dialog_lists.setItemAnimator(new DefaultItemAnimator()); rv_dialog_lists.setAdapter(bottomSheetAdapter); bottomSheetDialog = new BottomSheetDialog(BottomSheetDialogActivity.this, R.style.dialog); bottomSheetDialog.setContentView(view); mDialogBehavior = BottomSheetBehavior.from((View) view.getParent()); mDialogBehavior.setPeekHeight(getWindowHeight()); mDialogBehavior.setBottomSheetCallback(new BottomSheetBehavior.BottomSheetCallback() { @Override public void onStateChanged(@NonNull View bottomSheet, int newState) { if (newState == BottomSheetBehavior.STATE_HIDDEN) { bottomSheetDialog.dismiss(); mDialogBehavior.setState(BottomSheetBehavior.STATE_COLLAPSED); } } @Override public void onSlide(@NonNull View bottomSheet, float slideOffset) { } }); }

在監(jiān)聽到用戶滑動關(guān)閉BottomSheetDialog后,我們把BottomSheetBehavior的狀態(tài)設(shè)置為BottomSheetBehavior.STATE_COLLAPSED,也就是半個(gè)打開狀態(tài)(BottomSheetBehavior.STATE_EXPANDED為全打開),至此就解決了調(diào)用show()方法無法正常打開的問題。同時(shí)我們通過設(shè)置setPeekHeight和BottomSheetDialog的透明主題來實(shí)現(xiàn)知乎評論列表的效果。 在values/styles.xml文件中添加透明主題

<style name='dialog' parent='@android:style/Theme.Dialog'> <item name='android:windowFrame'>@null</item> <item name='android:windowIsFloating'>true</item> <item name='android:windowIsTranslucent'>true</item> <item name='android:windowNoTitle'>true</item> <item name='android:background'>@android:color/transparent</item> <item name='android:windowBackground'>@android:color/transparent</item> <item name='android:backgroundDimEnabled'>true</item> <item name='android:backgroundDimAmount'>0.6</item> </style>

最后附上Activity界面完整代碼如下:

public class BottomSheetDialogActivity extends AppCompatActivity implements View.OnClickListener { private Button bt_start; private ImageView iv_dialog_close; private RecyclerView rv_dialog_lists; private BottomSheetAdapter bottomSheetAdapter; private BottomSheetDialog bottomSheetDialog; private BottomSheetBehavior mDialogBehavior; private List<String> list_strs; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_bottom_sheet_dialog); list_strs = new ArrayList<>(); initView(); showSheetDialog(); } private void initView() { bt_start = (Button) findViewById(R.id.main_bt_start); for (int i=0; i<20; i++) { list_strs.add('評論' + i); } bt_start.setOnClickListener(this); } private void showSheetDialog() { View view = View.inflate(BottomSheetDialogActivity.this, R.layout.dialog_bottomsheet, null); iv_dialog_close = (ImageView) view.findViewById(R.id.dialog_bottomsheet_iv_close); rv_dialog_lists = (RecyclerView) view.findViewById(R.id.dialog_bottomsheet_rv_lists); iv_dialog_close.setOnClickListener(this); bottomSheetAdapter = new BottomSheetAdapter(BottomSheetDialogActivity.this, list_strs); rv_dialog_lists.setHasFixedSize(true); rv_dialog_lists.setLayoutManager(new LinearLayoutManager(BottomSheetDialogActivity.this)); rv_dialog_lists.setItemAnimator(new DefaultItemAnimator()); rv_dialog_lists.setAdapter(bottomSheetAdapter); bottomSheetDialog = new BottomSheetDialog(BottomSheetDialogActivity.this, R.style.dialog); bottomSheetDialog.setContentView(view); mDialogBehavior = BottomSheetBehavior.from((View) view.getParent()); mDialogBehavior.setPeekHeight(getWindowHeight()); mDialogBehavior.setBottomSheetCallback(new BottomSheetBehavior.BottomSheetCallback() { @Override public void onStateChanged(@NonNull View bottomSheet, int newState) { if (newState == BottomSheetBehavior.STATE_HIDDEN) { bottomSheetDialog.dismiss(); mDialogBehavior.setState(BottomSheetBehavior.STATE_COLLAPSED); } } @Override public void onSlide(@NonNull View bottomSheet, float slideOffset) { } }); } private int getWindowHeight() { Resources res = BottomSheetDialogActivity.this.getResources(); DisplayMetrics displayMetrics = res.getDisplayMetrics(); return displayMetrics.heightPixels; } @Override public void onClick(View v) { switch (v.getId()) { case R.id.main_bt_start: if (bottomSheetDialog != null) { bottomSheetDialog.show(); } break; case R.id.dialog_bottomsheet_iv_close: if (bottomSheetDialog != null) { bottomSheetDialog.dismiss(); } break; } }}

到此這篇關(guān)于android BottomSheetDialog新控件解析實(shí)現(xiàn)知乎評論列表效果的文章就介紹到這了,更多相關(guān)android 知乎評論列表內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: 知乎
相關(guān)文章:
主站蜘蛛池模板: 林美仑在线三级播放 | 99久热只有精品视频免费观看17 | 亚洲日韩男人网在线 | 亚洲国产香蕉视频欧美 | 国产一国产一有一级毛片 | 久久机热综合久久国产 | 日韩特黄特色大片免费视频 | 亚洲精品国产成人中文 | 国产一区二区三区影院 | 久久国产精品免费一区二区三区 | 国产一区二区三区美女在线观看 | 香蕉视频在线观看国产 | 日韩视频www | 亚洲韩精品欧美一区二区三区 | 精品国产高清a毛片无毒不卡 | 青青草免费观看 | 欧美国产一区二区二区 | 中国一级淫片aaa毛片毛片 | 正在播放国产大学生情侣 | 亚洲色在线视频 | 欧美一级片毛片 | 国产真实露脸4p视频 | 黄+色+性+人免费 | 欧美午夜在线播放 | 中文偷拍视频在线观看 | 国产乱人免费视频 | 激情影院在线视频永久观看 | 二级黄绝大片中国免费视频 | 国产精品素人搭讪在线播放 | 欧美日韩性生活视频 | 欧美a级完整在线观看 | 国产网站免费视频 | 成人啪啪免费视频 | 99九九影院理论片在线 | 黑人巨大进入美女深处的视频 | 国产剧情麻豆mv在线观看 | 亚洲精品女同一区二区三区 | 黄色片一级视频 | 国产无限制自拍 | 久久精品视频在线 | a毛片免费在线观看 |