锋菲复婚#多年后,你若“未娶”,我若“未嫁”,我们还能不能在一起?
使用选项卡的步骤:
(1)在布局文件中使用FrameLayout列出Tab组件及Tab中的内容组件
(2)Activity要继承TabActivity
(3)调用TabActivity的getTabHost()方法
(4)通过TabHost创建Tab选项
一、简单的Tab
1、工程目录
2、Test_Tab_activity.java
package com.example.test_tab;
import android.app.TabActivity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.TabHost;
import android.widget.TabHost.OnTabChangeListener;
import android.widget.TextView;
import android.widget.Toast;
public class Test_Tab_Activity extends TabActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 不应该添加setContentView()
// 获得TabHost,newTabSpec()创建一个新的Tab
final TabHost tab = getTabHost();
LayoutInflater.from(this).inflate(R.layout.test__tab,
tab.getTabContentView(), true);
tab.addTab(tab.newTabSpec("all").setIndicator("所有通话记录")
.setContent(R.id.textview01));
tab.addTab(tab.newTabSpec("ok").setIndicator("已接来电")
.setContent(R.id.textview02));
tab.addTab(tab.newTabSpec("cancel").setIndicator("未接来电")
.setContent(R.id.textview03));
//只有Tab选项卡内容更改时才会触发该事件
tab.setOnTabChangedListener(new OnTabChangeListener() {
@Override
public void onTabChanged(String arg0) {
// TODO Auto-generated method stub
System.out.println("当前选择:" + tab.getCurrentTabTag());
}
});
}
}
3、布局文件
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/frameLayout01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TabHost
android:id="@+id/tabhost01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
</TabHost>
<TextView
android:id="@+id/textview01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="所有通话记录ok" />
<TextView
android:id="@+id/textview02"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="已接来电ok" />
<TextView
android:id="@+id/textview03"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="未接来电ok" />
</FrameLayout>
【知识点】setOnTabChangedListener()方法
4、结果演示
二、通过实现接口TabHost.TabContentFactory的createTabContent()方法来实现
1、工程目录
2、Test_Tab_Activity.java
package com.example.test_tab2;
import java.util.ArrayList;
import java.util.List;
import android.app.TabActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TabHost;
import android.widget.TabHost.TabContentFactory;
public class Test_Tab_Activity extends TabActivity implements TabContentFactory {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
TabHost tab2 = getTabHost();
tab2.addTab(tab2.newTabSpec("all").setIndicator("所有通话记录")
.setContent(this));
tab2.addTab(tab2.newTabSpec("ok").setIndicator("已接来电").setContent(this));
tab2.addTab(tab2.newTabSpec("cancel").setIndicator("未接来电")
.setContent(this));
}
public View createTabContent(String tag) {
ListView lv = new ListView(this);
List<String> list = new ArrayList<String>();
// list.add(tag);
if (tag.equals("all")) {
list.add("tom");
list.add("kite");
list.add("rose");
} else if (tag.equals("ok")) {
list.add("tom");
list.add("kite");
} else {
list.add("rose");
}
ArrayAdapter adapter = new ArrayAdapter(this,
android.R.layout.simple_list_item_checked, list);
lv.setAdapter(adapter);
return lv;
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.test__tab_, menu);
return true;
}
}
3、布局文件test_tab.xml
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/frameLayout01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TabHost
android:id="@+id/tabhost01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
</TabHost>
</FrameLayout>
4、结果演示
三、通过setContent(Intent i)来传递intent对象,用来添加内容
1、工程目录
2、Test_Tab_Activity.java,还用到了Activity1.java、Activity2.java、Activity3.java
package com.example.test_tab3;
import android.os.Bundle;
import android.app.Activity;
import android.app.TabActivity;
import android.content.Intent;
import android.view.Menu;
import android.widget.TabHost;
public class Test_Tab_Activity extends TabActivity {
private Intent intent1,intent2,intent3;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
intent1 = new Intent(getApplicationContext(),Activity1.class);
intent2 = new Intent(getApplicationContext(),Activity2.class);
intent3 = new Intent(getApplicationContext(),Activity3.class);
TabHost tab3 = getTabHost();
tab3.addTab(tab3.newTabSpec("all").setIndicator("所有通话记录")
.setContent(intent1));
tab3.addTab(tab3.newTabSpec("ok").setIndicator("已接来电").setContent(intent2));
tab3.addTab(tab3.newTabSpec("cancel").setIndicator("未接来电")
.setContent(intent3));
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.test__tab_, menu);
return true;
}
}
package com.example.test_tab3;
import android.app.Activity;
import android.os.Bundle;
public class Activity1 extends Activity{
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.activity1);
}
}
3、布局文件test_tab.xml,还有对应的布局文件activity1.xml、activity2.xml、activity3.xml
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/frameLayout01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TabHost
android:id="@+id/tabhost01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
</TabHost>
</FrameLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/textview01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="所有通话记录" />
</LinearLayout>
4、结果演示
【注意】不要忘了在AndroidMenifest.xml中注册Activity1、2、3