android - 使用androidx 提供的tab fragment方式来实现标签页
访问量: 2788
关于底部tab , 可以看这里:
http://siwei.me/blog/posts/android-tablayout-view-pager-tab-bottom-tab其实,这里还有个官方推荐: https://material.io/develop/android/components/bottom-navigation/ 是个很好的例子
我用的是androidx 提供的 TabPagerAdapter + ViewPager 实现的。参考:https://developer.android.com/guide/navigation/navigation-swipe-view
过程如下:
1. MainActivity 中,增加:
public class MainActivity extends AppCompatActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
Log.d("main", "== hihihi");
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
}
2. activity_main.xml 中,增加:
<fragment android:name="com.shentou.TabsFragment"
android:id="@+id/collection_demo_fragment"
android:layout_width="match_parent"
android:layout_weight="1"
android:layout_height="match_parent" />
3. 增加 TabsFragment.java
public class TabsFragment extends Fragment {
TabPagerAdapter tabPagerAdapter;
ViewPager viewPager;
@Nullable
@Override
public View onCreateView(@NonNull LayoutInflater inflater,
@Nullable ViewGroup container,
@Nullable Bundle savedInstanceState) {
return inflater.inflate(R.layout.my_view_pager, container, false);
}
@Override
public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
tabPagerAdapter = new TabPagerAdapter(getChildFragmentManager());
viewPager = view.findViewById(R.id.pager);
viewPager.setAdapter(tabPagerAdapter);
TabLayout tabLayout = view.findViewById(R.id.tab_layout);
tabLayout.setupWithViewPager(viewPager);
}
}
4. 增加 TabPagerAdapter.java
class TabPagerAdapter extends FragmentStatePagerAdapter {
public TabPagerAdapter(FragmentManager fm) {
super(fm);
}
@Override
public Fragment getItem(int i) {
Fragment fragment = new SingleTabFragment();
Bundle args = new Bundle();
// Our object is just an integer :-P
args.putInt(SingleTabFragment.ARG_OBJECT, i + 1);
fragment.setArguments(args);
return fragment;
}
@Override
public int getCount() {
return 2;
}
@Override
public CharSequence getPageTitle(int position) {
return "OBJECT " + (position + 1);
}
}
5. 增加: SingleTabFragment.java
public class SingleTabFragment extends Fragment {
public static final String ARG_OBJECT = "object";
@Override
public View onCreateView(LayoutInflater inflater,
ViewGroup container, Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment_tabs, container, false);
}
@Override
public void onViewCreated(@NonNull View view, @Nullable Bundle savedInstanceState) {
Bundle args = getArguments();
TextView text = (TextView) view.findViewById(R.id.text1);
Log.i("== text: ", text.toString());
text.setText(Integer.toString(args.getInt(ARG_OBJECT)));
}
}
增加 fragment_tabs.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:id="@+id/text1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
增加:my_view_pager.xml
<?xml version="1.0" encoding="utf-8"?>
<androidx.viewpager.widget.ViewPager
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent">
<com.google.android.material.tabs.TabLayout
android:id="@+id/tab_layout"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</androidx.viewpager.widget.ViewPager>