Android 抽屉布局和AppBarLayout的问题
我对抽屉布局和AppBarLayout有问题。我需要添加抽屉布局以创建NavigationDrawer。当我添加抽屉布局时,整个布局以蓝色绘制。导航抽屉只能通过刷卡打开,而不是通过点击按钮打开。我不明白问题是什么。请帮帮我 这是我的主要布局:Android 抽屉布局和AppBarLayout的问题,android,navigation-drawer,android-tablayout,drawerlayout,android-appbarlayout,Android,Navigation Drawer,Android Tablayout,Drawerlayout,Android Appbarlayout,我对抽屉布局和AppBarLayout有问题。我需要添加抽屉布局以创建NavigationDrawer。当我添加抽屉布局时,整个布局以蓝色绘制。导航抽屉只能通过刷卡打开,而不是通过点击按钮打开。我不明白问题是什么。请帮帮我 这是我的主要布局: <?xml version="1.0" encoding="utf-8"?> <android.support.design.widget.CoordinatorLayout xmlns:android="http://sche
<?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);
}
}
}
package com.jeffe.tabstest;
导入android.content.Intent;
导入android.support.design.widget.NavigationView;
导入android.support.design.widget.TabLayout;
导入android.support.v4.app.Fragment;
导入android.support.v4.app.FragmentManager;
导入android.support.v4.app.FragmentPagerAdapter;
导入android.support.v4.view.GravityCompat;
导入android.support.v4.view.ViewPager;
导入android.support.v4.widget.DrawerLayout;
导入android.support.v7.app.ActionBarDrawerToggle;
导入android.support.v7.app.AppActivity;
导入android.os.Bundle;
导入android.support.v7.widget.Toolbar;
导入android.view.MenuItem;
导入java.util.ArrayList;
导入java.util.List;
公共类MainActivity扩展了AppCompatActivity
实现NavigationView.OnNavigationItemSelectedListener{
专用工具栏;
私人摊位摊位;
私人视页机视页机;
私人抽屉布局;
@凌驾
创建时受保护的void(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
toolbar=(toolbar)findviewbyd(R.id.toolbar);
设置支持操作栏(工具栏);
抽屉布局=(抽屉布局)findViewById(R.id.抽屉);
ActionBarDrawerToggle toggle=新建ActionBarDrawerToggle(此,抽屉布局,工具栏,
R.string.navigation\u drawer\u open,R.string.navigation\u drawer\u close);
抽屉布局。添加抽屉链接(切换);
toggle.syncState();
viewPager=(viewPager)findViewById(R.id.viewPager);
设置viewPager(viewPager);
tabLayout=(tabLayout)findViewById(R.id.tabs);
tabLayout.setupWithViewPager(viewPager);
NavigationView NavigationView=(NavigationView)findViewById(R.id.nav_视图);
断言navigationView!=null;
navigationView.setNavigationItemSelectedListener(此);
}
@凌驾
公共布尔值onNavigationItemSelected(MenuItem项){
int id=item.getItemId();
抽屉布局。关闭抽屉(重力公司启动);
返回true;
}
@凌驾
public void onBackPressed(){
断言抽屉布局!=null;
if(抽屉布局isDrawerOpen(重力比较开始)){
抽屉布局。关闭抽屉(重力公司启动);
}否则{
super.onBackPressed();
}
}
专用无效设置ViewPager(ViewPager ViewPager){
ViewPagerAdapter适配器=新的ViewPagerAdapter(getSupportFragmentManager());
addFragment(新的MusicTab(),“Tab1”);
addFragment(新的AnimeTab(),“Tab2”);
addFragment(新的ArtistTab(),“Tab3”);
addFragment(新的AlbumTab(),“Tab4”);
addFragment(新的FavoritesTab(),“Tab5”);
viewPager.setAdapter(适配器);
}
类ViewPagerAdapter扩展了FragmentPagerAdapter{
私有最终列表MFFragmentList=new ArrayList();
私有最终列表MFFragmentTitleList=new ArrayList();
公共视图页面编辑器(碎片管理器){
高级经理;
}
@凌驾
公共片段getItem(int位置){
返回MFFragmentList.get(位置);
}
@凌驾
public int getCount(){
返回MFFragmentList.size();
}
public void addFragment(片段片段,字符串标题){
添加(片段);
MFFragmentTitleList.add(标题);
}
@凌驾
公共字符序列getPageTitle(int位置){
返回MFFragmentTitleList.get(位置);
}
}
}
布局有问题,因为AppBar中没有一个按钮不工作。但在我添加抽屉布局之前,一切都很完美。不要使用
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);
}
});
希望它能有所帮助:)不要使用
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);
}
});
希望能有所帮助:)不起作用。关键点仍然不起作用,但至少是NavigationView动画——现在不行了。那蓝屏呢?我想这和我的布局有关,但我不明白怎么做。顺便说一句,我也不能按标签。你没听懂吗?请详细说明你的意思我的意思是我的布局问题,因为AppBar中没有一个按钮不起作用。我认为我不应该使用CoordinatorLayout和AppBarLayout,但我不知道用什么替换它们才能继续起作用。不要使用CoordinatorLayout,如果你想把抽屉放在actionbar的顶部,那就把抽屉的布局设成不起作用的样子。关键点仍然不起作用,但至少是NavigationView动画——现在不行了。那蓝屏呢?我想这和我的布局有关,但我不明白怎么做。顺便说一句,我也不能按标签。你没听懂吗?请详细说明你的意思我的意思是我的布局问题,因为AppBar中没有一个按钮不起作用。我认为我不应该使用CoordinatorLayout和AppBarLayout,但我不知道用什么替换它们才能继续起作用。不要使用CoordinatorLayout,如果您希望抽屉位于actionbar的顶部,则将您的抽屉布局设置为父级
抽屉布局
只需要一个主内容视图
。您有两个,它正在处理AppBarLayout