design包中的tablayout的使用

本文介绍如何使用Android的TabLayout和ViewPager组件实现标签页切换效果。通过创建自定义的FragmentPagerAdapter,实现不同标签页间的Fragment切换,并展示了如何设置TabLayout的样式及功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

布局的代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
    android:orientation="vertical"
    android:background="#F8F8F8"
    android:id="@+id/linear"
    tools:context="com.yangzhuokeji.myapplication.MainActivity">

    <android.support.design.widget.TabLayout
        android:background="@android:color/white"
        android:layout_marginTop="5dp"
        android:id="@+id/tab"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabIndicatorColor="#3082B4"
        android:enabled="false"
        app:tabTextColor="@android:color/black"
       app:tabSelectedTextColor="#3082B4"
        app:tabMode="fixed" />

    <android.support.v4.view.ViewPager
        android:layout_marginTop="10dp"
        android:background="@android:color/white"
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>
MyActivity.class
  1. import android.support.design.widget.TabLayout;  
  2. import android.support.v4.app.Fragment;  
  3. import android.support.v4.app.FragmentPagerAdapter;  
  4. import android.support.v4.content.ContextCompat;  
  5. import android.support.v4.view.ViewPager;  
  6. import android.support.v7.app.AppCompatActivity;  
  7. import android.os.Bundle;  
  8. import android.widget.LinearLayout;  
  9.   
  10. public class MainActivity extends AppCompatActivity {  
  11.     private LinearLayout linearLayout;  
  12.     Fragment[] fragments = {new BlankFragment(), new Blank2Fragment(), new Blank3Fragment(), new Blank4Fragment()};  
  13.     String[] titles = {"全部""已通过""审核中""未通过"};  
  14.   
  15.     @Override  
  16.     protected void onCreate(Bundle savedInstanceState) {  
  17.         super.onCreate(savedInstanceState);  
  18.         setContentView(R.layout.activity_main);  
  19.         TabLayout tab = (TabLayout) findViewById(R.id.tab);  
  20.         linearLayout = (LinearLayout) findViewById(R.id.linear);  
  21.         //添加tablayout中的竖线  
  22.         LinearLayout linearLayout = (LinearLayout) tab.getChildAt(0);  
  23.         linearLayout.setShowDividers(LinearLayout.SHOW_DIVIDER_MIDDLE);  
  24.         linearLayout.setDividerDrawable(ContextCompat.getDrawable(this,  
  25.                 R.drawable.divider));  
  26.         ViewPager viewPager = (ViewPager) findViewById(R.id.viewpager);  
  27.         viewPager.setAdapter(new FragmentPagerAdapter(getSupportFragmentManager()) {  
  28.             @Override  
  29.             public Fragment getItem(int position) {  
  30.   
  31.                 return fragments[position];  
  32.             }  
  33.   
  34.             @Override  
  35.             public int getCount() {  
  36.                 return fragments.length;  
  37.             }  
  38.   
  39.             @Override  
  40.             public CharSequence getPageTitle(int position) {  
  41.                 return titles[position];  
  42.             }  
  43.         });  
  44.         tab.setupWithViewPager(viewPager);  
  45.     }  
  46. }  

fragment举例:

  1. public class BlankFragment extends Fragment {  
  2.   
  3.   
  4.     public BlankFragment() {  
  5.         // Required empty public constructor  
  6.     }  
  7.   
  8.   
  9.     @Override  
  10.     public View onCreateView(LayoutInflater inflater, ViewGroup container,  
  11.                              Bundle savedInstanceState) {  
  12.         // Inflate the layout for this fragment  
  13.         return inflater.inflate(R.layout.fragment_blank, container, false);  
  14.     }  
  15.   
  16. }  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值