tabhost的美化

其实也很简单。只要学的进去明白了一点就可以明白很多。

安卓默认的TabHost样式是比较朴素的,可以对它进行样式美化。对布局进行美化的时候需要在布局文件中体现出来。TabHost标签应由一个TabWidget和一个FrameLayout组成。其中TabWidget定义了标签的属性,而frameLayout定义了标签的内容。

一、最普通tabHost
我们将 activity_main.xml修改为:
<?xml version="1.0"encoding="utf-8"?>
<TabHostxmlns:android="http://schemas.android.com/apk/res/android"
 android:id="@android:id/tabhost" 
  android:orientation="vertical"
   android:layout_width="fill_parent"
   android:layout_height="fill_parent">
   <TabWidgetandroid:id="@android:id/tabs"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content">
</TabWidget>
<FrameLayoutandroid:id="@android:id/tabcontent"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent">
</FrameLayout>
</TabHost>
注意点:1.各个标签的id基本是必须要交这个名字的;
MainActivity.java中代码如下:
public class MainActivity extends TabActivity {
TabHost tabHost;
    @Override
    public voidonCreate(Bundle savedInstanceState) {
       super.onCreate(savedInstanceState);
       setContentView(R.layout.activity_main);
       //获取TabHost对象
       tabHost = getTabHost();  
//新建一个newTabSpec,设置标签和图标(setIndicator),设置内容(setContent)
tabHost.addTab(tabHost.newTabSpec("Main_page")
.setIndicator("",getResources()
.getDrawable(android.R.drawable.ic_menu_call))
.setContent(new Intent(this,Main.class)));
tabHost.addTab(tabHost.newTabSpec("Search")
.setIndicator("",getResources()
.getDrawable(android.R.drawable.ic_menu_camera))
.setContent(new Intent(this,Main.class)));
......
//设置当前现实哪一个标签
tabHost.setCurrentTab(0);  //0为标签ID
    }
}
注意点:1.TabHost定义需要全局,方便在其他acitivity中调用;
2.tabHost = getTabHost()方法可以获取一个tabhost对象;
3.tabHost.addTab添加一个标签,注意后面的一堆set和get...然后其中的Main.class是自己新建的一个acitivity,这样四个标签页可以跳转到四个acitivity(在这个demo中是跳转到同一个activity)。

2.下至在底部

下置在底下版(如大家普遍使用的app,微信、微博等)
将TabHost下置在屏幕下方只需要在xml布局文件中添加一句话:
android:layout_alignParentBottom="true"
这是TabWidget的属性。
但是为了使这个alignParentBottom生效,必须将整个tabs封装在一个RelativeLayout中。
所以xml文件变为:
<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@android:id/tabhost" 
  android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height="fill_parent">
    <TabWidget android:id="@android:id/tabs"
   android:layout_width="fill_parent"
   android:layout_height="wrap_content"
   android:layout_alignParentBottom="true">
</TabWidget>
<FrameLayout android:id="@android:id/tabcontent"
   android:layout_width="fill_parent"
   android:layout_height="fill_parent">
</FrameLayout>
</RelativeLayout>
</TabHost>
.java文件是不变的。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值