温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Android中基于TabLayout+ViewPager如何实现标签卡效果

发布时间:2021-07-19 09:56:20 来源:亿速云 阅读:165 作者:小新 栏目:移动开发

小编给大家分享一下Android中基于TabLayout+ViewPager如何实现标签卡效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

先看效果

Android中基于TabLayout+ViewPager如何实现标签卡效果

1、布局文件

<?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"   tools:context="com.plbear.yyj.myapplication.MainActivity">   <android.support.design.widget.TabLayout     android:id="@+id/tab"     android:layout_width="match_parent"     android:layout_height="40dp"     app:tabGravity="fill"     app:tabIndicatorColor="#4978ef"     app:tabIndicatorHeight="2dp"     app:tabMode="scrollable"     app:tabSelectedTextColor="#4978ef"     app:tabTextColor="#222222"></android.support.design.widget.TabLayout>   <android.support.v4.view.ViewPager     android:id="@+id/view_pager"     android:layout_width="match_parent"     android:layout_height="wrap_content"></android.support.v4.view.ViewPager> </LinearLayout>

2、代码实现

package com.plbear.yyj.myapplication import android.os.Bundle import android.support.design.widget.Snackbar import android.support.design.widget.TabLayout import android.support.v4.app.Fragment import android.support.v4.app.FragmentPagerAdapter import android.support.v7.app.AppCompatActivity import android.view.Menu import android.view.MenuItem import kotlinx.android.synthetic.main.activity_main.* class MainActivity : AppCompatActivity() {   var mFragList = ArrayList<Fragment>()   var adapter = object:FragmentPagerAdapter(supportFragmentManager){     override fun getItem(position: Int): Fragment {       return mFragList[position]     }     override fun getCount(): Int {       return 2     }   }   override fun onCreate(savedInstanceState: Bundle?) {     super.onCreate(savedInstanceState)     setContentView(R.layout.activity_main)     initViewPager() //先将各个fragment加入到viewpager中     initTabLayout(); //初始化tablayout   }   fun initTabLayout(){     tab.setupWithViewPager(view_pager)     tab.setTabsFromPagerAdapter(adapter)     tab.tabMode = TabLayout.MODE_FIXED     tab.getTabAt(0)?.setText("第一页")     tab.getTabAt(1)?.setText("第二页")   }   fun initViewPager(){     mFragList.add(Fragment1())     mFragList.add(Fragment2())     view_pager.adapter = adapter   } }

这里需要注意点,需要先将setupWithViewPager和tablayout绑定起来,然后再初始化tab的标签页,这个非常重要,否则会造成tablayout中的文字显示不出来。

看完了这篇文章,相信你对“Android中基于TabLayout+ViewPager如何实现标签卡效果”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI