导航抽屉片段内的Android操作栏标签

时间:2014-08-22 05:47:57

标签: android android-actionbar android-viewpager navigation-drawer

我的导航抽屉带有碎片。是否有任何可能的方法在片段中实现操作栏选项卡,同时具有导航抽屉,就像在Google I / O 2014应用程序中一样?:

http://cdn.slashgear.com/wp-content/uploads/2014/06/google-io-2014-app-4.png

我的意思是我需要它至少看起来像动作栏标签(用滑动手势)。因为默认的viewPagerTabStrip真的太烂了。

先谢谢;)

1 个答案:

答案 0 :(得分:2)

是的..我已经在我的应用程序中实现了相同的功能。 我还使用了ViewPager

<android.support.v4.view.ViewPager xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/pager" android:layout_width="match_parent" android:background="@android:color/white" android:layout_height="match_parent"> </android.support.v4.view.ViewPager>

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main_fragment);

    viewPager = (ViewPager) findViewById(R.id.pager);
    viewPager.setAdapter(new MyAdapter(getSupportFragmentManager(), ActionBarActivity.this));
    viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int i, float v, int i2) {
        }
        @Override
        public void onPageSelected(int i) {
            actionBar.setSelectedNavigationItem(i);
        }
        @Override
        public void onPageScrollStateChanged(int i) {
        }
    });

    actionBar = getActionBar();
    actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
    actionBar.setDisplayShowHomeEnabled(true);

    ActionBar.Tab tab1 = actionBar.newTab();
    tab1.setText("Client");
    tab1.setTabListener(this);

    ActionBar.Tab tab2 = actionBar.newTab();
    tab2.setText("Supplier");
    tab2.setTabListener(this);

    ActionBar.Tab tab3 = actionBar.newTab();
    tab3.setText("Driver");
    tab3.setTabListener(this);

    ActionBar.Tab tab4 = actionBar.newTab();
    tab4.setText("Owner");
    tab4.setTabListener(this);

    actionBar.addTab(tab1);
    actionBar.addTab(tab2);
    actionBar.addTab(tab3);
    actionBar.addTab(tab4);

public void onTabSelected(ActionBar.Tab tab, FragmentTransaction fragmentTransaction) {
    viewPager.setCurrentItem(tab.getPosition());
}

@Override
public void onTabUnselected(ActionBar.Tab tab, FragmentTransaction fragmentTransaction) {

}

@Override
public void onTabReselected(ActionBar.Tab tab, FragmentTransaction fragmentTransaction) {
}

}

并使用片段适配器

    class MyAdapter extends FragmentPagerAdapter{

    Context context;
    public MyAdapter(FragmentManager fragmentManager, Context context){
        super(fragmentManager);
        this.context = context;
    }

    @Override
    public Fragment getItem(int i) {

        Fragment fragment = null;
        if(i == 0){
            fragment = new FragmentClass1(context);
        }else if(i == 1) {
            fragment = new FragmentClass2(context);
        }else if(i == 2){
            fragment = new FragmentClass3(context);
        }else {
            fragment = new FragmentClass4(context);
        }
        return fragment;
    }

    @Override
    public int getCount() {
        return 4;
    }
}

对于抽屉,请使用此

<android.support.v4.widget.DrawerLayout>  //你的代码 </android.support.v4.widget.DrawerLayout>