0

У меня проблема с DrawerLayout и AppBarLayout. Мне нужно добавить DrawerLayout для создания NavigationDrawer. Когда я добавляю DrawerLayout, весь макет окрашивается в синий цвет. И Navigation Drawer открывается только с помощью салфетки, не работает одним нажатием кнопки. Я не понимаю в чем проблема. Помоги мне, пожалуйста.Проблема с DrawerLayout и AppBarLayout

enter image description here

Это моя основная раскладка:

<?xml version="1.0" encoding="utf-8"?> 
<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    android:id="@+id/activity_main" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent"> 

    <android.support.v4.widget.DrawerLayout 
     android:id="@+id/drawer" 
     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:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar" 
      app:expanded="false"> 

      <android.support.v7.widget.Toolbar 
       android:id="@+id/toolbar" 
       android:layout_width="match_parent" 
       android:layout_height="?attr/actionBarSize" 
       android:background="@color/colorPrimary" 
       app:layout_scrollFlags="scroll|enterAlways" 
       app:popupTheme="@style/ThemeOverlay.AppCompat.Light" /> 

      <android.support.design.widget.TabLayout 
       android:id="@+id/tabs" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:layout_gravity="center_horizontal" 
       app:tabMode="scrollable" /> 
     </android.support.design.widget.AppBarLayout> 

     <android.support.v4.view.ViewPager 
      android:id="@+id/viewPager" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent" 
      app:layout_behavior="@string/appbar_scrolling_view_behavior"/> 

     <android.support.design.widget.NavigationView 
      android:id="@+id/nav_view" 
      android:layout_width="wrap_content" 
      android:layout_height="match_parent" 
      android:layout_gravity="start" 
      android:fitsSystemWindows="true" 
      app:menu="@menu/drawermenu" /> 
    </android.support.v4.widget.DrawerLayout> 
</android.support.design.widget.CoordinatorLayout> 

И это мой Главный код активности:

package com.jeffe.tabstest; 

import android.content.Intent; 
import android.support.design.widget.NavigationView; 
import android.support.design.widget.TabLayout; 
import android.support.v4.app.Fragment; 
import android.support.v4.app.FragmentManager; 
import android.support.v4.app.FragmentPagerAdapter; 
import android.support.v4.view.GravityCompat; 
import android.support.v4.view.ViewPager; 
import android.support.v4.widget.DrawerLayout; 
import android.support.v7.app.ActionBarDrawerToggle; 
import android.support.v7.app.AppCompatActivity; 
import android.os.Bundle; 
import android.support.v7.widget.Toolbar; 
import android.view.MenuItem; 

import java.util.ArrayList; 
import java.util.List; 

public class MainActivity extends AppCompatActivity 
     implements NavigationView.OnNavigationItemSelectedListener { 

    private Toolbar toolbar; 
    private TabLayout tabLayout; 
    private ViewPager viewPager; 
    private DrawerLayout drawerLayout; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 

     toolbar = (Toolbar)findViewById(R.id.toolbar); 
     setSupportActionBar(toolbar); 

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

     ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, 
       R.string.navigation_drawer_open, R.string.navigation_drawer_close); 
     drawerLayout.addDrawerListener(toggle); 
     toggle.syncState(); 

     viewPager = (ViewPager)findViewById(R.id.viewPager); 
     setupViewPager(viewPager); 

     tabLayout = (TabLayout)findViewById(R.id.tabs); 
     tabLayout.setupWithViewPager(viewPager); 

     NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view); 
     assert navigationView != null; 
     navigationView.setNavigationItemSelectedListener(this); 
    } 

    @Override 
    public boolean onNavigationItemSelected(MenuItem item) { 
     int id = item.getItemId(); 

     drawerLayout.closeDrawer(GravityCompat.START); 
     return true; 
    } 

    @Override 
    public void onBackPressed() { 
     assert drawerLayout != null; 
     if (drawerLayout.isDrawerOpen(GravityCompat.START)) { 
      drawerLayout.closeDrawer(GravityCompat.START); 
     } else { 
      super.onBackPressed(); 
     } 
    } 

    private void setupViewPager(ViewPager viewPager) { 
     ViewPagerAdapter adapter = new ViewPagerAdapter(getSupportFragmentManager()); 
     adapter.addFragment(new MusicTab(), "Tab1"); 
     adapter.addFragment(new AnimeTab(), "Tab2"); 
     adapter.addFragment(new ArtistTab(), "Tab3"); 
     adapter.addFragment(new AlbumTab(), "Tab4"); 
     adapter.addFragment(new FavoritesTab(), "Tab5"); 
     viewPager.setAdapter(adapter); 
    } 

    class ViewPagerAdapter extends FragmentPagerAdapter { 
     private final List<Fragment> mFragmentList = new ArrayList<>(); 
     private final List<String> mFragmentTitleList = new ArrayList<>(); 

     public ViewPagerAdapter(FragmentManager manager) { 
      super(manager); 
     } 

     @Override 
     public Fragment getItem(int position) { 
      return mFragmentList.get(position); 
     } 

     @Override 
     public int getCount() { 
      return mFragmentList.size(); 
     } 

     public void addFragment(Fragment fragment, String title) { 
      mFragmentList.add(fragment); 
      mFragmentTitleList.add(title); 
     } 

     @Override 
     public CharSequence getPageTitle(int position) { 
      return mFragmentTitleList.get(position); 
     } 
    } 
} 

Что-то не так с макетом, потому что ни одна из кнопок в AppBar не Безразлично Не работай. Но прежде, чем я добавил DrawerLayout, все сработало отлично.

+1

Параметра 'DrawerLayout' должен иметь только один основной контент' View'. У вас двое, и он обрабатывает «AppBarLayout», как и весь его основной контент. Вы можете изменить свой макет, как показано в [этот пост] (http://stackoverflow.com/questions/30719369/android-design-library-coordinatorlayout-appbarlayout-and-drawerlayout). –

+0

Спасибо, я просто перемещаю AppBarLayout в другой файл макета, и теперь все работает отлично. –

ответ

0

Не используйте ActionBarDrawerToggle и NavigationView, что является самым старым способом.

Попробуйте это -

toolbar = (Toolbar)findViewById(R.id.toolbar); 
toolbar.setNavigationIcon(YOUR_MENU_ICON); //set your navigation icon 
setSupportActionBar(toolbar); 


toolbar.setNavigationOnClickListener(new View.OnClickListener() { 

    @Override 
    public void onClick(View v) { 
      drawerLayout.openDrawer(drawerLayout); 
     } 
    }); 

Надеется, что это поможет :)

+0

Не работает. Ключ по-прежнему не работает, но, по крайней мере, это анимация NavigationView - теперь это не так. Как насчет синего экрана? Я думаю, что это имеет какое-то отношение к моему макету, но я не понимаю, как это сделать. Кстати, я не могу нажать на вкладки тоже. –

+0

Не понял? Пожалуйста, уточните, что вы имеете в виду? –

+0

Я имею в виду, что моя проблема в макете, потому что ни одна из кнопок в AppBar не работает. –

Смежные вопросы