android修改tab 導航 指標顏色

來源:互聯網
上載者:User

標籤:android   style   blog   class   code   c   


我其實想修改的上面的藍色條條,改成紅色。

這個問題實在是困擾我了太長時間。之前參照google的這個文章:

https://developer.android.com/training/basics/actionbar/styling.html

但是事與願違,我發現竟然連我整個tab顏色都改了。


覺得很奇怪,為什麼google給的方法是修改整個tab?難道google搞錯了?

網上找了很久,發現很多人都在問這個問題,而實際解決的人很少。偶爾有幾個解決的,也是採用google的那個方法。但是我的不對啊!

這個問題一直被放置。。中間幾次各種嘗試,不行。今天又搜尋,找到一個文章,我大致看了一下,還是採用google的方法,不過他附帶了源碼,有些疑問,為什麼他的顏色可以修改?就下載他的源碼運行看看效果。發現果然改掉了。這是為什嗎?最後發下,奧秘在於他採用的圖片,是上面透明,底下帶顏色的。而我之前採用的都是上下都有顏色,所以才會把整個tab覆蓋。

就是這種圖片:


呵呵,終於找到原因。

下面說下具體流程吧:這個流程上面給的那個google的文章有。

一、修改系統的styles.xml.V14以上版本在values-v14檔案夾下:

 <style name="AppBaseTheme" parent="android:Theme.Holo.Light.DarkActionBar">        <!-- API 14 theme customizations can go here. -->         <item name="android:actionBarStyle">@style/my_actionbar_style</item>         <item name="android:actionOverflowButtonStyle">@style/MyCustomTheme.OverFlow</item> <!-- it‘s work -->        <item name="android:homeAsUpIndicator">@drawable/upcaret</item>  <!-- it‘s work --><!--          <item name="android:actionButtonStyle">@style/my_actionbar_tabbar_style</item> -->         <!-- 設定ActionBar Tab的樣式,例如下面的紅色指引,Tab之間的間隙等等 -->  <item name="android:actionBarTabStyle">@style/myTabView</item>  <!-- 設定ActionBar Tab字型的樣式 -->  <!--     <item name="android:actionBarTabTextStyle">@style/myTabText</item>   -->    </style>
   <style name="myTabView" parent="@android:style/Widget.Holo.Light.ActionBar.TabView">        <item name="android:background">@drawable/tab_indicator</item>        <item name="android:paddingLeft">8dip</item>        <item name="android:paddingRight">8dip</item>    </style>  

二、在res下的drawable檔案夾下(如果沒有,自己建立一個)建立tab_indicator.xml:

<selector xmlns:android="http://schemas.android.com/apk/res/android">    <item android:state_selected="false" android:state_pressed="false" android:drawable="@android:color/transparent" />    <item android:state_selected="false" android:state_pressed="true" android:drawable="@android:color/transparent" />         <item android:state_selected="true"  android:state_pressed="false" android:drawable="@drawable/base_tabpager_indicator_selected" />    <item android:state_selected="true"  android:state_pressed="true" android:drawable="@drawable/base_tabpager_indicator_selected" /></selector>
至於神器的那個drawable圖片我上傳了一份,大家可以在此的基礎了換顏色和修改高度。地址:http://pan.baidu.com/s/1ozNKM

最終效果:


參考資料:
https://developer.android.com/training/basics/actionbar/styling.html
http://blog.csdn.net/xiaanming/article/details/9971721

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.