Android開發(fā)之DrawerLayout實現(xiàn)抽屜效果

谷歌官方推出了一種側(cè)滑菜單的實現(xiàn)方式(抽屜效果),即 DrawerLayout笛质,這個類是在Support Library里的鬼悠,需要加上android-support-v4.jar這個包。

使用注意點

1庆械、DrawerLayout的第一個子元素必須是默認內(nèi)容沃疮,即抽屜沒有打開時顯示的布局(如FrameLayout)盒让,后面緊跟的子元素是抽屜內(nèi)容,即抽屜布局(如ListView)司蔬。

2邑茄、抽屜菜單的擺放和布局通過android:layout_gravity屬性來控制,可選值為left葱她、right或start撩扒、end。

3吨些、抽屜菜單的寬度為 dp 單位而高度和父View一樣搓谆。抽屜菜單的寬度應(yīng)該不超過320dp,這樣用戶可以在菜單打開的時候看到部分內(nèi)容界面豪墅。

4泉手、打開抽屜: DrawerLayout .openDrawer(); 關(guān)閉抽屜:DrawerLayout.closeDrawer( );

一個典型的布局實例:

<android.support.v4.widget.DrawerLayoutxmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/drawer_layout"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <!--可以在程序中根據(jù)抽屜菜單 切換Fragment-->
    <FrameLayout
        android:id="@+id/fragment_layout"
         android:background="#0000ff"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent">
    </FrameLayout>
    <!--左邊抽屜菜單-->
    <RelativeLayout
        android:id="@+id/menu_layout_left"
        android:layout_width="240dp"
        android:layout_height="match_parent"
        android:layout_gravity="left"
        android:background="#ff0000">
        <ListView
            android:id="@+id/menu_listView_l"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
        </ListView>
    </RelativeLayout>
    <!--右邊抽屜菜單-->
    <RelativeLayout
        android:id="@+id/menu_layout_right"
        android:layout_width="240dp"
        android:layout_height="match_parent"
       android:layout_gravity="right"
        android:background="#00ff00">
        <ListView
            android:id="@+id/menu_listView_r"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
        </ListView>
    </RelativeLayout>
</android.support.v4.widget.DrawerLayout>

這里存放的是ListView,下面會講配合 Android M推出的NavigationView

遇到的問題

1偶器、在點擊DrawerLayout中的空白處的時候斩萌,底部的content會獲得事件。
由于Google的demo是一個ListView屏轰,所以ListView會獲得焦點颊郎,事件就不會傳遞了,看不出來問題霎苗。但是如果用的include加載的布局姆吭,會出現(xiàn)這個情況,那么如何解決唁盏?
解決辦法:在include進的那個布局里面内狸,添加clickable=true

2、除了抽屜的布局視圖之外的視圖究竟放哪里
左厘擂、右抽屜和中間內(nèi)容視圖默認是不顯示的昆淡,其他布局視圖都會直接顯示出來,但是需要將其放在 DrawerLayout 內(nèi)部才能正常使用(不要放在外面)刽严,否則要么是相互覆蓋昂灵,或者就是觸屏事件失效,滾動等效果全部失效。

3倔既、去除左右抽屜劃出后內(nèi)容顯示頁背景的灰色恕曲?
drawerLayout.setScrimColor(Color.TRANSPARENT);

4鹏氧、如何填充抽屜的劃出后與屏幕邊緣之間的內(nèi)容(即上面的灰色部分)渤涌?
drawerLayout.setDrawerShadow(Drawable shadowDrawable, int gravity)
drawerLayout.setDrawerShadow(int resId, int gravity)

配合NavigationView實現(xiàn)抽屜菜單

NavigationView是Android M中提出一個新的MD風格的組件,它將自己一分為二把还,上面顯示一個通用的布局实蓬,下面顯示一組菜單。與DrawerLayout一起使用可以實現(xiàn)通用的側(cè)滑菜單吊履,布局如下

<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/id_drawer_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">
        <TextView
            android:id="@+id/tv_content"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:text="Hello World"
            android:textSize="30sp" />
    </RelativeLayout>

    <android.support.design.widget.NavigationView
        android:id="@+id/nv_menu_left"
        android:layout_width="240dp"
        android:layout_height="match_parent"
        android:layout_gravity="left" //左側(cè)菜單
        app:headerLayout="@layout/header" //導航的頂部視圖
        app:menu="@menu/menu_drawer_left" /> //導航的底部菜單
</android.support.v4.widget.DrawerLayout>

header.xml安皱,很簡單

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="240dp" //設(shè)置一下頭部高度
    android:background="#123456" //設(shè)置一個背景色
    android:orientation="vertical"
    android:padding="16dp">

    <ImageView
        android:layout_width="80dp"
        android:layout_height="80dp"
        android:layout_marginBottom="16dp"
        android:layout_marginTop="36dp"
        android:src="@mipmap/ic_launcher" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="YungFan" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="http://www.reibang.com/users/ab557ce505cd/timeline" />
</LinearLayout>

menu_drawer_left.xml,就構(gòu)造四個簡單菜單

<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android">

    <item
        android:id="@+id/nav_home"
        android:icon="@mipmap/infusion"
        android:title="Home" />
    <item
        android:id="@+id/nav_messages"
        android:icon="@mipmap/mypatient"
        android:title="Messages" />
    <item
        android:id="@+id/nav_friends"
        android:icon="@mipmap/mywork"
        android:title="Friends" />
    <item
        android:id="@+id/nav_discussion"
        android:icon="@mipmap/personal"
        android:title="Discussion" />

</menu>

實現(xiàn)效果圖

DrawerLayout + NavigationView.png

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末艇炎,一起剝皮案震驚了整個濱河市酌伊,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌缀踪,老刑警劉巖居砖,帶你破解...
    沈念sama閱讀 205,874評論 6 479
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異驴娃,居然都是意外死亡奏候,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,151評論 2 382
  • 文/潘曉璐 我一進店門唇敞,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蔗草,“玉大人,你說我怎么就攤上這事疆柔≈渚” “怎么了?”我有些...
    開封第一講書人閱讀 152,270評論 0 342
  • 文/不壞的土叔 我叫張陵旷档,是天一觀的道長模叙。 經(jīng)常有香客問我,道長彬犯,這世上最難降的妖魔是什么向楼? 我笑而不...
    開封第一講書人閱讀 55,137評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮谐区,結(jié)果婚禮上湖蜕,老公的妹妹穿的比我還像新娘。我一直安慰自己宋列,他們只是感情好昭抒,可當我...
    茶點故事閱讀 64,116評論 5 370
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般灭返。 火紅的嫁衣襯著肌膚如雪盗迟。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,935評論 1 283
  • 那天熙含,我揣著相機與錄音罚缕,去河邊找鬼。 笑死怎静,一個胖子當著我的面吹牛邮弹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蚓聘,決...
    沈念sama閱讀 38,261評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼腌乡,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了夜牡?” 一聲冷哼從身側(cè)響起与纽,我...
    開封第一講書人閱讀 36,895評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎塘装,沒想到半個月后急迂,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,342評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡氢哮,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,854評論 2 323
  • 正文 我和宋清朗相戀三年袋毙,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片冗尤。...
    茶點故事閱讀 37,978評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡听盖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出裂七,到底是詐尸還是另有隱情皆看,我是刑警寧澤,帶...
    沈念sama閱讀 33,609評論 4 322
  • 正文 年R本政府宣布背零,位于F島的核電站腰吟,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏徙瓶。R本人自食惡果不足惜毛雇,卻給世界環(huán)境...
    茶點故事閱讀 39,181評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望侦镇。 院中可真熱鬧灵疮,春花似錦、人聲如沸壳繁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,182評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蒿赢,卻和暖如春润樱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背羡棵。 一陣腳步聲響...
    開封第一講書人閱讀 31,402評論 1 260
  • 我被黑心中介騙來泰國打工壹若, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人晾腔。 一個月前我還...
    沈念sama閱讀 45,376評論 2 352
  • 正文 我出身青樓舌稀,卻偏偏與公主長得像啊犬,于是被迫代替她去往敵國和親灼擂。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,677評論 2 344

推薦閱讀更多精彩內(nèi)容