【问题标题】:position value of tab selected while switching one tab to another is not changing in android tabLayout在将一个选项卡切换到另一个选项卡时选择的选项卡的位置值在 android tabLayout 中没有改变
【发布时间】:2018-03-07 09:16:55
【问题描述】:

虽然在 tablayout 位置值选项卡中切换选项卡没有改变。请参阅下面的代码。

tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
        @Override
        public void onTabSelected(TabLayout.Tab tab) {
            tab.getIcon().setColorFilter(Color.parseColor("#ffffff"), PorterDuff.Mode.SRC_IN);
        }

        @Override
        public void onTabUnselected(TabLayout.Tab tab) {
            tab.getIcon().setColorFilter(Color.parseColor("#40FFFFFF"), PorterDuff.Mode.SRC_IN);
        }

        @Override
        public void onTabReselected(TabLayout.Tab tab) {

        }
    });

onTabSelected() 方法我将它的位置值作为参考,但是在切换选项卡时它的位置值没有改变。所以我尝试分配下面的代码来参考这也不适用于我。

viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
        @Override
        public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

        }

        @Override
        public void onPageSelected(int position) {
            tabposition=position;
        }

        @Override
        public void onPageScrollStateChanged(int state) {

            // Hide the keyboard.
            ((InputMethodManager)getSystemService(INPUT_METHOD_SERVICE))
                    .hideSoftInputFromWindow(viewPager.getWindowToken(), 0);


        }
    });

我想在这里使用位置值

 public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.

    getMenuInflater().inflate(R.menu.main, menu);
    menu.clear();
    Log.d("position", "--------- "+tabposition);
    if (tabposition == 0) {
        getMenuInflater().inflate(R.menu.main, menu);  //  menu for alert.
    } else if (tabposition ==1){
        getMenuInflater().inflate(R.menu.transactionmenu, menu);  // menu for transactiontab
    }else {
        getMenuInflater().inflate(R.menu.notificationsmenu, menu);  // menu for notificationtab
    }
    return super.onPrepareOptionsMenu(menu);
    //return true;
}

【问题讨论】:

  • 你是否在 viewpager 中使用 tablayout?
  • 是的,我只用那个
  • 那么你可以使用fragments and FragmentPagerAdapter。你不需要使用addOnPageChangeListener and setOnTabSelectedListener

标签: android android-fragments android-tablayout


【解决方案1】:

如果你想为不同的页面使用不同的菜单,你可以在每个片段中使用以下代码

@Override
public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
    menu.clear();
    inflater.inflate(R.menu.menu, menu);//menu for that fragment
    super.onCreateOptionsMenu(menu, inflater);
}

并且还在每个片段中,添加 setHasOptionsMenu(true);

@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setHasOptionsMenu(true);
    }

并像使用 Fragment 寻呼机适配器

public class MyAdapter extends FragmentPagerAdapter {
    static int NUM_ITEMS = 3;
    final String[] a={"one" ,"two" ,"three"};
    public MyAdapter(FragmentManager fragmentManager) {
        super(fragmentManager);

    }
    @Override
    public int getCount() {
        return NUM_ITEMS;
    }
    @Override
    public Fragment getItem(int position) {
        switch (position) {
            case 0:
                return new Fragmentone();
            case 1:
                return new Fragmenttwo();
            case 2:
                return new Fragmentthree();
            default:
                return null;
        }
    }
    @Override
    public CharSequence getPageTitle(int position) {
        return a[position];
    }
}

在你的活动中,使用这个

mViewPager = (ViewPager) findViewById(R.id.container);
        final TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
        mSectionsPagerAdapter = new MyAdapter(getSupportFragmentManager());
        mViewPager.setAdapter(mSectionsPagerAdapter);
        tabLayout.setupWithViewPager(mViewPager);

使用 tabTextColortabSelectedTextColor 更改选项卡文本颜色,

<android.support.design.widget.TabLayout
            android:id="@+id/tabs"
            app:tabIndicatorColor="#fff"
            app:tabTextColor="#80ffffff"
            app:tabSelectedTextColor="#fff"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2011-05-21
    • 1970-01-01
    • 2011-11-21
    • 1970-01-01
    • 1970-01-01
    • 2018-03-22
    • 1970-01-01
    相关资源
    最近更新 更多