`
yezhiqiu-love
  • 浏览: 168680 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

修改TabHost默认样式

阅读更多

 

 

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

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

1. TabHost布局文件 main.xml

	<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后台代码

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

<?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

<?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