android应用开发详解(八)---------------常用组件之选项卡Tab的三种用法(续)

锋菲复婚#多年后,你若“未娶”,我若“未嫁”,我们还能不能在一起?

使用选项卡的步骤:

(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

时间: 2024-08-03 17:09:51

android应用开发详解(八)---------------常用组件之选项卡Tab的三种用法(续)的相关文章

【转】【Android应用开发详解】第01期:第三方授权认证(一)实现第三方授权登录、分享以及获取用户资料

转载请注明出处:http://blog.csdn.net/yangyu20121224/article/details/9057257 由于公司项目的需要,要实现在项目中使用第三方授权登录以及分享文字和图片等这样的效果,几经波折,查阅了一番资料,做了一个Demo.实现起来的效果还是不错的,不敢独享,决定写一个总结的教程,供大家互相交流.学习和参考,博主只求能和大家共同进步.希望能多多支持! 这篇文章中,我们使用到了Share SDK,它是为iOS.Android.WP8的APP提供社会化功能的一

Android相机开发详解(一)

Android相机开发详解(一) 请支持原创,尊重原创,转载请注明出处:http://blog.csdn.net/kangweijian(来自kangweijian的csdn博客) Android相机开发能够实现打开相机,前后摄像头切换,摄像预览,保存图片,浏览已拍照图片等相机功能. Android相机开发详解(一)主要实现打开相机,摄像预览,前后置摄像头切换,保存图片等四个功能. Android相机开发详解(二)主要实现翻页浏览相片,触控缩放浏览图片,删除图片,发送图片等四个功能. Andro

Android开发经典书籍下载——《Android 4高级编程》《疯狂Android讲义》《Android应用开发详解(郭宏志)》《Android应用案例开发大全》《Android 3D游戏开发技术》

这是我收集的关于android开发方面的经典书籍,高清PDF电子版,可以在我的百度网盘免费下载,希望对需要的朋友有帮助. 目录: <Android 4高级编程>(附完整源代码) <疯狂Android讲义> <Android应用开发详解(郭宏志)> <Android应用案例开发大全> <Android 3D游戏开发技术> <Android内核剖析 柯元旦> <深入理解Android  卷1> <深入理解Android

Android WebView 开发详解

Android WebView 开发详解 1.概览: Android WebView 做为承载网页的载体控件,他在网页显示的过程中会产生一些事件,并回调给我们的应用程序,以便我们在网页加载过程中做应用程序想处理的事情.比如说客户端需要显示网页加载的进度.网页加载发生错误等等事件. WebView提供两个事件回调类给应用层,分别为WebViewClient,WebChromeClient开发者可以继承这两个类,接手相应事件处理.WebViewClient 主要提供网页加载各个阶段的通知,比如网页开

Android Widget 开发详解(二)

转载请标明出处:http://blog.csdn.net/sk719887916/article/details/47027263 不少开发项目中都会有widget功能,别小瞧了它,他也是android的七大组件之一,对widget陌生的朋友可以阅读下我的上篇文章< Android Widget工作原理详解(一)> 今天我们就实现一个可以滑动的widet,熟悉下一个普通widget的开发. 一 创建AppWidgetProvider 此类是widget的控制核心,主要控制添加,删除,更新等.他

Android WebView 开发详解(一)

转载请注明出处  http://blog.csdn.net/typename/article/details/39030091 powered by meichal zhao 概览: Android WebView在Android平台上是一个特殊的View, 他能用来显示网页,这个类可以被用来在你的app中仅仅显示一张在线的网页,还可以用来开发浏览器.WebView内部实现是采用渲染引擎来展示view的内容,提供网页前进后退,网页放大,缩小,搜索,前端开发者可以使用web inspector(A

Android WebView 开发详解(二)

转载请注明出处  http://blog.csdn.net/typename/article/details/39495409 powered by meichal zhao 概览: Android WebView 做为承载网页的载体控件,他在网页显示的过程中会产生一些事件,并回调给我们的应用程序,以便我们在网页加载过程中做应用程序想处理的事情.比如说客户端需要显示网页加载的进度.网页加载发生错误等等事件. WebView提供两个事件回调类给应用层,分别为WebViewClient,WebChr

Android WebView 开发详解(三)

转载请注明出处   http://blog.csdn.net/typename/article/details/40302351 powered by miechal zhao 概览 Android WebView提供展示网页,也提供我们应用程序对网页加载的一些定制,比如我们为了减少网络数据可以设置当前加载的页面不能显示图片,如果是pc网址在pad上访问我们可以提供用户一种概览模式的浏览方式,可以提供放大网页字体等定制功能.Android 提供管理WebView的一些setting的类WebSe

android应用开发详解(八)----------------常用组件之进度条(续)

撑不住的时候,可以对自己说声"我好累",但不要对自己说"我不行". 进度条有很多种:对话框进度条.标题栏进度条.水平进度条 一.对话框进度条 (1)覆盖Activity的onCreateDialog()方法,并在其中创建对话框 (2)调用Activity的showDialog()方法,显示进度条对话框 二.标题栏进度条 (1)调用Activity的requestWindowFeature()方法,获得进度条 (2)调用Activity的setProgressBarI