Day3(下) TabLayout的用法大全及其屬性詳解

通常在ViewPager的上方蓖议,我們都會放一個標簽指示器與ViewPager進行聯(lián)動矢否,同樣“愛閱”也是遵照這樣的設(shè)計風格進行設(shè)計和實現(xiàn)的腥刹。可選擇的實現(xiàn)方案其實有很多宴卖,比如:TabPageIndicator或者GitHub上的開源框架PagerSlidingTabTrip滋将。但是這些都是第三方的而且也已經(jīng)比較老了,所以我使用Android自帶的控件TabLayout來實現(xiàn)這個效果症昏,而且TabLayout更為強大随闽,因為Tab標簽可以使用自定義View并且可以實現(xiàn)多種屬性的設(shè)置。

首先來看下效果圖:

點此進入目錄:[干貨] 十天 教你從創(chuàng)意到上線APP

一肝谭、TabLayout的基本使用

1掘宪、在布局中加入該控件

    <android.support.design.widget.TabLayout
        android:id="@+id/tab_layout_main"
        style="@style/MyCustomTabLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:tabGravity="center"
        android:background="#D2A2CC"
        app:tabMode="scrollable" />

2蛾扇、在代碼中找到并設(shè)置

    @BindView(R.id.tab_layout_main)
    TabLayout mTabLayout;
    mTabLayout.addTab(tablayout.newTab().setText("新聞"));
    mTabLayout.addTab(tablayout.newTab().setText("天氣"));
    mTabLayout.addTab(tablayout.newTab().setText("娛樂"));
顯示效果
向上滑動還可收縮成這樣:

這樣我們就把最簡單的用法掌握了,但如果你想要往里面加入一些個性化設(shè)置也是可以的魏滚,比如你想加入圖片的話镀首,可以這么辦:

    mTabLayout.addTab(tablayout.newTab().setText("新聞").setIcon(R.mipmap.icon1));
    mTabLayout.addTab(tablayout.newTab().setText("天氣").setIcon(R.mipmap.icon2));
    mTabLayout.addTab(tablayout.newTab().setText("娛樂").setIcon(R.mipmap.icon3));

二、結(jié)合ViewPager施展魔法

基本的設(shè)置結(jié)束了鼠次,那么這個時候我們要實現(xiàn)最開始的效果 —— 滑動ViewPager的同時改變Tab的狀態(tài)更哄,要真么辦呢?

1腥寇、首先要準備好ViewPager的數(shù)據(jù)

在我們上午實現(xiàn)的ViewPagerAdapter中重寫getPageTitle()方法成翩,以此返回每個ViewPager的標題的數(shù)據(jù),代碼如下:

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

這個方法里對應返回的值就是我們最終想要顯示在Tab中的標題赦役,所以你要可以根據(jù)你自己的業(yè)務場景來進行實現(xiàn)捕传。

2、把ViewPager和TabLayout進行綁定

代碼很簡單扩劝,一行搞定:

    mTabLayout.setupWithViewPager(mViewpager);

沒錯庸论,setupWithViewPager()是TabLayout自帶的方法,就是專門用來和ViewPager視圖進行綁定的棒呛。如果沒有其他問題聂示,你會發(fā)現(xiàn)我們的基本視圖效果已經(jīng)實現(xiàn)了,但是如果你想要實現(xiàn)更多的屬性效果簇秒,可以參看接下來總結(jié)的一些常用屬性鱼喉。

三、TabLayout常用屬性

1趋观、顏色改變

  • 改變選中字體的顏色
app:tabSelectedTextColor="@android:color/holo_orange_light"
  • 改變未選中字體的顏色
app:tabTextColor="@color/colorPrimary"
  • 改變指示器下標的顏色
app:tabIndicatorColor="@android:color/holo_orange_light"
  • 改變整個TabLayout的顏色
app:tabBackground="color"

2扛禽、尺寸與圖標

  • 改變TabLayout內(nèi)部字體大小
app:tabTextAppearance="@android:style/TextAppearance.Holo.Large"
  • 改變指示器下標的高度
app:tabIndicatorHeight="4dp"
  • 添加圖標
mTabLayout.addTab(tabLayout.newTab().setText("Tab A").setIcon(R.mipmap.ic_launcher));
  • 內(nèi)容的顯示模式
app:tabGravity="center"  // 居中,如果是fill皱坛,則是充滿

3编曼、寬度限制

  • 設(shè)置最大的tab寬度
app:tabMaxWidth="xxdp"
  • 設(shè)置最小的tab寬度
app:tabMinWidth="xxdp"

4、TabLayout的監(jiān)聽事件

選中了某個tab的監(jiān)聽事件OnTabSelectedListener()

    tabLayout.setOnTabSelectedListener(newTabLayout.OnTabSelectedListener() {
    
        @Override
        public voidonTabSelected(TabLayout.Tab tab) {
            //選中了tab的邏輯
        }
        
        @Override
        public voidonTabUnselected(TabLayout.Tab tab) {
            //未選中tab的邏輯
        }
        
        @Override
        public voidonTabReselected(TabLayout.Tab tab) {
            //再次選中tab的邏輯
        }
    });

至此為止剩辟,我們TabLayout的最常用屬性就介紹完畢了掐场,如果你還有更復雜的需求,比如:Tab點擊縮放的實現(xiàn)贩猎,可以參考該鏈接:TabLayout使用方法詳解

聯(lián)系方式:

簡書:WillFlow
GitHub:愛閱

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末熊户,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子吭服,更是在濱河造成了極大的恐慌嚷堡,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件艇棕,死亡現(xiàn)場離奇詭異蝌戒,居然都是意外死亡串塑,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門瓶颠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拟赊,“玉大人,你說我怎么就攤上這事粹淋∥睿” “怎么了?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵桃移,是天一觀的道長屋匕。 經(jīng)常有香客問我,道長借杰,這世上最難降的妖魔是什么过吻? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮蔗衡,結(jié)果婚禮上纤虽,老公的妹妹穿的比我還像新娘。我一直安慰自己绞惦,他們只是感情好逼纸,可當我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著济蝉,像睡著了一般杰刽。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上王滤,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天贺嫂,我揣著相機與錄音,去河邊找鬼雁乡。 笑死第喳,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蔗怠。 我是一名探鬼主播墩弯,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼寞射!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起锌钮,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤桥温,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后梁丘,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體侵浸,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡旺韭,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了掏觉。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片区端。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖澳腹,靈堂內(nèi)的尸體忽然破棺而出织盼,到底是詐尸還是另有隱情,我是刑警寧澤酱塔,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布沥邻,位于F島的核電站,受9級特大地震影響羊娃,放射性物質(zhì)發(fā)生泄漏唐全。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一蕊玷、第九天 我趴在偏房一處隱蔽的房頂上張望邮利。 院中可真熱鬧,春花似錦垃帅、人聲如沸延届。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽祷愉。三九已至,卻和暖如春赦颇,著一層夾襖步出監(jiān)牢的瞬間二鳄,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工媒怯, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留订讼,地道東北人。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓扇苞,卻偏偏與公主長得像欺殿,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子鳖敷,可洞房花燭夜當晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容