谷歌官方推出了一種側(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)效果圖