android - 使用androidx 提供的tab fragment方式来实现标签页
访问量: 2371
关于底部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>