-1

私はnavigatonバーでアプリを作るしようとしている... とナビゲーション引き出しを作る:は、これが私の活動のレイアウトで右重力

<?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" 
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" 
android:layout_gravity="right" 
tools:openDrawer="right"> 

<include 
    layout="@layout/app_bar_navigation" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" /> 

<android.support.design.widget.NavigationView 
    android:id="@+id/nav_view" 
    android:layout_width="wrap_content" 
    android:layout_height="match_parent" 
    android:layout_gravity="right" 
    android:fitsSystemWindows="true" 
    app:headerLayout="@layout/nav_header_navigation" 
    app:menu="@menu/activity_navigation_drawer" /> 

</android.support.v4.widget.DrawerLayout> 

、これはツールバーコーディネータレイアウト魔女である含まれています

<android.support.design.widget.AppBarLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:theme="@style/AppTheme.AppBarOverlay"> 

    <android.support.v7.widget.Toolbar 
     android:id="@+id/toolbar" 
     android:layout_width="match_parent" 
     android:layout_height="?attr/actionBarSize" 
     android:background="?attr/colorPrimary" 
     app:popupTheme="@style/AppTheme.PopupOverlay" /> 


</android.support.design.widget.AppBarLayout> 

<include layout="@layout/content_navigation" /> 

<android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_gravity="bottom|start" 
    android:layout_margin="@dimen/fab_margin" 
    android:src="@android:drawable/ic_dialog_email" /> 

</android.support.design.widget.CoordinatorLayout> 

ナビゲーションが正常に動作しますが、ActionBarDrawerToggleをクリックすると、このエラーが起動し、アプリの入賞:

java.lang.IllegalArgumentExceptionが:重力で見つかりませ引き出しビューが

とトグルボタンのアクションのために残っていない:

 DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
      this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); 
    drawer.setDrawerListener(toggle); 
    toggle.syncState(); 

とイムこの通知を取得:

メソッド呼び出しをdrawer.setDrawerListener(toggle)は、java.lang.NullPointerExeptionを生成する可能性があります。

答えて

1

DrawerLayoutを使用するにはドキュメント

によると、幅とmatch_parentの高さを持つ最初の 子供としてあなたの主なコンテンツビューを配置します。メインコンテンツビューの後に引き出しを子として ビューに追加し、layout_gravityを に適切に設定します。引き出しは通常、高さが の固定幅のmatch_parentを使用します。

次のビュー

<include 
    layout="@layout/app_bar_navigation" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" /> 

を含ん使用するときは、実際に3つのビューの合計を構成する2つのビューを含めています。これの代わりに

final DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
      this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close){ 
     @Override 
     public void onDrawerOpened(View drawerView) { 
      super.onDrawerOpened(drawerView); 
     } 
     @Override 
     public void onDrawerClosed(View drawerView) { 
      super.onDrawerClosed(drawerView); 
     } 

    }; 
    drawer.setDrawerListener(toggle); 
    toggle.syncState(); 
    toolbar.setNavigationOnClickListener(new View.OnClickListener() { 

     @Override 
     public void onClick(View v) { 
      if (drawer.isDrawerOpen(GravityCompat.END)) { 
       drawer.closeDrawer(GravityCompat.END); 
      } else { 
       drawer.openDrawer(GravityCompat.END); 
      } 
     } 
    }); 


は、私は、これは私のコードに変更し、それが良い作品作っ1.

<LinearLayout 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:orientation="vertical"> 

    <android.support.design.widget.AppBarLayout 
     android:layout_width="match_parent" 
     android:layout_height="wrap_content" 
     android:theme="@style/AppTheme.AppBarOverlay"> 

     <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:background="?attr/colorPrimary" 
      app:popupTheme="@style/AppTheme.PopupOverlay" /> 


    </android.support.design.widget.AppBarLayout> 

    <include layout="@layout/content_navigation" /> 

    <android.support.design.widget.FloatingActionButton 
     android:id="@+id/fab" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_gravity="bottom|start" 
     android:layout_margin="@dimen/fab_margin" 
     android:src="@android:drawable/ic_dialog_email" /> 

    </android.support.design.widget.CoordinatorLayout> 

</LinearLayout> 
1

に内部の2つのビューを組み合わせることのLinearLayoutの中にあなたのレイアウトを囲みます。

DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
     this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); 
drawer.setDrawerListener(toggle); 
toggle.syncState(); 
関連する問題