2017-10-11 17 views
-1

Navigation Drawerを使用しています。ActionBarDrawerToggleは、引き出しをスライドすると同期しますが、Toolbarアイコンをクリックすると、引き出しが開かれません。 私のコードで何が間違っていますか。ナビゲーションボックスをツールバーにリンクする

actionBarDrawerToggle = new ActionBarDrawerToggle(Main2Activity.this, drawerLayout, toolbar, R.string.drawer_open, R.string.close_drawer) { 
     @Override 
     public void onDrawerClosed(View drawerView) { 
      super.onDrawerClosed(drawerView); 
     } 

     @Override 
     public void onDrawerOpened(View drawerView) { 
      super.onDrawerOpened(drawerView); 
     } 
    }; 
    drawerLayout.setDrawerListener(actionBarDrawerToggle); 
    drawerLayout.post(new Runnable() { 
     @Override 
     public void run() { 
      actionBarDrawerToggle.syncState(); 
     } 
    }); 

私はそうしようとしているもの:これは私が使用してい私のレイアウトである

actionBar.setDisplayHomeAsUpEnabled(true); 
    @Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    switch (item.getItemId()) { 
     case android.R.id.home: 
      drawerLayout.openDrawer(Gravity.START); 
      return true; 
    } 

    return super.onOptionsItemSelected(item); 
} 

。私はNavigationViewと引き出しレイアウトを持っています。

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:ads="http://schemas.android.com/apk/res-auto" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:id="@+id/drawer" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true" 
    tools:openDrawer="start"> 

    <RelativeLayout 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:fitsSystemWindows="true" 
     tools:context=".Main2Activity"> 

      <android.support.v7.widget.Toolbar 
       android:id="@+id/toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       android:background="?attr/colorPrimary" 
       android:minHeight="?attr/actionBarSize" 
       app:popupTheme="@style/ThemeOverlay.AppCompat.ActionBar" 
       app:theme="@style/ToolbarColoredIcon" /> 
     <include layout="@layout/content_main2" /> 
    </RelativeLayout> 

    <android.support.design.widget.NavigationView 
     android:id="@+id/navigation_view" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:layout_gravity="start"> 

     <LinearLayout 
      android:id="@+id/nav_layout" 
      android:layout_width="match_parent" 
      android:layout_height="wrap_content" 
      android:orientation="vertical"> 
      <!--header--> 
      <include 
       android:id="@+id/header" 
       layout="@layout/nav_header" 

       /> 
      <!--items--> 
      <LinearLayout 
       android:layout_width="match_parent" 
       android:layout_height="wrap_content" 
       android:orientation="vertical" 
       android:paddingBottom="@dimen/dp20"> 

       <include 
        android:id="@+id/nav_menue_item_home" 
        layout="@layout/nav_menue_item" /> 

       <include 
        android:id="@+id/nav_menue_item_settings" 
        layout="@layout/nav_menue_item" /> 

       <include 
        android:id="@+id/nav_menue_item_more_apps" 
        layout="@layout/nav_menue_item" /> 

       <include 
        android:id="@+id/nav_menue_item_rate_us" 
        layout="@layout/nav_menue_item" /> 

       <include 
        android:id="@+id/nav_menue_item_privacy_policy" 
        layout="@layout/nav_menue_item" /> 
      </LinearLayout> 

      <LinearLayout 
       android:layout_width="match_parent" 
       android:layout_height="match_parent" 
       android:background="#e3e4e3" 
       android:gravity="bottom" 
       android:orientation="vertical"> 

       <com.google.android.gms.ads.NativeExpressAdView 
        android:id="@+id/adViewNative" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_alignParentTop="true" 
        ads:adSize="@string/native_sm_ad_size" 
        ads:adUnitId="@string/native_sm_ad_unit_id" /> 

      </LinearLayout> 

     </LinearLayout> 
    </android.support.design.widget.NavigationView> 

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

ここで問題はどこですか。

おかげで私は私の問題を解決しました。問題は実際にはコードではありませんが、レイアウトには問題があります。ここでは、クリックしてツールバーを使用できないTabHostを追加しています。これは実際の問題です。

+0

'toolbar'がヌルでない場合、その' ActionBarDrawerToggle'コンストラクタで 'setDisplayHomeAsUpEnabled()'コールと 'onOptionsItemSelected()'メソッドは必要ありません。おそらくレイアウトに問題があります。例えば、 'Toolbar'をカバーする' View'があります。 –

答えて

1

toolbar.xmlを作成します。

<?xml version="1.0" encoding="utf-8"?> 
<android.support.v7.widget.Toolbar 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:background="@color/toolbar" 
    android:minHeight="?attr/actionBarSize" 
    android:fitsSystemWindows="true" 
    > 

</android.support.v7.widget.Toolbar> 

はdrawer_menu.xmlを作成します:ハンバーガーアイコンの

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

     <!--First child represents elements of activity in drawerLayout--> 

     <RelativeLayout 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:orientation="vertical" 
      android:id="@+id/relative_layout"> 

      <include 
       android:id="@+id/toolbar" 
       layout="@layout/toolbar" 
       /> 

     </RelativeLayout> 

     <!--Second child (navigation view) represents elements of navigation drawer in drawerLayout--> 

     <android.support.design.widget.NavigationView 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      android:id="@+id/navigation_view" 
      android:layout_gravity="start" 
      android:background="@color/toolbar" 
      app:menu="@menu/drawer_menu"> 

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

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

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

    <group 
     android:checkableBehavior="single" 
     android:id="@+id/first_group"> 

     <item 
      android:id="@+id/first_item" 
      android:title="First Item" 
      android:icon="@drawable/first_item" 
      /> 

    </group> 

    <group 
     android:checkableBehavior="single" 
     android:id="@+id/second_group"> 
     <item 
      android:id="@+id/second_item" 
      android:title="Second Item" 
      android:icon="@drawable/second_item"> 

     </item> 
    </group> 

</menu> 

を次に、あなたの活動の形式は次のようにする必要があります

drawerLayout = (DrawerLayout) findViewById(R.id.drawer_layout); 

actionBarDrawerToggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.drawer_open, R.string.drawer_close); 

drawerLayout.addDrawerListener(actionBarDrawerToggle); 

そしてメソッドを作成します。

@Override 
protected void onPostCreate(Bundle savedInstanceState) { 
    super.onPostCreate(savedInstanceState); 
    actionBarDrawerToggle.syncState(); 
} 

はそれが助けなら、私に教えてください。

+0

ハンバーガーのアイコンが正常に機能しているが、彼らはドン、tは引き出しがすなわちリスナー –

+0

をクリックして応答していない開いて次に何かがあなたのレイアウト – Shaifu

+0

と間違っている必要があり、レイアウトを確認し、今@Shaifu –

関連する問題