许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  修改TabHost默认样式:Android开发自定义TabHost

修改TabHost默认样式:Android开发自定义TabHost

阅读数 7
点赞 0
article_banner

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是一白色背景图片


免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删



相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空