2013-07-15 108 views
0

我想将tabhost的默认蓝色更改为红色。更改tabhost风格android

<style name="AppTheme" parent="android:Theme.Light.NoTitleBar"> 
      <item name="android:tabWidgetStyle">@drawable/tab_indicator_holo</item> 
      </style> 

tab_indicator_holo.xml

<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
    <!-- Non focused states --> 
    <item android:state_focused="false" android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/tab_unselected_holo" /> 
    <item android:state_focused="false" android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/tab_selected_holo" /> 

    <!-- Focused states --> 
    <item android:state_focused="true" android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/tab_unselected_focused_holo" /> 
    <item android:state_focused="true" android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/tab_selected_focused_holo" /> 

    <!-- Pressed --> 
    <!-- Non focused states --> 
    <item android:state_focused="false" android:state_selected="false" android:state_pressed="true" android:drawable="@drawable/tab_unselected_pressed_holo" /> 
    <item android:state_focused="false" android:state_selected="true" android:state_pressed="true" android:drawable="@drawable/tab_selected_pressed_holo" /> 

    <!-- Focused states --> 
    <item android:state_focused="true" android:state_selected="false" android:state_pressed="true" android:drawable="@drawable/tab_unselected_pressed_holo" /> 
    <item android:state_focused="true" android:state_selected="true" android:state_pressed="true" android:drawable="@drawable/tab_selected_pressed_holo" /> 
</selector> 

但标签样式不应用于tabhost。默认的蓝色不会变为红色。

我得到这个

enter image description here

任何意见或建议,请。

+0

'安卓tabWidgetStyle'应指向延长'Widget.TabWidget'(这反过来会覆盖它的标签栏属性之一指向你有'tab_indicator_holo.xml'绘制风格)。 – Luksprog

回答

5

你可能已经找到了答案,但对于那些可能面临同样问题的人,这就是我所做的。

  1. 转到custom holo theme并将tabwedget设置为yes并选择首选颜色。

  2. 下载zip文件,复制到我的项目中。

  3. 添加到tabadapter与充气tab_indicator_holo创建的视图。

View mIndicator = inflater.inflate(R.layout.tab_indicator_holo, mTabHost.getTabWidget(), false); 
    TextView title1 = (TextView) mIndicator.findViewById(android.R.id.title); 

    title1.setText("TAB1"); 

    mTabsAdapter.addTab(mTabHost.newTabSpec("TAB1").setIndicator(mIndicator), FRAGMENT1.class, null); 

    View mIndicator2 = inflater.inflate(R.layout.tab_indicator_holo,  mTabHost.getTabWidget(), false); 
    TextView title2 = (TextView) mIndicator2.findViewById(android.R.id.title); 

    title2.setText("TAB2"); 
    mTabsAdapter.addTab(mTabHost.newTabSpec("TAB2").setIndicator(mIndicator2), FRAGMENT2.class, null);
+0

谢谢!这终究正是我所需要的。真棒! – Zach

+0

NyanLH,你能完成你的代码示例吗?哪个功能添加到? inflater,mTabsAdapter从哪里来? – Gavriel