Android : NavitagionView (DrawerLayout の Drawer) をフルサイズ(画面の高さに合わせて)表示する
アプリ領域全体だけで良い = システムのステータスバー(アンテナとか電池残量とか表示している部分)にオーバーラップしなくても良い、という場合は Toolbar を使うだけで OK です(逆に Toolbar を使う場合に Drawer を被せないようにする場合、Layout に工夫が必要になります)。
- ActionBar ではなく Toolbar を使う
- ActionBar でやるには lemycanh/DrawerOnTopActionBar · GitHub のような方法があるようだが、面倒くさい。ActionBar を Toolbar に変える方が簡単
ステータスバー領域にも被せる(配置的にはステータスバーの裏)場合には更に以下の様な処理が必要です。これは v21 = 5.0 = Lollipop 以降限定の属性を使用しているので、v21 ディレクトリの styles.xml で別途定義しなくてはなりません。
- DrawerLayout に android:fitsSystemWindows="true" を設定する
- アプリに設定する Theme で android:windowDrawsSystemBarBackgrounds を true に、android:statusBarColor を @android:color/transparent(#00000000)にする。
DrawerLayout を使うメインのアクティビティのレイアウト xml 例
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:fitsSystemWindows="true" tools:context=".MainActivity"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <android.support.v7.widget.Toolbar android:id="@+id/toolbar" android:layout_height="?attr/actionBarSize" android:layout_width="match_parent" android:background="?attr/colorPrimary"/> <FrameLayout android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent"> </FrameLayout> </LinearLayout> <android.support.design.widget.NavigationView android:id="@+id/navigation_view" android:layout_width="wrap_content" android:layout_height="match_parent" android:layout_gravity="start" app:headerLayout="@layout/navigation_header" app:menu="@menu/drawer"/> </android.support.v4.widget.DrawerLayout>
ステータスバー領域も使う場合の values-v21\styles.xml
<?xml version="1.0" encoding="utf-8"?> <resources> <style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <item name="colorPrimary">@color/app_primary</item> <item name="colorPrimaryDark">@color/app_primary_dark</item> <item name="colorAccent">@color/app_accent</item> <item name="android:windowDrawsSystemBarBackgrounds">true</item> <item name="android:statusBarColor">@android:color/transparent</item> </style> </resources>
参考
上から 3 番目くらいの Design Support Library について書いてある回答を参照。