Android控件<第十四篇>: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"


<style name="AppTheme.TabLayout.TextAppearance" parent="TextAppearance.Design.Tab">
    <item name="android:textSize">16sp</item>
    <item name="android:textColor">#B2A04D4D</item>
    <item name="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"


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

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

app:tabIconTint="@color/bt_1"
图片.png

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

    app:tabIconTintMode="src_in"

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

xfermode示例图.jpg

它的取值有:src_atopsrc_overaddscreensrc_inmultiply

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(new TabLayout.OnTabSelectedListener() {
        @Override
        public void onTabSelected(TabLayout.Tab tab) {
            //添加选中Tab的逻辑
        }

        @Override
        public void onTabUnselected(TabLayout.Tab tab) {
            //添加未选中Tab的逻辑
        }

        @Override
        public void onTabReselected(TabLayout.Tab tab) {
            //再次选中tab的逻辑
        }
    });

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

(5)与ViewPager关联

代码如下:

mytab.setupWithViewPager(mViewPager);
(6)github中丰富TabLayout推荐

https://github.com/18317084205/JTabLayout

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

[本章完...]

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

推荐阅读更多精彩内容