Android开发学习笔记:浅谈Tab选项卡

简介:

Tab选项卡是一个非常方便的组件。

一.使用Tab组件的步骤:

1.在布局文件中使用FrameLayout列出Tab组件以及Tab中的内容组件

2.Activity要继承TabActivity

3.调用TabActivity的getTabHost( )方法来获得TabHost对象

4.通过TabHost创建Tab选项

二.实现不同Tab里面的内容有两种方式:

1.切换不同的Tab时候,不同Tab里面的内容在同一个Activity显示,主要是通过修改布局文件里面的id来实现的。下面是一个具体的例子:

MainActivity.java

 
  1. package com.android.tab.activity;  
  2.  
  3. import android.app.TabActivity;  
  4. import android.os.Bundle;  
  5. import android.view.LayoutInflater;  
  6. import android.widget.TabHost;  
  7.  
  8. public class MainActivity extends TabActivity {  
  9.     @Override 
  10.     public void onCreate(Bundle savedInstanceState) {  
  11.         super.onCreate(savedInstanceState);  
  12.          //获得TabHost对象       
  13.         TabHost tah = getTabHost();  
  14.           
  15.         // from(this)从TabActivity获取LayoutInflater  
  16.         // R.layout.main 存放Tab布局  
  17.         // 通过TabHost获得存放Tab标签页内容的FrameLayout  
  18.         // 是否将inflate 加到根布局元素上  
  19.         LayoutInflater.from(this).inflate(R.layout.main, tah.getTabContentView(), true);  
  20.           
  21.         //设置Tab标签的内容和显示内容  
  22.         tah.addTab(tah.newTabSpec("tab1").setIndicator("图片1").setContent(R.id.TextView01));  
  23.         tah.addTab(tah.newTabSpec("tab2").setIndicator("图片2").setContent(R.id.TextView02));  
  24.         tah.addTab(tah.newTabSpec("tab3").setIndicator("图片3").setContent(R.id.TextView03));                        
  25.     }  

main.xml

 
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:id="@+id/FrameLayout01"   
  4.     android:layout_width="wrap_content"   
  5.     android:layout_height="wrap_content" 
  6.     >     
  7.     <TabHost   
  8.         android:id="@+id/TabHost01" 
  9.         android:layout_width="wrap_content"   
  10.         android:layout_height="wrap_content"   
  11.         /> 
  12.     <TextView   
  13.         android:id="@+id/TextView01"   
  14.         android:background="@drawable/pic1" 
  15.         android:layout_width="wrap_content"   
  16.         android:layout_height="wrap_content"   
  17.         />    
  18.     <TextView   
  19.         android:id="@+id/TextView02"   
  20.         android:background="@drawable/pic2" 
  21.         android:layout_width="wrap_content"   
  22.         android:layout_height="wrap_content"   
  23.         />    
  24.     <TextView   
  25.         android:id="@+id/TextView03"   
  26.         android:background="@drawable/pic3" 
  27.         android:layout_width="wrap_content"   
  28.         android:layout_height="wrap_content"   
  29.         />    
  30. </FrameLayout> 
  31.  
  32.  

效果图:

 1.切换不同的Tab时候,不同Tab里面的内容在不同的Activity显示

 先创建三个类FirstActivity.java,SecondActivity.java,ThirdActivity.java,都是继承Activity

FirstActivity.java

 
  1. package com.android.tabtest.activity;  
  2.  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.widget.TextView;  
  6.  
  7. public class FirstActivity extends Activity {  
  8.     public void onCreate(Bundle savedInstanceState) {  
  9.        super.onCreate(savedInstanceState);  
  10.        TextView textview = new TextView(this);  
  11.        textview.setText("这是Tab1");  
  12.        setContentView(textview);  
  13.     }  
  14. }  

SecondActivity.java

 
  1. package com.android.tabtest.activity;  
  2.  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.widget.TextView;  
  6.  
  7. public class SecondActivity extends Activity {  
  8.     public void onCreate(Bundle savedInstanceState) {  
  9.         super.onCreate(savedInstanceState);  
  10.         TextView textview = new TextView(this);  
  11.         textview.setText("这是Tab2");  
  12.         setContentView(textview);  
  13.     }  
  14.  
  15. }  

ThirdActivity.java

 
  1. package com.android.tabtest.activity;  
  2.  
  3. import android.app.Activity;  
  4. import android.os.Bundle;  
  5. import android.widget.TextView;  
  6.  
  7. public class ThirdActivity extends Activity {  
  8.     public void onCreate(Bundle savedInstanceState) {  
  9.            super.onCreate(savedInstanceState);  
  10.            TextView textview = new TextView(this);  
  11.            textview.setText("这是Tab3");  
  12.            setContentView(textview);  
  13.         }  
  14.  
  15. }  

在layout文件夹中对main.xml进行修改

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

新建一个测试Tab的类TabDemo.java,继承于TabActivity类

 
  1. package com.android.tabtest.activity;  
  2.  
  3. import android.app.TabActivity;  
  4. import android.content.Intent;  
  5. import android.content.res.Resources;  
  6. import android.os.Bundle;  
  7. import android.widget.TabHost;  
  8. import android.widget.TabHost.TabSpec;  
  9.    
  10. public class TabDemo extends TabActivity {  
  11.     /** Called when the activity is first created. */ 
  12.     @Override 
  13.     public void onCreate(Bundle savedInstanceState) {  
  14.         super.onCreate(savedInstanceState);  
  15.         setContentView(R.layout.main);//这里使用了上面创建的xml文件(Tab页面的布局)  
  16.         Resources res = getResources(); // Resource object to get Drawables  
  17.         TabHost tabHost = getTabHost();  // The activity TabHost  
  18.         TabSpec spec;  
  19.         Intent intent;  // Reusable Intent for each tab  
  20.    
  21.       //第一个Tab  
  22.         intent = new Intent(this,FirstActivity.class);//新建一个Intent用作Tab1显示的内容  
  23.         spec = tabHost.newTabSpec("tab1")//新建一个 Tab  
  24.         .setIndicator("Tab1", res.getDrawable(android.R.drawable.ic_media_play))//设置名称以及图标  
  25.         .setContent(intent);//设置显示的intent,这里的参数也可以是R.id.xxx  
  26.         tabHost.addTab(spec);//添加进tabHost  
  27.    
  28.         //第二个Tab  
  29.         intent = new Intent(this,SecondActivity.class);//第二个Intent用作Tab1显示的内容  
  30.         spec = tabHost.newTabSpec("tab2")//新建一个 Tab  
  31.         .setIndicator("Tab2", res.getDrawable(android.R.drawable.ic_menu_edit))//设置名称以及图标  
  32.         .setContent(intent);//设置显示的intent,这里的参数也可以是R.id.xxx  
  33.         tabHost.addTab(spec);//添加进tabHost  
  34.           
  35.        //第三个Tab  
  36.         intent = new Intent(this,SecondActivity.class);//第二个Intent用作Tab1显示的内容  
  37.         spec = tabHost.newTabSpec("tab2")//新建一个 Tab  
  38.         .setIndicator("Tab3", res.getDrawable(android.R.drawable.ic_menu_help))//设置名称以及图标  
  39.         .setContent(intent);//设置显示的intent,这里的参数也可以是R.id.xxx  
  40.         tabHost.addTab(spec);//添加进tabHost  
  41.    
  42.         tabHost.setCurrentTab(0);//设置当前的选项卡,这里为Tab1  
  43.     }   

在AndroidManifest.xml里加入9~29行的声明代码

 
  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  3.       package="com.android.tabtest.activity" 
  4.       android:versionCode="1" 
  5.       android:versionName="1.0"> 
  6.     <uses-sdk android:minSdkVersion="10" /> 
  7.  
  8.     <application android:icon="@drawable/icon" android:label="@string/app_name"> 
  9.     <activity android:name=".TabDemo" 
  10.                   android:label="@string/app_name"> 
  11.             <intent-filter> 
  12.                 <action android:name="android.intent.action.MAIN" /> 
  13.                 <category android:name="android.intent.category.LAUNCHER" /> 
  14.             </intent-filter> 
  15.     </activity> 
  16.     <activity android:name=".FirstActivity" 
  17.                   android:label="@string/app_name"> 
  18.             <intent-filter> 
  19.                 <action android:name="android.intent.action.MAIN" /> 
  20.                 <category android:name="android.intent.category.LAUNCHER" /> 
  21.             </intent-filter> 
  22.     </activity> 
  23.     <activity android:name=".SecondActivity" 
  24.                   android:label="@string/app_name"> 
  25.             <intent-filter> 
  26.                 <action android:name="android.intent.action.MAIN" /> 
  27.                 <category android:name="android.intent.category.LAUNCHER" /> 
  28.             </intent-filter> 
  29.     </activity> 
  30.     </application> 
  31. </manifest> 

效果图:

 


本文转自 lingdududu 51CTO博客,原文链接: 

http://blog.51cto.com/liangruijun/643043
相关文章
|
21天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
12 0
|
1月前
|
XML 缓存 Android开发
Android开发,使用kotlin学习多媒体功能(详细)
Android开发,使用kotlin学习多媒体功能(详细)
97 0
|
1月前
|
设计模式 人工智能 开发工具
安卓应用开发:构建未来移动体验
【2月更文挑战第17天】 随着智能手机的普及和移动互联网技术的不断进步,安卓应用开发已成为一个热门领域。本文将深入探讨安卓平台的应用开发流程、关键技术以及未来发展趋势。通过分析安卓系统的架构、开发工具和框架,本文旨在为开发者提供全面的技术指导,帮助他们构建高效、创新的移动应用,以满足不断变化的市场需求。
18 1
|
1月前
|
机器学习/深度学习 调度 Android开发
安卓应用开发:打造高效通知管理系统
【2月更文挑战第14天】 在移动操作系统中,通知管理是影响用户体验的关键因素之一。本文将探讨如何在安卓平台上构建一个高效的通知管理系统,包括服务、频道和通知的优化策略。我们将讨论最新的安卓开发工具和技术,以及如何通过这些工具提高通知的可见性和用户互动性,同时确保不会对用户造成干扰。
33 1
|
12天前
|
XML 开发工具 Android开发
构建高效的安卓应用:使用Jetpack Compose优化UI开发
【4月更文挑战第7天】 随着Android开发不断进化,开发者面临着提高应用性能与简化UI构建流程的双重挑战。本文将探讨如何使用Jetpack Compose这一现代UI工具包来优化安卓应用的开发流程,并提升用户界面的流畅性与一致性。通过介绍Jetpack Compose的核心概念、与传统方法的区别以及实际集成步骤,我们旨在提供一种高效且可靠的解决方案,以帮助开发者构建响应迅速且用户体验优良的安卓应用。
|
15天前
|
监控 算法 Android开发
安卓应用开发:打造高效启动流程
【4月更文挑战第5天】 在移动应用的世界中,用户的第一印象至关重要。特别是对于安卓应用而言,启动时间是用户体验的关键指标之一。本文将深入探讨如何优化安卓应用的启动流程,从而减少启动时间,提升用户满意度。我们将从分析应用启动流程的各个阶段入手,提出一系列实用的技术策略,包括代码层面的优化、资源加载的管理以及异步初始化等,帮助开发者构建快速响应的安卓应用。
|
15天前
|
Java Android开发
Android开发之使用OpenGL实现翻书动画
本文讲述了如何使用OpenGL实现更平滑、逼真的电子书翻页动画,以解决传统贝塞尔曲线方法存在的卡顿和阴影问题。作者分享了一个改造后的外国代码示例,提供了从前往后和从后往前的翻页效果动图。文章附带了`GlTurnActivity`的Java代码片段,展示如何加载和显示书籍图片。完整工程代码可在作者的GitHub找到:https://github.com/aqi00/note/tree/master/ExmOpenGL。
19 1
Android开发之使用OpenGL实现翻书动画
|
15天前
|
Android开发 开发者
Android开发之OpenGL的画笔工具GL10
这篇文章简述了OpenGL通过GL10进行三维图形绘制,强调颜色取值范围为0.0到1.0,背景和画笔颜色设置方法;介绍了三维坐标系及与之相关的旋转、平移和缩放操作;最后探讨了坐标矩阵变换,包括设置绘图区域、调整镜头参数和改变观测方位。示例代码展示了如何使用这些方法创建简单的三维立方体。
13 1
Android开发之OpenGL的画笔工具GL10
|
21天前
|
Android开发
Android开发小技巧:怎样在 textview 前面加上一个小图标。
Android开发小技巧:怎样在 textview 前面加上一个小图标。
12 0
|
21天前
|
Android开发
Android 开发 pickerview 自定义选择器
Android 开发 pickerview 自定义选择器
12 0