一、修改點選的動畫
函式:setUnboundedRipple
這是預設的點選的動畫
data:image/s3,"s3://crabby-images/223dc/223dc4b2ba8d95284fa72c0bbc2421804b28fa1c" alt="TabLayout您可能不知道的實用用法"
mGlueTabLayout.setUnboundedRipple(true);
複製程式碼
這是之後的效果:
data:image/s3,"s3://crabby-images/d0c85/d0c851cf3218d4c7368222e55773815d5a8aa046" alt="TabLayout您可能不知道的實用用法"
二、設定下劃線指示器的寬度不要填充完(動態的根據TabView的寬度來設定自身的寬度)
函式:setTabIndicatorFullWidth
這是預設的效果
data:image/s3,"s3://crabby-images/84637/8463788b93adcfaeb600deedd3d7859258ba05df" alt="TabLayout您可能不知道的實用用法"
mGlueTabLayout.setTabIndicatorFullWidth(false);
複製程式碼
這是之後的效果:
data:image/s3,"s3://crabby-images/5b409/5b4098a2a2ce8f13c1503fb4cfc4cbdff169532e" alt="TabLayout您可能不知道的實用用法"
三、設定下劃線指示器的樣式
函式:setSelectedTabIndicator
這是預設的效果
data:image/s3,"s3://crabby-images/84637/8463788b93adcfaeb600deedd3d7859258ba05df" alt="TabLayout您可能不知道的實用用法"
GradientDrawable gradientDrawable = new GradientDrawable();
gradientDrawable.setCornerRadius(dp2px(2));
mGlueTabLayout.setSelectedTabIndicator(gradientDrawable);
複製程式碼
我改變了其的直角,變為了圓角,看效果吧:
data:image/s3,"s3://crabby-images/4c7b2/4c7b2d354bcf4aa449c5ebefc9c4cbaa89e6776e" alt="TabLayout您可能不知道的實用用法"
res/drawable
資料夾下寫個xml檔案傳入setSelectedTabIndicator(@DrawableRes int tabSelectedIndicatorResourceId)
,效果是一樣的。
這個您也許也需要
data:image/s3,"s3://crabby-images/831e8/831e8c6b98e7024a6ca49537ac1028e6f7387fc4" alt="粘動動畫.gif"
所以,我寫了GlueTabLayout
簡單擴充套件了TabLayout
,新增了這個動畫,GlueTabLayout
本質就是TabLayout
,一點未變,您怎麼用TabLayout
,就可以怎麼使用GlueTabLayout
,是不是很友好,哈哈。
我還新增了一個TabLayout
沒有提供的方法,我新增了精確設定下劃線指示器寬度的方法。
我把它開源了,用以方便有需要的人,更詳細的描述移步 GitHub 。
以上 :)