-3

這裏是我的主XML文件:如何在Android中的工具欄下啓動抽屜佈局?

<?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:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:fitsSystemWindows="true" 
     android:id="@+id/nav_drawer"> 

    <android.support.design.widget.CoordinatorLayout 
     xmlns:tools="http://schemas.android.com/tools" 
     android:layout_width="match_parent" 
     android:layout_height="match_parent" 
     android:fitsSystemWindows="true" 
     tools:context="com.example.amit.rssreader.MainActivity"> 


     <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_main" /> 


    </android.support.design.widget.CoordinatorLayout> 
     <android.support.design.widget.NavigationView 
      android:layout_width="wrap_content" 
      android:layout_height="match_parent" 
      app:menu="@menu/navigation_menu" 
      android:layout_gravity="start"> 

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

這是正在發生的事情 This is what is happening

我想有行動吧。這wasnt導航抽屜活動的下方的抽屜,抽屜式導航欄已稍後由xml添加。

回答

1

我想這可能會幫助您:

  1. 修改XML佈局:

    <?xml version="1.0" encoding="utf-8"?> 
    <LinearLayout 
        xmlns:android="http://schemas.android.com/apk/res/android" 
        android:orientation="vertical" 
        android:layout_width="match_parent" 
        android:layout_height="match_parent"> 
        <android.support.design.widget.AppBarLayout 
         android:layout_width="match_parent" 
         android:layout_height="wrap_content"> 
         <android.support.v7.widget.Toolbar 
          android:id="@+id/toolbar" 
          android:layout_width="match_parent" 
          android:layout_height="wrap_content"> 
    
         </android.support.v7.widget.Toolbar> 
        </android.support.design.widget.AppBarLayout> 
    
        <android.support.v4.widget.DrawerLayout 
         android:layout_width="match_parent" 
         android:layout_height="match_parent"> 
         <android.support.design.widget.CoordinatorLayout 
          android:layout_width="match_parent" 
          android:layout_height="match_parent"> 
          <include layout="@layout/content_main" /> 
         </android.support.design.widget.CoordinatorLayout> 
        </android.support.v4.widget.DrawerLayout> 
    </LinearLayout> 
    
  2. 沒有價值觀/ styles.xml工具欄創建活動主題,並把它應用到你的活動AndroidManifest文件:

    <style name="AppTheme.NoActionBar"> 
        <item name="windowActionBar">false</item> 
        <item name="windowNoTitle">true</item> 
    </style> 
    
  3. 並使其工作,使您的活動的onCreate方法看起來像這樣:

    @Override 
    protected void onCreate(@Nullable Bundle savedInstanceState) { 
        super.onCreate(savedInstanceState); 
        setContentView(R.layout.activity_main); 
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
        final DrawerLayout drawerLayout = (DrawerLayout) 
         findViewById(R.id.drawerLayout); 
    
        ActionBar supportActionBar = getSupportActionBar(); 
        if(supportActionBar != null) { 
         supportActionBar.setDisplayHomeAsUpEnabled(true); 
         supportActionBar.setHomeButtonEnabled(true); 
        } 
    
        setSupportActionBar(toolbar); 
    
        final ListView drawerList = (ListView) 
         findViewById(R.id.drawerList); 
         drawerList.setAdapter(new ArrayAdapter<>(this, android.R.layout.simple_list_item_1, 
         new String[] { "Item 1", "Item 2", "Item 3" })); 
    
    
    
         drawerLayout.setScrimColor(Color.TRANSPARENT); 
    
         ActionBarDrawerToggle actionBarDrawerToggle = 
         new ActionBarDrawerToggle(this, drawerLayout, 
           toolbar, R.string.app_name, R.string.app_name); 
    
         actionBarDrawerToggle.setToolbarNavigationClickListener(new View.OnClickListener() { 
         @Override 
         public void onClick(View v) { 
          if(drawerLayout.isDrawerOpen(drawerList)) { 
           drawerLayout.closeDrawers(); 
          } else { 
           drawerLayout.openDrawer(drawerList); 
          } 
         } 
        }); 
    
        drawerLayout.addDrawerListener(actionBarDrawerToggle); 
    
        actionBarDrawerToggle.syncState(); 
    } 
    

    這是如何工作的。 Drawer closedDrawer opened

相關問題