`

修改TabHost默认样式

阅读更多

TabHost是Android提供的一个容器组件,利用它可以轻松地实现TAB界面,如下图所示:

但很多时候,默认的TAB样式并不符合软件的整体风格,这时候该怎么办呢?其实,我们可以编写XML对其样式进行修改。下面修改后的效果图:

1. TabHost布局文件 main.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
	<TabHost


	    android:id
="@+id/tabhost"
  

	    android:layout_width
="fill_parent"


	    android:layout_height
="fill_parent"
>

  
	    <LinearLayout
  

	        android:orientation
="vertical"


	        android:layout_width
="fill_parent"
  

	        android:layout_height
="fill_parent"
>

  
	        <TabWidget
  

	            android:id
="@android:id/tabs"


	            android:layout_width
="fill_parent"
 

	            android:layout_height
="30dip"


	            android:background
="#a0a0a0"


	            android:layout_weight
="0"
 />

  
	        <FrameLayout
  

	            android:id
="@android:id/tabcontent"
  

	            android:layout_width
="fill_parent"
  

	            android:layout_height
="fill_parent"


	            android:layout_weight
="1"
>


				  <ListView
 

				    android:id
="@+id/user_list"


				    android:layout_width
="fill_parent"


				    android:layout_height
="fill_parent"
 

				    android:divider
="@drawable/divider_line"


				    android:cacheColorHint
="#00000000"
 />


				  <ListView
 

				    android:id
="@+id/article_list"


				    android:layout_width
="fill_parent"


				    android:layout_height
="fill_parent"
 

				    android:divider
="@drawable/divider_line"


				    android:cacheColorHint
="#00000000"
 />

  
				  <ListView
 

				    android:id
="@+id/feed_list"


				    android:layout_width
="fill_parent"


				    android:layout_height
="fill_parent"
 

				    android:divider
="@drawable/divider_line"


				    android:cacheColorHint
="#00000000"
 />

  
				  <ListView
 

				    android:id
="@+id/book_list"


				    android:layout_width
="fill_parent"


				    android:layout_height
="fill_parent"
 

				    android:divider
="@drawable/divider_line"


				    android:cacheColorHint
="#00000000"
 />

  				    				    				      
	        </FrameLayout>


  
	    </LinearLayout>


  
	</TabHost>


FrameLayout里有四个ListView 分别对应用户、文章、频道、图书。
TabWidget和FrameLayout的ID不能自己定义修改。

2. Activity后台代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
RelativeLayout articleTab =
 (
RelativeLayout)
 LayoutInflater.from
(
this
)
.inflate
(
R.layout
.minitab
, null
)
;

TextView articleTabLabel =
 (
TextView)
 articleTab.findViewById
(
R.id
.tab_label
)
;

articleTabLabel.setText
(
"文章"
)
;

 
RelativeLayout feedTab =
 (
RelativeLayout)
 LayoutInflater.from
(
this
)
.inflate
(
R.layout
.minitab
, null
)
;

TextView feedTabLabel =
 (
TextView)
 feedTab.findViewById
(
R.id
.tab_label
)
;

feedTabLabel.setText
(
"频道"
)
;

 
RelativeLayout bookTab =
 (
RelativeLayout)
 LayoutInflater.from
(
this
)
.inflate
(
R.layout
.minitab
, null
)
;

TextView bookTabLabel =
 (
TextView)
 bookTab.findViewById
(
R.id
.tab_label
)
;

bookTabLabel.setText
(
"图书"
)
;

 
TabHost tabHost =
 (
TabHost)
 findViewById(
R.id
.tabhost
)
;

tabHost.setup
(
)
;

 
tabHost.addTab
(
tabHost.newTabSpec
(
"user"
)
.setIndicator
(
userTab)
.setContent
(
R.id
.user_list
)
)
;

tabHost.addTab
(
tabHost.newTabSpec
(
"article"
)
.setIndicator
(
articleTab)
.setContent
(
R.id
.article_list
)
)
;

tabHost.addTab
(
tabHost.newTabSpec
(
"feed"
)
.setIndicator
(
feedTab)
.setContent
(
R.id
.feed_list
)
)
;

tabHost.addTab
(
tabHost.newTabSpec
(
"book"
)
.setIndicator
(
bookTab)
.setContent
(
R.id
.book_list
)
)
;

TabHost创建出来以后,必须先setup一下,tabHost.setup();
setIndicator方法设置的View其实就对应了TAB中的一个个选项卡,它们都是通过一个叫minitab的布局文件inflate出来的。

3. 选项卡布局文件minitab.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?xml
 version
="1.0"
 encoding
="utf-8"
?>


<RelativeLayout
 xmlns:android
="http://schemas.android.com/apk/res/android"
  

    android:layout_width
="fill_parent"


    android:layout_height
="fill_parent"


    android:paddingLeft
="5dip"


    android:paddingRight
="5dip"
>

  
 
    <TextView
 android:id
="@+id/tab_label"
  

        android:layout_width
="fill_parent"


        android:layout_height
="fill_parent"


        android:gravity
="center"


        android:textColor
="#000000"


        android:textStyle
="bold"


        android:background
="@drawable/minitab"
 />

 
</RelativeLayout>


drawable/minitab是一个selector,指定了Tab选项卡的背景颜色。

4. selector文件 minitab.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?xml
 version
="1.0"
 encoding
="utf-8"
?>


<selector


	xmlns:android
="http://schemas.android.com/apk/res/android"


	>


	<item


		android:state_selected
="false"


		android:drawable
="@drawable/minitab_unselected"


		>


	</item>



	<item


		android:state_selected
="true"


		android:drawable
="@drawable/minitab_default"


		>


	</item>



</selector>


minitab_unselected是一浅蓝色背景图片
minitab_default是一白色背景图片

分享到:
评论

相关推荐

    自定义Android的TabHost控件样式

    默认的Tab样式可能不符合某些应用的设计需求,因此我们需要对其进行定制。 1. **自定义TabWidget样式** - 通过修改`res/layout/tab_indicator.xml`来改变每个Tab的外观。你可以设置背景色、文字颜色、字体大小、...

    TabHost自定义样式 自定义TabWidget

    默认情况下,TabHost的样式可能无法满足所有设计需求,因此我们需要进行自定义。 1. 自定义TabWidget样式: - 通过重写TabWidget的布局文件,可以改变选项卡的背景、文字颜色、字体大小等属性。例如,可以设置`...

    自己布局TabHost,样式多样化显示

    默认情况下,TabHost的布局方式较为单一,不支持复杂的样式定制。 要实现自定义TabHost,我们需要编写XML布局文件来控制TabHost的位置和样式。例如,可以将TabHost放置在屏幕底部,通过设置`android:layout_gravity...

    解决TabHost下面白线

    2. 自定义TabWidget:覆写TabWidget的默认样式,去除底部边框。在res/values/styles.xml中创建一个新的样式,然后在布局文件中引用这个样式。 ```xml &lt;item name="android:background"&gt;@drawable/tab_background ...

    Android studio TabHost布局

    - TabHost中的标签顺序由添加的顺序决定,第一个添加的标签会成为默认选中的标签。 - TabHost的布局高度通常设置为match_parent,以确保整个屏幕都被占据。 通过以上步骤,你就可以在Android Studio中实现一个基本...

    android TabHost自定义选项卡

    要自定义选项卡的外观,你可以覆盖TabWidget的默认样式。这可以通过设置自定义布局文件来实现,或者在代码中修改TabSpec的指示器。 ```xml &lt;!-- custom_tab.xml --&gt; android:layout_width="wrap_content" ...

    Android TabHost 标签在屏幕左侧样例

    // 修改TabHost的布局 tabHost.getTabWidget().setOrientation横向); // 将TabWidget设置为横向排列 ViewGroup.LayoutParams layoutParams = tabHost.getLayoutParams(); layoutParams.gravity = Gravity.LEFT | ...

    自定义TabHost经典案例

    然而,系统默认的TabHost功能有限,样式和交互方式较为固定,因此开发者通常需要对其进行自定义以满足更加个性化的应用需求。本经典案例将深入探讨如何自定义TabHost,打破传统限制,实现更加灵活多变的选项卡界面。...

    自定义TabHost例子,类似于微博下面的Tab选项卡

    1. **自定义Tab布局**:默认的TabWidget样式可能过于简单,我们可以通过创建自定义的Tab布局文件,比如包含ImageView和TextView,来实现更丰富的视觉效果。在布局文件中,可以设置文字颜色、字体大小、图标等属性。 ...

    TabHost美化

    2. **设置字体和颜色**:通过修改标签中的文字样式,可以改变字体大小、颜色以及字体类型。可以使用`SpannableString`和`Typeface`实现这一效果。 3. **添加图标**:图标可以增强用户的视觉感知,使界面更加直观。...

    android使用了自定义button自定义tabHost切换页面Demo

    在“自定义tabhost使用了不同默认的上标签切换页面”这一描述中,我们可以理解为每个Tab可能展示不同的内容,而这些内容可能是通过不同的Activity或Fragment来实现的。当用户点击不同的Tab时,TabHost会根据预设的...

    FragmentTabHost的使用,包括添加缓存View,选项卡,Tabhost

    默认情况下,FragmentTabHost会为每个Fragment创建新的实例,但如果我们希望复用已存在的Fragment,可以通过设置Tag和FragmentTransaction的`setReorderingAllowed(true)`来实现。 ```java ...

    TabHost小Demo

    4. **设置默认选中标签**:通过`tabHost.setCurrentTab(index)`指定默认显示的标签页。 ### TabHost与ActivityGroup 在早期的Android版本中,`ActivityGroup`常用于在TabHost内管理子Activity。然而,随着Android...

    TabHostDemo.

    默认情况下,`TabHost` 的标签样式可能不符合设计需求。可以通过修改主题或自定义布局来改变标签的外观。在 `AndroidManifest.xml` 中为应用或单个活动指定主题,或者在 `TabSpec` 中设置自定义布局。 5. **处理...

    Android高级应用源码-封装的一个tabhost框架.rar

    - 源码中可能包含了对TabHost的样式和动画的自定义,这涉及到对XML布局文件的修改,以及可能的Java代码实现,例如改变选项卡的颜色、字体、过渡效果等。 8. **实践与应用**: - 通过学习这个源码,开发者可以将...

    android 学习 TabHost

    默认的Tab样式可能不能满足所有需求,可以自定义Tab的外观。例如,可以修改文字颜色、大小、图标,甚至创建自定义视图来替换TabWidget。 ### 4. 动态添加Tab 如果Tab的数量在运行时才能确定,可以通过动态添加Tab...

    tabhost工具类

    默认的Tab样式可能不能满足所有需求,你可以通过设置TabWidget的属性或者自定义布局来改变Tab的样式。例如,你可以修改Tab的背景色、文字颜色等: ```xml android:id="@android:id/tabs" android:layout_width...

    自定义标签在底部TabHost可直接使用

    要创建一个底部的`TabHost`,我们需要对默认的`TabHost`进行一些调整。通常,`TabHost`会在顶部显示选项卡,但我们可以通过修改布局文件来改变这一位置。在XML布局文件中,我们可以将`TabWidget`放置在底部,例如: ...

    tabhost下方显示

    然而,TabHost的默认设置通常是将其置于屏幕顶部,但根据特定的设计需求,有时我们需要将它调整到屏幕下方。本篇文章将详细介绍如何重写TabHost,使其在屏幕下方显示,并实现一些新的视觉效果。 首先,我们来理解...

    TabHost和ViewPager

    4. **界面设计**:`TabHost`和`ViewPager`的样式可以自定义,以适应应用的整体风格。可以通过修改主题、颜色、字体等元素,使界面更加美观且符合用户体验。 总之,`TabHost`和`ViewPager`的结合使用能够帮助开发者...

Global site tag (gtag.js) - Google Analytics