Android側(cè)滑菜單控件DrawerLayout使用詳解
DrawerLayout是Android V4包下一個(gè)帶有側(cè)滑功能的布局控件,可以根據(jù)手勢(shì)展開(kāi)與隱藏側(cè)邊欄,也可以隨著側(cè)邊欄的點(diǎn)擊改變主界面區(qū)的內(nèi)容。并且只需要按照DrawerLayout規(guī)定的布局格式進(jìn)行布局,即可實(shí)現(xiàn)左右側(cè)滑效果。
一、約定的抽屜布局
DrawerLayout的布局一般分為三個(gè)部分:第一部分為主界面內(nèi)容布局,第二部分為左邊側(cè)滑界面布局,第三部分為右邊側(cè)滑界面布局。那么系統(tǒng)是怎么區(qū)分左邊側(cè)滑和右邊側(cè)滑的代碼塊的呢?請(qǐng)注意DrawerLayout布局中側(cè)滑部分的代碼塊必須指定android:layout_gravity屬性,layout_gravity="start/left"代表左邊側(cè)滑,layout_gravity="end/right"代表右邊側(cè)滑。在官方文檔中推薦DrawerLayout最好作為界面的根布局,否則可能會(huì)出現(xiàn)觸摸事件被屏蔽的問(wèn)題。DrawerLayout中主內(nèi)容區(qū)的布局要放到最頂層,接著放置左邊側(cè)滑界面布局,最后放置右邊側(cè)滑界面布局。類(lèi)似布局如下:
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/drawerlayout" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.administer.drawlayoutdemo.MainActivity"> <RelativeLayout android:id="@+id/relativelayout" android:layout_width="match_parent" android:layout_height="match_parent"> <Button android:id="@+id/left_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="開(kāi)啟左邊菜單欄" /> <Button android:id="@+id/right_btn" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="開(kāi)啟右邊菜單欄" android:layout_alignParentRight="true"/> </RelativeLayout> <RelativeLayout android:id="@+id/left" android:layout_width="200dp" android:layout_height="match_parent" android:layout_gravity="left" android:background="#f00"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="左邊布局" /> </RelativeLayout> <RelativeLayout android:id="@+id/right" android:layout_width="200dp" android:layout_height="match_parent" android:layout_gravity="right" android:background="#00f"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="右邊布局" /> </RelativeLayout> </android.support.v4.widget.DrawerLayout>
二、DrawerLayout的監(jiān)聽(tīng)
DrawerLayout的監(jiān)聽(tīng)器有三種。DrawerLayout添加監(jiān)聽(tīng)器的方法為drawerLayout.addDrawerListener(),由于DrawerLayout側(cè)滑菜單的展開(kāi)與隱藏均可以被監(jiān)聽(tīng),這樣我們就可以在側(cè)滑菜單展開(kāi)與隱藏發(fā)生的時(shí)刻做一些希望做的事情。(Ps:drawerLayout.setDrawerListener()已過(guò)時(shí),不過(guò)仍可使用,與drawerLayout.addDrawerListener()用途一樣)
1、使用DrawerListener監(jiān)聽(tīng)
drawerLayout.addDrawerListener(new DrawerLayout.DrawerListener() { @Override public void onDrawerSlide(View drawerView, float slideOffset) { /** * 抽屜滑動(dòng)時(shí),調(diào)用此方法 * */ } @Override public void onDrawerOpened(View drawerView) { /** * 抽屜被完全展開(kāi)時(shí),調(diào)用此方法 * */ } @Override public void onDrawerClosed(View drawerView) { /** * 抽屜被完全關(guān)閉時(shí),調(diào)用此方法 * */ } @Override public void onDrawerStateChanged(int newState) { /** * 抽屜狀態(tài)改變時(shí),調(diào)用此方法 * */ } });
2、使用SimpleDrawerListener監(jiān)聽(tīng)
顧名思義,即是DrawerListener的精簡(jiǎn)版,不必實(shí)現(xiàn)DrawerListener的全部回調(diào)函數(shù),可以根據(jù)業(yè)務(wù)需求選擇重寫(xiě)相應(yīng)的方法,用法與DrawerListener一致。
3、配合ActionBar使用的ActionBarDrawerToggle監(jiān)聽(tīng)
如果Activity中有ActionBar,最好使用ActionBarDrawerToggle進(jìn)行監(jiān)聽(tīng),ActionBarDrawerToggle實(shí)現(xiàn)了DrawerListener,它可以做DrawerListener能做的所有事情,不過(guò)使用ActionBarDrawerToggle監(jiān)聽(tīng),需要選擇重寫(xiě)的方法。
(補(bǔ)充:1、DrawerLayout.openDrawer()和DrawerLayout.closeDrawer()可以打開(kāi)和關(guān)閉側(cè)邊欄。 2、如果側(cè)滑欄的點(diǎn)擊事件穿透到主界面,在該側(cè)滑欄的布局文件的最外層加上 android:clickable="true")
三、不足(亦或是優(yōu)點(diǎn)?)
和一般的側(cè)滑菜單相比,DrawerLayout的側(cè)滑效果會(huì)浮現(xiàn)在主界面的上方,而不像其他側(cè)滑菜單,不會(huì)遮擋主界面。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android實(shí)現(xiàn)右邊抽屜Drawerlayout效果
- Android側(cè)滑菜單之DrawerLayout用法詳解
- Android DrawerLayout實(shí)現(xiàn)側(cè)拉菜單功能
- Android使用DrawerLayout實(shí)現(xiàn)仿QQ雙向側(cè)滑菜單
- Android App中DrawerLayout抽屜效果的菜單編寫(xiě)實(shí)例
- Android中DrawerLayout+ViewPager滑動(dòng)沖突的解決方法
- Android原生側(cè)滑控件DrawerLayout使用方法詳解
- Android組件之DrawerLayout實(shí)現(xiàn)抽屜菜單
- Android中DrawerLayout實(shí)現(xiàn)側(cè)滑菜單效果
- Android抽屜布局DrawerLayout的簡(jiǎn)單使用
相關(guān)文章
Android無(wú)需申請(qǐng)權(quán)限撥打電話的兩種方式
android 打電話有兩種實(shí)現(xiàn)方式,第一種方法撥打電話跳轉(zhuǎn)到撥號(hào)界面,第二種方法,撥打電話直接進(jìn)行撥打,下面逐一給大家介紹這兩種方式,需要的朋友參考下吧2016-12-12android 九宮格滑動(dòng)解鎖開(kāi)機(jī)實(shí)例源碼學(xué)習(xí)
開(kāi)機(jī)密碼的樣式種類(lèi)多種多樣,五花八門(mén).本文接下來(lái)介紹滑動(dòng)九宮格來(lái)達(dá)到開(kāi)機(jī)目的,感興趣的朋友可以了解下2013-01-01Android原生態(tài)實(shí)現(xiàn)分享轉(zhuǎn)發(fā)功能實(shí)例
大家好,本篇文章主要講的是Android原生態(tài)實(shí)現(xiàn)分享轉(zhuǎn)發(fā)功能實(shí)例,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下2021-12-12關(guān)于Android高德地圖的簡(jiǎn)單開(kāi)發(fā)實(shí)例代碼(DEMO)
高德地圖在日常生活中經(jīng)常會(huì)用到,那么基于代碼如何實(shí)現(xiàn)高德地圖呢?下面小編給大家分享一個(gè)demo幫助大家學(xué)習(xí)android高德地圖的簡(jiǎn)單開(kāi)發(fā),需要的朋友參考下2016-11-11Android實(shí)現(xiàn)個(gè)人資料頁(yè)面頭像背景模糊顯示包(狀態(tài)欄)
這篇文章主要介紹了Android實(shí)現(xiàn)個(gè)人資料頁(yè)面頭像背景模糊顯示包括狀態(tài)欄,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-03-03Android開(kāi)發(fā)實(shí)現(xiàn)的簡(jiǎn)單媒體播放器功能示例
這篇文章主要介紹了Android開(kāi)發(fā)實(shí)現(xiàn)的簡(jiǎn)單媒體播放器功能,結(jié)合實(shí)例形式分析了Android基于surfaceview實(shí)現(xiàn)多媒體視頻及音頻播放的相關(guān)操作技巧,需要的朋友可以參考下2017-10-10Android Studio開(kāi)發(fā)中Gradle各種常見(jiàn)報(bào)錯(cuò)問(wèn)題解決方案
這篇文章主要為大家介紹了Android Studio開(kāi)發(fā)中Gradle各種常見(jiàn)報(bào)錯(cuò)問(wèn)題解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12Android 獲取屏幕高度,標(biāo)題高度,狀態(tài)欄高度(實(shí)例代碼)
getWindow().findViewById(Window.ID_ANDROID_CONTENT)這個(gè)方法獲取到的view就是程序不包括標(biāo)題欄的部分,然后就可以知道標(biāo)題欄的高度了2013-11-11