我们可以固定所选标签的位置吗?
Can we fix position of selected tab?
我想用 TabLayout
实现制表符,但方式不同。我想要的是,我的选项卡应该是可滚动的,但我想将所选选项卡的位置固定在中间。到目前为止,我发现我们可以有固定的选项卡或可滚动的选项卡,但与选定选项卡的固定位置无关。这可能吗?
如果我理解你的话,你可以用一个简单的 TabLayout 来生成它。
xml(可滚动标签模式)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/holo_blue_light"
app:tabMode="scrollable" />
<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" />
</RelativeLayout>
您的 Activity - 带有简单适配器的初始页面适配器 - 我在这里称之为 PagerAdapter。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewPager viewPager = (ViewPager) findViewById(R.id.viewpager);
PagerAdapter adapter = new PagerAdapter(getSupportFragmentManager());
adapter.addFragment(new TestFragment(), "ONE");
adapter.addFragment(new TestFragment(), "TWO");
adapter.addFragment(new TestFragment(), "THREE");
adapter.addFragment(new TestFragment(), "FOUR");
adapter.addFragment(new TestFragment(), "FIVE");
adapter.addFragment(new TestFragment(), "SIX");
adapter.addFragment(new TestFragment(), "SEVEN");
adapter.addFragment(new TestFragment(), "EIGHT");
adapter.addFragment(new TestFragment(), "NINE");
adapter.addFragment(new TestFragment(), "TEN");
viewPager.setAdapter(adapter);
TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
tabLayout.setupWithViewPager(viewPager);
}
如您所见,如果选择了 "SEVEN" 选项卡,则它位于中间。
刚发现这个库 SmartTabLayout,这正是我想要的。把它张贴在这里,以防将来有人需要它。
我想用 TabLayout
实现制表符,但方式不同。我想要的是,我的选项卡应该是可滚动的,但我想将所选选项卡的位置固定在中间。到目前为止,我发现我们可以有固定的选项卡或可滚动的选项卡,但与选定选项卡的固定位置无关。这可能吗?
如果我理解你的话,你可以用一个简单的 TabLayout 来生成它。
xml(可滚动标签模式)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/holo_blue_light"
app:tabMode="scrollable" />
<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" />
</RelativeLayout>
您的 Activity - 带有简单适配器的初始页面适配器 - 我在这里称之为 PagerAdapter。
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
ViewPager viewPager = (ViewPager) findViewById(R.id.viewpager);
PagerAdapter adapter = new PagerAdapter(getSupportFragmentManager());
adapter.addFragment(new TestFragment(), "ONE");
adapter.addFragment(new TestFragment(), "TWO");
adapter.addFragment(new TestFragment(), "THREE");
adapter.addFragment(new TestFragment(), "FOUR");
adapter.addFragment(new TestFragment(), "FIVE");
adapter.addFragment(new TestFragment(), "SIX");
adapter.addFragment(new TestFragment(), "SEVEN");
adapter.addFragment(new TestFragment(), "EIGHT");
adapter.addFragment(new TestFragment(), "NINE");
adapter.addFragment(new TestFragment(), "TEN");
viewPager.setAdapter(adapter);
TabLayout tabLayout = (TabLayout) findViewById(R.id.tabs);
tabLayout.setupWithViewPager(viewPager);
}
如您所见,如果选择了 "SEVEN" 选项卡,则它位于中间。
刚发现这个库 SmartTabLayout,这正是我想要的。把它张贴在这里,以防将来有人需要它。