TabLayout-标签布局

TabLayout是Material design控件之一,效果图如下:

图片.png

(1)导入依赖包

implementation 'com.android.support:design:28.0.0'

(2)基础代码

<android.support.design.widget.TabLayout    android:id="@+id/tabLayout"android:layout_width="match_parent"android:layout_height="wrap_content"/>

tabLayout = findViewById(R.id.tabLayout);    tabLayout.addTab(tabLayout.newTab().setText("首页").setIcon(R.mipmap.home));    tabLayout.addTab(tabLayout.newTab().setText("消息").setIcon(R.mipmap.message));    tabLayout.addTab(tabLayout.newTab().setText("工具").setIcon(R.mipmap.tool));    tabLayout.addTab(tabLayout.newTab().setText("提醒").setIcon(R.mipmap.notification));    tabLayout.addTab(tabLayout.newTab().setText("我").setIcon(R.mipmap.me));

以上就是基础代码,首先在xml中写一个TabLayout布局,然后用代码为TabLayout添加Tab,Tab中设置好文字和图片,效果如下:

25.gif

(3)基本属性

tabTextColor:设置Tab未被选中时的文字颜色

app:tabTextColor="@color/bt_1"

图片.png

tabSelectedTextColor:设置选中项中的字体颜色

app:tabSelectedTextColor="@color/colorPrimary"

图片.png

tabBackground:设置Tab背景

app:tabBackground="@color/bt_1"

图片.png

tabIndicatorColor:设置指示器的颜色

app:tabIndicatorColor="@color/bt_1"

图片.png

tabIndicatorHeight:设置指示器的高度

app:tabIndicatorHeight="10dp"

图片.png

tabTextAppearance:设置style改变字体属性

app:tabTextAppearance="@style/AppTheme.TabLayout.TextAppearance"

<stylename="AppTheme.TabLayout.TextAppearance"parent="TextAppearance.Design.Tab"><itemname="android:textSize">16sp</item><itemname="android:textColor">#B2A04D4D</item><itemname="textAllCaps">false</item></style>

图片.png

tabMode:设置Tablayout的布局模式,有两个值

fixed:固定的,不能滑动,很多标签的时候会被挤压(默认是fixed)

app:tabMode="fixed"

图片.png

scrollable:可以滑动的

app:tabMode="scrollable"

26.gif

tabGravity:设置TabLayout的布局方式,有两个值

fill:充满

app:tabGravity="fill"

图片.png

center:居中

app:tabGravity="center"

图片.png

默认是fill,且只有当tabMode为fixed时才有效

tabMaxWidth:设置tab项最大的宽度

tabMinWidth:设置tab项最小的宽度

tabContentStart:设置TabLayout开始位置的偏移量

paddingStart,paddingEnd:设置整个TabLayout的内边距

tabPadding,tabPaddingStart,tabPaddingEnd,tabPaddingTop,tabPaddingBottom:设置tab项的内边距

style:设置样式

style="@style/AppTheme.TabLayout"

<stylename="AppTheme.TabLayout"parent="Widget.Design.TabLayout"><itemname="tabMode">scrollable</item><itemname="tabIndicatorColor">@color/bt_1</item><itemname="tabIndicatorHeight">4dp</item><itemname="tabTextAppearance">@style/AppTheme.TabLayout.TextAppearance</item><itemname="tabBackground">@color/colorPrimary</item><itemname="tabSelectedTextColor">@color/bt_2</item></style>

tabIconTint:设置文字上面图标的颜色

app:tabIconTint="@color/bt_1"

图片.png

tabIconTintMode:文字上的图标和文字上图标区域的颜色之间的图像混合模式

app:tabIconTintMode="src_in"

这个混合模式可以查看以下xfermode示例图

xfermode示例图.jpg

它的取值有:src_atop、src_over、add、screen、src_in、multiply

tabIndicatorFullWidth:指示器是否沾满整个宽度(默认为true)

app:tabIndicatorFullWidth="false"

值为true的效果:

图片.png

值为false的效果:

图片.png

tabIndicatorGravity:设置指示器的方位(默认指示器在下方)

app:tabIndicatorGravity="bottom"

它有四个值,分别是:

top:指示器在上方

图片.png

bottom:指示器在下方

图片.png

center:指示器在中间

图片.png

stretch:指示器沾满整个布局

图片.png

tabIndicatorAnimationDuration:设置指示器动画时间

app:tabIndicatorAnimationDuration="5000"

26.gif

tabInlineLabel:设置图标和文件的方向(默认为false)

app:tabInlineLabel="true"

如果为true

图片.png

tabRippleColor:设置水波纹的颜色

app:tabRippleColor="@color/bt_1"

27.gif

tabUnboundedRipple:设置水波纹是否有边界(默认有边界)

app:tabUnboundedRipple="true"

如果为true,则无边框

28.gif

(4)设置监听

tabLayout.addOnTabSelectedListener(newTabLayout.OnTabSelectedListener(){

@OverridepublicvoidonTabSelected(TabLayout.Tabtab){//添加选中Tab的逻辑

}

@OverridepublicvoidonTabUnselected(TabLayout.Tabtab){//添加未选中Tab的逻辑

}

@OverridepublicvoidonTabReselected(TabLayout.Tabtab){//再次选中tab的逻辑

}});

它有三个回调方法,假如初始位置在“首页”标签,现在从“首页”标签点到“我”标签,那么onTabUnselected首先被执行,这里的tab是“首页”标签,然后onTabSelected被执行,这里的tab是“我”标签。

又假如,当前标签是“首页”标签,现再次点击“首页”标签,这是onTabReselected回调被触发。

(5)与ViewPager关联

代码如下:

mytab.setupWithViewPager(mViewPager);

(6)github中丰富TabLayout推荐

https://github.com/18317084205/JTabLayout

大家有空可以看一下这位大神的项目。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,287评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,346评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,277评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,132评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,147评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,106评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,019评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,862评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,301评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,521评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,682评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,405评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,996评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,651评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,803评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,674评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,563评论 2 352