使用TabLayout做横向滑动菜单

本文介绍了如何利用TabLayout创建一个支持横向滑动的菜单。首先,需要导入必要的类库,然后在布局文件中配置TabLayout,最后在MainActivity中进行相关设置,以达到预期的横滑效果。

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

在使用TabLayout要进行导入类库(系统自带)


在build.gradle中更改版本号

在布局中

<android.support.v4.widget.DrawerLayout
    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:id="@+id/mydraw"
    tools:context="com.example.zonghelianxi.MainActivity">
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        >
        <android.support.design.widget.TabLayout

            android:layout_width="match_parent"

            android:layout_height="wrap_content"

            app:tabGravity="center"

            app:tabIndicatorColor="@color/colorAccent"

            app:tabMode="scrollable"

            app:tabSelectedTextColor="@color/colorPrimaryDark"

            app:tabTextColor="@color/colorPrimary"

            android:id="@+id/tablayout1">



        </android.support.design.widget.TabLayout>



        <android.support.v4.view.ViewPager

            android:layout_width="match_parent"

            android:layout_height="match_parent"

            android:id="@+id/vp"

            android:layout_below="@id/tablayout1"></android.support.v4.view.ViewPager>
    </LinearLayout>
    <LinearLayout
        android:layout_width="200dp"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:layout_gravity="start"
        android:background="#00f"
        android:id="@+id/lin_menu">

        <ListView
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:id="@+id/menulistview"></ListView>
    </LinearLayout>


</android.support.v4.widget.DrawerLayout>

mainactivity中

public class MainActivity extends AppCompatActivity {

    private DrawerLayout mydraw;
    private LinearLayout linmenu;
    private ListView menulv;
    private TabLayout tab;
    private ArrayList <String> menus;
    private ViewPager vp;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate (savedInstanceState);
        setContentView (R.layout.activity_main);
        tab = findViewById (R.id.tablayout1);
        vp = findViewById (R.id.vp);
        menus = new ArrayList<> ( );
        for (int i = 0; i <10 ; i++) {
            menus.add ("列表"+i);
        }

        vp.setAdapter (new vpadapter(getSupportFragmentManager ()) );
        tab.setupWithViewPager (vp);


    }


    class vpadapter extends FragmentPagerAdapter {


        public vpadapter(FragmentManager fm) {
            super (fm);
        }

        @Override
        public CharSequence getPageTitle(int position) {
            return menus.get (position);
        }

        @Override
        public Fragment getItem(int position) {
            Fragment01 fragment01 = new Fragment01 ( );
            return fragment01;
        }

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

效果如下



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值