Android中的一个tabber中有四个类?

时间:2011-07-01 11:27:34

标签: android tabactivity

我想像UITabBarController在iPhone中那样做, 我有四个课程,我想在一个标签中使用它们

当我点击第一个标签时,第一个课应该显示 当我点击第二个标签时,第二个课程应该显示 当我点击第三个标签时,第三个类应该显示 当我单击第四个选项卡时,第四个类应显示

在这种情况下操作的最佳和简单方法是什么, 我是Android开发的新手,这是我的第一个应用程序 如果您对问题不清楚,可以再问一次......

2 个答案:

答案 0 :(得分:0)

android dev网站有一个你正在寻找的例子。 http://developer.android.com/resources/tutorials/views/hello-tabwidget.html

有代码示例。你需要制作一个标签布局xml文件,编辑main.xml然后在java代码中,对于每个标签你都会有这样的东西

intent = new Intent().setClass(this, AlbumsActivity.class);
spec = tabHost.newTabSpec("albums").setIndicator("Albums",
       res.getDrawable(R.drawable.ic_tab_albums))
      .setContent(intent);
tabHost.addTab(spec);

答案 1 :(得分:0)

这是在android

中实现标签栏的Java代码
           tabHost = getTabHost(); // The activity TabHost
    tabHost.setOnTabChangedListener(this);
    Resources res = getResources(); // Resource object to get Drawables
    tabHost = getTabHost(); // The activity TabHost
    TabHost.TabSpec spec; // Reusable TabSpec for each tab

    TabSpec firstTabSpec = tabHost.newTabSpec("tid1");
    TabSpec secondTabSpec = tabHost.newTabSpec("tid2");
    TabSpec thirdTabSpec = tabHost.newTabSpec("tid3");
    TabSpec fourthTabSpec = tabHost.newTabSpec("tid4");
    TabSpec fifthTabSpec = tabHost.newTabSpec("tid5");

    viewCache[0] = LayoutInflater.from(this).inflate(R.layout.tabs1, null);
    viewCache[1] = LayoutInflater.from(this).inflate(R.layout.tabs1, null);
    viewCache[2] = LayoutInflater.from(this).inflate(R.layout.tabs1, null);
    viewCache[3] = LayoutInflater.from(this).inflate(R.layout.tabs1, null);
    viewCache[4] = LayoutInflater.from(this).inflate(R.layout.tabs1, null);

    firstTabSpec.setIndicator(viewCache[0]);
    secondTabSpec.setIndicator(viewCache[1]);
    thirdTabSpec.setIndicator(viewCache[2]);
    fourthTabSpec.setIndicator(viewCache[3]);
    fifthTabSpec.setIndicator(viewCache[4]);

    firstTabSpec.setContent(new Intent(this, HomeTabActivityGroup.class));
    secondTabSpec
            .setContent(new Intent(this,   ProfileTabActivityGroup.class));
    thirdTabSpec.setContent(new Intent(this,
            NotificationTabActivityGroup.class));
    fourthTabSpec.setContent(new Intent(this,
            FavoritesTabActivityGroup.class));
    fifthTabSpec
            .setContent(new Intent(this, MoreTabActivityGroupNew.class));

    tabHost.addTab(firstTabSpec);
    tabHost.addTab(secondTabSpec);
    tabHost.addTab(thirdTabSpec);
    tabHost.addTab(fourthTabSpec);
    tabHost.addTab(fifthTabSpec);

// <强> * ** * ** * ** * ** * ** * ** * ** * ** * ** * ** * ** * ** * ** * *           这是Tab栏的xml coed

 <?xml version="1.0" encoding="utf-8"?>
  <TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<RelativeLayout
    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_alignParentBottom="true" 
        android:layout_height="wrap_content" 
        tabStripEnabled = "false"/>
    <FrameLayout
        android:id="@android:id/tabcontent"
        android:layout_alignParentTop="true"
        android:layout_above="@android:id/tabs"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        />
</RelativeLayout>

// <强> * ** * ** * ** * ** * < / EM> ** * ** * ** * ** * ** * < / EM> ** * ** * ** * ** * * 这是用于制表符布局的Tab1.xml的xml coed

   <?xml version="1.0" encoding="utf-8"?>
 <LinearLayout android:id="@+id/LinearLayout01" 
android:layout_width="wrap_content" android:layout_height="wrap_content"
xmlns:android="http://schemas.android.com/apk/res/android" android:gravity="center">
  <ImageView android:id="@+id/ImageView01" android:layout_width="wrap_content"
        android:layout_height="50dip"></ImageView>
    </LinearLayout>