> 本讲内容:标签页的实现 TabHost TabWidget TabActivity 使用Tab标签页控件,可以在同一个空间里放置更多内容。譬如Android自带的拨号程序及通讯录等,就使用了Tab标签功能:
下面我们用实例的方式来学习如何制作上面类似的标签效果,其实还是很简单的。我同样是把解释写到示例的注释里了,注释是我的理解并不准确,方便你记忆而已。 1、新建一个项目 Lesson44_Tab ,Activity起名叫 MainActivity 2、编写 main.xml 内容如下,这次的形式和普通布局文件有所区别,请注意看写法: - <?xml version="1.0" encoding="utf-8"?>
<!-- 根元素是 TabHost ,我们这个文件要和TabActivity配合使用,在TabActivity的源代码里写死了要找的Id是android.R.id.tabhost,
因此这里的ID也要定死成TabHost 的ID 是定死的 "@android:id/tabhost" 下面的类似,不再解释。 -->
<tabhost android:layout_height="fill_parent" android:layout_width="fill_parent" xmlns:android="http://schemas.android.com/apk/res/android" android:id="@android:id/tabhost">
<!-- TabWidget 就是标签选项卡的头部部分,注意ID的写法 -->
<tabwidget android:layout_height="wrap_content" android:layout_width="fill_parent" android:id="@android:id/tabs">
</tabwidget>
<!-- FrameLayout 就是标签的内容显示部分,注意ID的写法,还要注意我们做了个上部空白设定 android:paddingTop="65dp",是为了不让内容和标签重叠 -->
<framelayout android:layout_height="fill_parent" android:layout_width="fill_parent" android:id="@android:id/tabcontent" android:paddingtop="65dp">
<!-- LinearLayout 是一个标签里的内容,程序根据你定义的ID来把他们放在不同的标签下面 -->
<linearlayout android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/linearLayout1">
<textview android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/textView1" android:text="标签1中的内容">
</textview>
</linearlayout>
<!-- LinearLayout 是另一个标签里的内容-->
<linearlayout android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/linearLayout2">
<textview android:layout_height="wrap_content" android:layout_width="wrap_content" android:id="@+id/textView2" android:text="标签2中的内容">
</textview>
</linearlayout>
</framelayout>
</tabhost>
复制代码 3、编写 MainActivity,请注意它继承的是 TabActivity 类,解释在代码里: - package basic.android.lesson44;
import android.app.TabActivity;
import android.os.Bundle;
import android.widget.TabHost;
public class MainActivity extends TabActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
// tabHost是一个标签容器
TabHost tabHost = this.getTabHost();
// 每一个TabSpec对象就是个标签
// TabSpec.setIndicator()方法是设置标签显示样式
// TabSpec.setContent()方法显示标签下方的内容显示
//定义第一个标签
tabHost.addTab(tabHost.newTabSpec("OneTab")
.setIndicator("OneTab", getResources().getDrawable(android.R.drawable.star_on))
.setContent(R.id.linearLayout1));
//定义第二个标签
tabHost.addTab(tabHost.newTabSpec("TwoTab")
.setIndicator("TwoTab", getResources().getDrawable(android.R.drawable.star_off))
.setContent(R.id.linearLayout2));
}
}
复制代码 4、编译程序,运行代码,查看结果:
点击 TwoTab ,标签切换:
关于注释你最好先看一遍,等代码跑起来后再看一遍。好了,本讲就到这里。
</div |