使用ViewPagerIndicator单击选项卡时禁用平滑动画

时间:2013-04-18 08:08:21

标签: android android-viewpager viewpagerindicator

我正在使用ViewPagerIndicator lib中的TabPageIndicator和ViewPager来显示6个片段。假设我在第一页,如果我点击第6个标签,我会看到所有页面都滚动。是否可以禁用此动画?也许我可以在ViewPager中以某种方式禁用它?

以下是适配器代码:

public class TabBarFragmentPagerAdapter extends FragmentPagerAdapter implements IconPagerAdapter {
private final List<Fragment> items;
private static final String[] TITLES = new String[] { "Home", "Profile", "Explore", "Contacts", "Beacon" };
private static final int[] ICONS = new int[] {
        R.drawable.icon_tabbar_home_bg,
        R.drawable.icon_tabbar_profile_bg,
        R.drawable.icon_tabbar_explore_bg,
        R.drawable.icon_tabbar_contacts_bg,
        R.drawable.icon_tabbar_beacon_bg
};

public TabBarFragmentPagerAdapter(FragmentManager fm, List<Fragment> items) {
    super(fm);
    this.items = items;
}

@Override
public Fragment getItem(int position) {
    return items.get(position);
}

@Override
public int getIconResId(int index) {
    return ICONS[index];
}

@Override
public CharSequence getPageTitle(int position) {
    return TITLES[position];
}

@Override
public int getCount() {
    return items.size();
}
}

3 个答案:

答案 0 :(得分:10)

另一种选择是覆盖setCurrentItem(int i)类子类CustomViewPager中的ViewPager,如下所示:

@Override
public void setCurrentItem(int item) {
    super.setCurrentItem(item,false);
}

答案 1 :(得分:4)

我调查了TabPageIndicator的代码,我发现现在不可能。请参阅mTabClickListener的代码:

private final OnClickListener mTabClickListener = new OnClickListener() {
    public void onClick(View view) {
        TabView tabView = (TabView)view;
        final int oldSelected = mViewPager.getCurrentItem();
        final int newSelected = tabView.getIndex();
        mViewPager.setCurrentItem(newSelected);
        if (oldSelected == newSelected && mTabReselectedListener != null) {
            mTabReselectedListener.onTabReselected(newSelected);
        }
    }
};

要支持此功能,我们应该向setCurrentItem添加第二个参数。像这样:

mViewPager.setCurrentItem(newSelected, smoothScrollEnabled);

答案 2 :(得分:0)

您现在可以使用材料库和viewPager2中的TabLayout以及仅这段代码来同步它们并禁用平滑滚动:

TabLayoutMediator(tabLayout, pager, false, false) { tab, position ->
                when(position) {
                    0 -> tab.text = "text 1"
                    1 -> tab.text = "text 2"
                    2 -> tab.text = "text 3"
                }
            }.attach()

设置为false的第二个布尔参数是 smoothScroll 参数

更多信息和官方文档: https://material.io/develop/android/components/tabs