Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/191.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Android 抽屉布局和AppBarLayout的问题_Android_Navigation Drawer_Android Tablayout_Drawerlayout_Android Appbarlayout - Fatal编程技术网

Android 抽屉布局和AppBarLayout的问题

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

我对抽屉布局和AppBarLayout有问题。我需要添加抽屉布局以创建NavigationDrawer。当我添加抽屉布局时,整个布局以蓝色绘制。导航抽屉只能通过刷卡打开,而不是通过点击按钮打开。我不明白问题是什么。请帮帮我

这是我的主要布局:

<?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