it-roy-ru.com

Выбор вкладки TabLayout

Как выбрать вкладку в TabLayout программно?

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

Если вам известен индекс вкладки, которую вы хотите выбрать, вы можете сделать это так:

TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
TabLayout.Tab tab = tabLayout.getTabAt(someIndex);
tab.select();

Этот метод работает, даже если вы используете TabLayout сам по себе без ViewPager (что нетипично, и, вероятно, это плохая практика, но я видел, как это было сделано).

360
Firefly

Вот как я это решил:

void selectPage(int pageIndex){
    tabLayout.setScrollPosition(pageIndex,0f,true);
    viewPager.setCurrentItem(pageIndex);
}
72
dap

Использовать этот:

<Android.support.design.widget.TabLayout
    Android:id="@+id/patienthomescreen_tabs"
    Android:layout_width="match_parent"
    Android:layout_height="72sp"
    app:tabGravity="fill"
    app:tabMode="fixed"
    app:tabIndicatorColor="@Android:color/white"
    app:tabSelectedTextColor="@color/green"/>

После в OnClickListener:

TabLayout tabLayout = (TabLayout) findViewById(R.id.patienthomescreen_tabs);
TabLayout.Tab tab = tabLayout.getTabAt(someIndex);
tab.select();
33
Pravin Suthar

Вероятно, это не окончательное решение и требуется, чтобы вы использовали TabLayout вместе с ViewPager, но я решил это так:

void selectPage(int pageIndex)
{
    viewPager.setCurrentItem(pageIndex);
    tabLayout.setupWithViewPager(viewPager);
}

Я проверил, насколько велико влияние производительности на использование этого кода, сначала посмотрев на мониторы ЦП и памяти в Android Studio при запуске метода, а затем сравнив его с нагрузкой, которая была загружена на ЦП и память. когда я сам переходил между страницами (с помощью жестов смахивания), и разница не сильно большая, так что, по крайней мере, это не ужасное решение ...

Надеюсь, это поможет кому-то!

19
Daniel Kvist

использовать tabs.getTabAt(2).select();

19
Riyas PK

Если вы не можете использовать tab.select () и не хотите использовать ViewPager, вы все равно можете программно выбрать вкладку. Если вы используете настраиваемое представление через TabLayout.Tab setCustomView(Android.view.View view), это проще. Вот как это сделать в обоих направлениях.

// if you've set a custom view
void updateTabSelection(int position) {
    // get the position of the currently selected tab and set selected to false
    mTabLayout.getTabAt(mTabLayout.getSelectedTabPosition()).getCustomView().setSelected(false);
    // set selected to true on the desired tab
    mTabLayout.getTabAt(position).getCustomView().setSelected(true);
    // move the selection indicator
    mTabLayout.setScrollPosition(position, 0, true);

    // ... your logic to swap out your fragments
}

Если вы не используете пользовательский вид, то вы можете сделать это следующим образом

// if you are not using a custom view
void updateTabSelection(int position) {
    // get a reference to the tabs container view
    LinearLayout ll = (LinearLayout) mTabLayout.getChildAt(0);
    // get the child view at the position of the currently selected tab and set selected to false
    ll.getChildAt(mTabLayout.getSelectedTabPosition()).setSelected(false);
    // get the child view at the new selected position and set selected to true
    ll.getChildAt(position).setSelected(true);
    // move the selection indicator
    mTabLayout.setScrollPosition(position, 0, true);

    // ... your logic to swap out your fragments
}

Используйте StateListDrawable для переключения между выбранными и невыбранными объектами рисования или чем-то похожим, чтобы делать то, что вы хотите, с цветами и/или рисунками.

12
kenodoggy

Просто установите viewPager.setCurrentItem(index) и соответствующий TabLayout выберет соответствующую вкладку.

12
Panduka DeSilva

Вы можете попробовать решить это с этим:

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

TabLayout.Tab tab = tabLayout.getTabAt(pos);
if (tab != null) {
    tab.select();
}
7
CoCo Dev

попробуй это

    new Handler().postDelayed(
            new Runnable(){
                @Override
                public void run() {
                    if (i == 1){
                        tabLayout.getTabAt(0).select();
                    } else if (i == 2){
                        tabLayout.getTabAt(1).select();
                    }
                }
            }, 100);
6
A.G.THAMAYS

добавить для вашего просмотра:

 viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {

            @Override
            public void onPageSelected(int position) {
                array.clear();
                switch (position) {
                    case 1:
                        //like a example
                        setViewPagerByIndex(0);
                        break;
                }
            }

            @Override
            public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
            }

            @Override
            public void onPageScrollStateChanged(int state) {
            }
        });

// на обработчике, чтобы предотвратить падение памяти

private void setViewPagerByIndex(final int index){
    Application.getInstance().getHandler().post(new Runnable() {
        @Override
        public void run() {
            viewPager.setCurrentItem(index);
        }
    });
}
2
Alex Zaraos

Я я использую TabLayout для переключения фрагментов. Он работает по большей части, за исключением тех случаев, когда я пытался программно выбрать вкладку с помощью tab.select(), мой TabLayout.OnTabSelectedListener вызывал onTabSelected(TabLayout.Tab tab), что вызывало бы у меня много горя. Я искал способ сделать программный выбор, не вызывая слушателя.

Поэтому я адаптировал ответ @kenodoggy к своему использованию. Кроме того, я столкнулся с проблемой, когда некоторые из внутренних объектов возвращали бы ноль (потому что они еще не были созданы, потому что я отвечал на onActivityResult() из моего фрагмента, что происходит до onCreate() в случае, если активность singleTask или singleInstance), поэтому я написал подробное описание последовательности if/else, которая сообщит об ошибке и провалится без NullPointerException, которая в противном случае сработала бы. Я использую Timber для регистрации, если вы не используете эту замену с Log.e().

void updateSelectedTabTo(int position) {
    if (tabLayout != null){
        int selected = tabLayout.getSelectedTabPosition();
        if (selected != -1){
            TabLayout.Tab oldTab = tabLayout.getTabAt(0);
            if (oldTab != null){
                View view = oldTab.getCustomView();
                if (view != null){
                    view.setSelected(false);
                }
                else {
                    Timber.e("oldTab customView is null");
                }
            }
            else {
                Timber.e("oldTab is null");
            }
        }
        else {
            Timber.e("selected is -1");
        }
        TabLayout.Tab newTab = tabLayout.getTabAt(position);
        if (newTab != null){
            View view = newTab.getCustomView();
            if (view != null){
                view.setSelected(false);
            }
            else {
                Timber.e("newTab customView is null");
            }
        }
        else {
            Timber.e("newTab is null");
        }
    }
    else {
        Timber.e("tablayout is null");
    }
}

Здесь tabLayout - моя переменная памяти, связанная с объектом TabLayout в моем XML. И я не использую функцию вкладки прокрутки, поэтому я также удалил ее.

2
Dhiraj Gupta

По умолчанию, если вы выберете вкладку, она будет выделена. Если вы хотите выбрать Явно, означает использовать данный закомментированный код в onTabSelected (TabLayout.Tab tab) с указанным вами положением указателя вкладки. Этот код объясняет об изменении фрагмента на выбранной позиции вкладки с помощью viewpager.

public class GalleryFragment extends Fragment implements TabLayout.OnTabSelectedListener 
{
private ViewPager viewPager;public ViewPagerAdapter adapter;private TabLayout tabLayout;
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
View rootView = inflater.inflate(R.layout.fragment_gallery, container, false);
viewPager = (ViewPager) rootView.findViewById(R.id.viewpager);
adapter = new ViewPagerAdapter(getChildFragmentManager());
adapter.addFragment(new PaymentCardFragment(), "PAYMENT CARDS");
adapter.addFragment(new LoyaltyCardFragment(), "LOYALTY CARDS");
viewPager.setAdapter(adapter);
tabLayout = (TabLayout) rootView.findViewById(R.id.tabs);
    tabLayout.setupWithViewPager(viewPager);
    tabLayout.setOnTabSelectedListener(this);
}

@Override
public void onTabSelected(TabLayout.Tab tab) {
    //This will be called 2nd when you select a tab or swipe using viewpager
    final int position = tab.getPosition();
    Log.i("card", "Tablayout pos: " + position);
    //TabLayout.Tab tabdata=tabLayout.getTabAt(position);
    //tabdata.select();
    tabLayout.post(new Runnable() {
        @Override
        public void run() {
            if (position == 0) {
                PaymentCardFragment paymentCardFragment = getPaymentCardFragment();
                if (paymentCardFragment != null) {
                   VerticalViewpager vp = paymentCardFragment.mypager;
                    if(vp!=null)
                    {
                      //vp.setCurrentItem(position,true);
                      vp.setCurrentItem(vp.getAdapter().getCount()-1,true);
                    }
                  }
            }
            if (position == 1) {
               LoyaltyCardFragment loyaltyCardFragment = getLoyaltyCardFragment();
                if (loyaltyCardFragment != null) {
                   VerticalViewpager vp = loyaltyCardFragment.mypager;
                    if(vp!=null)
                    {
                        vp.setCurrentItem(position);
                    }
                  }
            }
        }
    });
}

@Override
public void onTabUnselected(TabLayout.Tab tab) {
 //This will be called 1st when you select a tab or swipe using viewpager
}
@Override
public void onTabReselected(TabLayout.Tab tab) {
  //This will be called only when you select the already selected tab(Ex: selecting 3rd tab again and again)
}
 private PaymentCardFragment getLoyaltyCardFragment() {
    Fragment f = adapter.mFragmentList.get(viewPager.getCurrentItem());

   if(f instanceof PaymentCardFragment)
   {
    return (PaymentCardFragment) f;
   }
   return null;
 }
private LoyaltyCardFragment getPaymentCardFragment() {
    Fragment f = adapter.mFragmentList.get(viewPager.getCurrentItem());
    if(f instanceof LoyaltyCardFragment)
   {
    return (LoyaltyCardFragment) f;
   }
   return null;
 }
  class ViewPagerAdapter extends FragmentPagerAdapter {
   public List<Fragment> mFragmentList = new ArrayList<>();
    private final List<String> mFragmentTitleList = new ArrayList<>();
   public void addFragment(Fragment fragment, String title) {
   mFragmentList.add(fragment);
   mFragmentTitleList.add(title);
  }
 }
}
1
anand krish

вы должны использовать viewPager

 viewPager.setCurrentItem(n);
 tabLayout.setOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
            @Override
            public void onTabSelected(TabLayout.Tab tab) {
                viewPager.setCurrentItem(tab.getPosition());
            }

            @Override
            public void onTabUnselected(TabLayout.Tab tab) {
            }

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

            }
        });
1
Luis Muñoz

Немного поздно, но может быть полезным решением. Я использую свой TabLayout непосредственно в своем фрагменте и пытаюсь выбрать вкладку довольно рано в жизненном цикле фрагмента. Для меня работало ожидание, пока TabLayout не закончит рисование своих дочерних представлений с помощью метода Android.view.View#post. то есть:

int myPosition = 0;
myFilterTabLayout.post(() -> { filterTabLayout.getTabAt(myPosition).select(); });
1
ahmed_khan_89

Комбинированное решение из разных ответов:

new Handler().postDelayed(() -> {

  myViewPager.setCurrentItem(position, true);

  myTabLayout.setScrollPosition(position, 0f, true);
},
100);
1
Zon

Если так получилось, что ваша вкладка по умолчанию является первой (0), и вы случайно переключаетесь на фрагмент, то вы должны вручную заменить фрагмент в первый раз. Это потому, что вкладка выбирается до того, как слушатель будет зарегистрирован.

private TabLayout mTabLayout;

...

@Override
public View onCreateView(@NonNull LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.fragment_tablayout, container, false);
    mTabLayout = view.findViewById(R.id.sliding_tabs);
    mTabLayout.addOnTabSelectedListener(mOnTabSelectedListener);

    getActivity().getSupportFragmentManager().beginTransaction()
        .replace(R.id.tabContent, MyFirstFragment.newInstance()).commit();
    return view;
}

В качестве альтернативы вы можете рассмотреть вызов getTabAt(0).select() и переопределение onTabReselected следующим образом:

@Override
public void onTabReselected(TabLayout.Tab tab) {
    // Replace the corresponding tab fragment.
}

Это будет работать, потому что вы по существу заменяете фрагмент на каждой вкладке, повторно выбирая.

1
farthVader

Если у вас есть проблемы с пониманием, этот код может помочь вам

private void MyTabLayout(){
    TabLayout.Tab myTab = myTabLayout.newTab(); // create a new tab
    myTabLayout.addTab(myTab); // add my new tab to myTabLayout
    myTab.setText("new tab"); 
    myTab.select(); // select the new tab
}

Вы также можете добавить это в свой код:

myTabLayout.setTabTextColors(getColor(R.color.colorNormalTab),getColor(R.color.colorSelectedTab));
0
alexandre petitjean

Это тоже может помочь

viewPager.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
    @Override
    public void onPageScrolled(int i, float v, int i1) {
    }

    @Override
    public void onPageSelected(int i) {
        tablayout.getTabAt(i).select();
    }

    @Override
    public void onPageScrollStateChanged(int i) {
    }
});
0
Hadi Note

Попробуйте так.

tabLayout.setTabTextColors(getResources().getColor(R.color.colorHintTextLight),
                           getResources().getColor(R.color.colorPrimaryTextLight));
0
Anandharaj R

Вы можете установить положение TabLayout, используя следующие функции

public void setTab(){
 tabLayout.setScrollPosition(YOUR_SCROLL_INDEX,0,true);
 tabLayout.setSelected(true);
}
0
Dhruv Narayan Singh

если вы используете TabLayout без ViewPager, это помогает

 mTitles = getResources().getStringArray(R.array.tabItems);
    mIcons = getResources().obtainTypedArray(R.array.tabIcons);
    for (int i = 0; i < mTitles.length; i++) {

        tabs.addTab(tabs.newTab().setText(mTitles[i]).setIcon(mIcons.getDrawable(i)));
        if (i == 0) {
            /*For setting selected position 0 at start*/
            Objects.requireNonNull(Objects.requireNonNull(tabs.getTabAt(i)).getIcon()).setColorFilter(ContextCompat.getColor(getApplicationContext(), R.color.colorPrimary), PorterDuff.Mode.SRC_IN);
        }
    }

    tabs.addOnTabSelectedListener(new TabLayout.OnTabSelectedListener() {
        @Override
        public void onTabSelected(TabLayout.Tab tab) {
            Objects.requireNonNull(tab.getIcon()).setColorFilter(ContextCompat.getColor(getApplicationContext(), R.color.colorPrimary), PorterDuff.Mode.SRC_IN);
        }

        @Override
        public void onTabUnselected(TabLayout.Tab tab) {
            Objects.requireNonNull(tab.getIcon()).setColorFilter(ContextCompat.getColor(getApplicationContext(), R.color.white), PorterDuff.Mode.SRC_IN);
        }

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

        }
    });
0
Tijo Thomas