Android中选项卡功能的实现

时间:2023-03-08 17:19:40

Android中选项卡功能的实现

Android中使用TabHostTabWidget来实现选项卡功能。TabHost必须是布局的根节点,它包含两个子节点:

TabWidget,显示选项卡;

FrameLayout,显示标签内容。

实现选项卡功能有两种方法,一种是将多个View放在同一个Activity中,然后使用使用标签来进行切换。另一种是直接使用标签切换不同的Activity。

后一种方法更为常用一些。本文也只介绍了后一种方法的实现过程。

1. 创建一个工程,名字可以叫HelloTabWidget。

2. 创建多个不同的Activity,用来表示各个标签页中的不同内容。

3. 为标签设计不同的icon。每个标签应该有两个icon,一个表示选中,一个未选中。将图片放在 res/drawable/文件夹下。然后创建一个相应的

StateListDrawable,用来实现在选中和未选中直接自动的切换。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <!-- When selected, use grey -->
  4. <item android:drawable="@drawable/ic_tab_artists_grey"
  5. android:state_selected="true" />
  6. <!-- When not selected, use white-->
  7. <item android:drawable="@drawable/ic_tab_artists_white" />
  8. </selector>

4. 将main.xml替换为以下内容。

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <TabHost xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:id="@android:id/tabhost"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent">
  6. <LinearLayout
  7. android:orientation="vertical"
  8. android:layout_width="fill_parent"
  9. android:layout_height="fill_parent"
  10. android:padding="5dp">
  11. <TabWidget
  12. android:id="@android:id/tabs"
  13. android:layout_width="fill_parent"
  14. android:layout_height="wrap_content" />
  15. <FrameLayout
  16. android:id="@android:id/tabcontent"
  17. android:layout_width="fill_parent"
  18. android:layout_height="fill_parent"
  19. android:padding="5dp" />
  20. </LinearLayout>
  21. </TabHost>

5. 让你的主Activity继承自TabActivity

6. 在主Activity的onCreate方法中加入标签

  1. public void onCreate(Bundle savedInstanceState) {
  2. super.onCreate(savedInstanceState);
  3. setContentView(R.layout.main);
  4. Resources res = getResources(); // Resource object to get Drawables
  5. TabHost tabHost = getTabHost();  // The activity TabHost
  6. TabHost.TabSpec spec;  // Resusable TabSpec for each tab
  7. Intent intent;  // Reusable Intent for each tab
  8. // Create an Intent to launch an Activity for the tab (to be reused)
  9. intent = new Intent().setClass(this, ArtistsActivity.class);
  10. // Initialize a TabSpec for each tab and add it to the TabHost
  11. spec = tabHost.newTabSpec("artists").setIndicator("Artists",
  12. res.getDrawable(R.drawable.ic_tab_artists))
  13. .setContent(intent);
  14. tabHost.addTab(spec);
  15. // Do the same for the other tabs
  16. intent = new Intent().setClass(this, AlbumsActivity.class);
  17. spec = tabHost.newTabSpec("albums").setIndicator("Albums",
  18. res.getDrawable(R.drawable.ic_tab_albums))
  19. .setContent(intent);
  20. tabHost.addTab(spec);
  21. intent = new Intent().setClass(this, SongsActivity.class);
  22. spec = tabHost.newTabSpec("songs").setIndicator("Songs",
  23. res.getDrawable(R.drawable.ic_tab_songs))
  24. .setContent(intent);
  25. tabHost.addTab(spec);
  26. tabHost.setCurrentTab(2);
  27. }

7. 运行程序即可看到效果。

总结:

main.xml中定义的选项卡的样式,它和TabActivity共同配合,创建了选项卡的框架。TabHost.TabSpec 代表了一个选项卡的内容,TabHost使用addTab方法将其加入到整个选项卡中。

TabHost.TabSpec

原文: http://blog.****.net/cool_android/article/details/7202381