基于TabLayout中的Tab間隔設(shè)置方法(實例講解)
TabLayout和ViewPager搭配使用,是有很多方便性,但是TabLayout這東西還是有很多被人吐槽的地方。
這里只講怎么設(shè)置tab之間的間隔,網(wǎng)上找了一堆方法,什么padding和margin的啥都沒用,沒辦法,想用TabLayout只能自己想辦法了。效果如下:

一、實現(xiàn)方法,既然這東西不好設(shè)置,那就直接在背景上做點事情,布局代碼如下:
<android.support.design.widget.TabLayout xmlns:app="http://schemas.android.com/apk/res-auto" android:id="@+id/tl_download_tabs" android:layout_width="wrap_content" android:layout_height="30dp" android:layout_marginTop="10dp" android:layout_gravity="center_horizontal" android:overScrollMode="never" app:tabMode="fixed" app:tabPaddingStart="30dp" app:tabPaddingEnd="30dp" app:tabIndicatorHeight="0dp" app:tabBackground="@drawable/download_tab_bg_selector" app:tabSelectedTextColor="#000000" app:tabTextColor="#ffffff"/>
二、其中關(guān)鍵的地方就在背景的selector上,代碼如下:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_selected="true">
<!--<shape>
<solid android:color="#ffffff"/>
<corners android:topLeftRadius="10dp" android:topRightRadius="10dp" />
</shape>-->
<!--為了讓TabLayout內(nèi)部的Tab有間隔,暫時找不到其他設(shè)置方法,只能在背景圖形里面設(shè)置間隔-->
<layer-list>
<item>
<shape>
<solid android:color="@android:color/transparent"/>
</shape>
</item>
<item android:left="5dp" android:right="5dp">
<shape>
<corners android:topLeftRadius="10dp" android:topRightRadius="10dp" />
<solid android:color="#ffffff"/>
</shape>
</item>
</layer-list>
</item>
<item android:state_selected="false">
<!--<shape>
<solid android:color="#bcbcbc"/>
<corners android:topLeftRadius="10dp" android:topRightRadius="10dp" />
</shape>-->
<layer-list>
<item>
<shape>
<solid android:color="@android:color/transparent"/>
</shape>
</item>
<item android:left="5dp" android:right="5dp">
<shape>
<corners android:topLeftRadius="10dp" android:topRightRadius="10dp" />
<solid android:color="#bcbcbc"/>
</shape>
</item>
</layer-list>
</item>
</selector>
注釋掉的地方是原來沒間隔的selector,這里直接給背景設(shè)置了個左右的padding,效果杠杠的。
缺點:如果間隔過大的話,那這種方式就有一點的缺陷了,就是點擊到空白處,也能選中tab。
不過對于間隔不是很大的,基本是感覺不出來的。
三、Activity的使用就很簡單了:
TabLayout mTabLayout = (TabLayout) findViewById(R.id.tl_download_tabs);
mTabLayout.addTab(mTabLayout.newTab().setText("已下載"));
mTabLayout.addTab(mTabLayout.newTab().setText("下載中"));
mTabLayout.setupWithViewPager(mViewPager);
四、原來是線性布局下,放著TabLayout和ViewPager,試著在TabLayout外嵌套多一個RelativeLayout,發(fā)現(xiàn)出來的效果Tab的文字不顯示了,至于網(wǎng)上說的調(diào)換addTab和setupWithViewPager的順序也是坑,可以看到顯示,但是出現(xiàn)了更離譜的情況,前面兩個空白,后面還多了兩個正常的,反正是很奇葩。
最后還是得在Adapter中去處理,把以下方法重寫下就可以了,其實這樣可能更合理些,至少能保證Tab的數(shù)量和ViewPager的頁數(shù)是一致的。
@Override
public CharSequence getPageTitle(int position) {
if(position == 0){
return "已下載";
}else if(position == 1){
return "下載中";
}
return "";
}
以上這篇基于TabLayout中的Tab間隔設(shè)置方法(實例講解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Android?縮放動畫?ScaleAnimation的使用小結(jié)
ScaleAnimation即縮放動畫,應用場景特別多,比如常見的隱藏菜單點擊顯示,這篇文章主要介紹了Android?縮放動畫?ScaleAnimation的使用小結(jié),需要的朋友可以參考下2024-03-03
Listview加載的性能優(yōu)化是如何實現(xiàn)的
在android開發(fā)中Listview是一個很重要的組件,它以列表的形式根據(jù)數(shù)據(jù)的長自適應展示具體內(nèi)容,用戶可以自由的定義listview每一列的布局,接下來通過本文給大家介紹Listview加載的性能優(yōu)化是如何實現(xiàn)的,對listview性能優(yōu)化相關(guān)知識感興趣的朋友一起學習吧2016-01-01
詳解Android App中使用VideoView來實現(xiàn)視頻播放的方法
這篇文章主要介紹了Android App中使用VideoView來實現(xiàn)視頻播放的方法,舉例講解了VideoView組件中setVidePath(String path)和setVideoURI(Uri uri)的用法,需要的朋友可以參考下2016-04-04
Android編程添加快捷方式(Short)到手機桌面的方法(含添加,刪除及查詢)
這篇文章主要介紹了Android編程添加快捷方式(Short)到手機桌面的方法,含有針對桌面快捷方式的添加,刪除及查詢的操作實現(xiàn)技巧,需要的朋友可以參考下2016-01-01
Android實現(xiàn)美團、大眾點評的購買懸浮效果(ScrollView滾動監(jiān)聽)
這篇文章主要為大家詳細介紹了Android對ScrollView滾動監(jiān)聽,實現(xiàn)美團、大眾點評的購買懸浮效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02
Android編程之菜單Menu的創(chuàng)建方法示例
這篇文章主要介紹了Android編程之菜單Menu的創(chuàng)建方法,結(jié)合實例形式分析了Android菜單Menu的布局、響應及功能實現(xiàn)技巧,需要的朋友可以參考下2017-08-08

