Android UI开发第十八篇——ActivityGroup实现tab功能

简介:

android.app包中含有一个ActivityGroup类,该类是Activity的容器,可以包含多个嵌套进来的Activitys,这篇文章就是借助ActivityGroup可以嵌套Activity的功能来实现Tab功能。tab这种UI在很多的移动应用中可以看到,包括android、iphone、window phone7等移动终端上都有这样的应用,Tab这种UI方式具有小视图大容量的特点。

       首先,从SDK中doc文档中都可以获知,ActivityGroup类的父类是Activity(见下图),也就是说二者具有相同的接口和生命周期,同Activity一样,也有onCreate()、onPause()等函数可供我们重载。

 

 ActivityGroup中有两个public方法(下图):ActivityGroup中可以调用getLocalActivityManage()方法获取LocalActityManage来管理Activity。

 

 ActivityGroup实现的tab功能的效果图如下。

 

先看一下java代码:

 
  1. public class MainView extends ActivityGroup {  
  2.     @SuppressWarnings("unused")  
  3.     private LinearLayout bodyView,headview;  
  4.     private LinearLayout one, two, three, four;  
  5.     private int flag = 0// 通过标记跳转不同的页面,显示不同的菜单项  
  6.     /** Called when the activity is first created. */ 
  7.     @Override 
  8.     public void onCreate(Bundle savedInstanceState) {  
  9.         super.onCreate(savedInstanceState);  
  10.         setContentView(R.layout.view_main);  
  11.         initMainView();  
  12.         // 显示标记页面  
  13.         showView(flag);  
  14.         one.setOnClickListener(new OnClickListener() {        
  15.             public void onClick(View v) {  
  16.                 // TODO Auto-generated method stub  
  17.                 flag = 0;  
  18.                 showView(flag);  
  19.                 }  
  20.         });  
  21.         two.setOnClickListener(new OnClickListener() {                    
  22.             public void onClick(View v) {  
  23.                 // TODO Auto-generated method stub  
  24.                 flag = 1;  
  25.                 showView(flag);  
  26.             }  
  27.         });  
  28.         three.setOnClickListener(new OnClickListener() {                  
  29.             public void onClick(View v) {  
  30.                 // TODO Auto-generated method stub  
  31.                 flag = 2;  
  32.                 showView(flag);  
  33.             }  
  34.         });  
  35.         four.setOnClickListener(new OnClickListener() {           
  36.                 public void onClick(View v) {  
  37.                 // TODO Auto-generated method stub  
  38.                     flag = 3;  
  39.                     showView(flag);  
  40.             }  
  41.         });  
  42.  
  43.     }  
  44.      
  45.     /*  
  46.      * 初始化主界面  
  47.      */ 
  48.     public void initMainView() {  
  49.         headview=(LinearLayout) findViewById(R.id.head);  
  50.         bodyView=(LinearLayout) findViewById(R.id.body);  
  51.         one=(LinearLayout) findViewById(R.id.one);  
  52.         two=(LinearLayout) findViewById(R.id.two);  
  53.         three=(LinearLayout) findViewById(R.id.three);  
  54.         four=(LinearLayout) findViewById(R.id.four);  
  55.     }  
  56.       
  57.    // 在主界面中显示其他界面  
  58.     public void showView(int flag) {  
  59.         switch (flag) {  
  60.         case 0:  
  61.             bodyView.removeAllViews();  
  62.             View v = getLocalActivityManager().startActivity("one",  
  63.                     new Intent(MainView.this, OneView.class)).getDecorView();  
  64.  
  65.             one.setBackgroundResource(R.drawable.frame_button_background);  
  66.             two.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  67.             three.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  68.             four.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  69.           
  70.             bodyView.addView(v);  
  71.             break;  
  72.         case 1:  
  73.             bodyView.removeAllViews();  
  74.             bodyView.addView(getLocalActivityManager().startActivity("two",  
  75.                     new Intent(MainView.this, TwoView.class))  
  76.                     .getDecorView());  
  77.             one.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  78.             two.setBackgroundResource(R.drawable.frame_button_background);  
  79.             three.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  80.             four.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  81.             break;  
  82.         case 2:           
  83.             bodyView.removeAllViews();  
  84.             bodyView.addView(getLocalActivityManager().startActivity(  
  85.                     "three"new Intent(MainView.this, ThreeView.class))  
  86.                     .getDecorView());  
  87.             one.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  88.             two.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  89.             three.setBackgroundResource(R.drawable.frame_button_background);  
  90.             four.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  91.             break;  
  92.         case 3:           
  93.             bodyView.removeAllViews();  
  94.             bodyView.addView(getLocalActivityManager().startActivity(  
  95.                     "four"new Intent(MainView.this, FourView.class))  
  96.                     .getDecorView());  
  97.             one.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  98.             two.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  99.             three.setBackgroundResource(R.drawable.frame_button_nopressbg);  
  100.             four.setBackgroundResource(R.drawable.frame_button_background);  
  101.             break;  
  102.         default:  
  103.             break;  
  104.         }  
  105.     }  

程序中重要的是如下的方法:

 
  1.     bodyView.removeAllViews();  
  2.     bodyView.addView(getLocalActivityManager().startActivity("two",  
  3. new Intent(MainView.this, TwoView.class))  
  4. .getDecorView());  

 使用view的removeAllViews()方法清除不需要的view,使用addView(View v)方法添加需要的view。

getLocalActivityManager().startActivity("two",new Intent(MainView.this, TwoView.class))得到一个window对象,window对象调用

getDecorView()获取view。关于window的方法可以参考android.app.Window。

      通过tab的效果图可以看到这个效果使用了上、中、下三种布局,layout就可以这样做了。实现layout就可以实现tab功能了。




     本文转自xyz_lmn51CTO博客,原文链接:http://blog.51cto.com/xyzlmn/817245,如需转载请自行联系原作者



相关文章
|
16天前
|
消息中间件 安全 数据处理
Android为什么不能在子线程更新UI
Android为什么不能在子线程更新UI
23 0
|
20天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
12 0
|
11天前
|
XML 开发工具 Android开发
构建高效的安卓应用:使用Jetpack Compose优化UI开发
【4月更文挑战第7天】 随着Android开发不断进化,开发者面临着提高应用性能与简化UI构建流程的双重挑战。本文将探讨如何使用Jetpack Compose这一现代UI工具包来优化安卓应用的开发流程,并提升用户界面的流畅性与一致性。通过介绍Jetpack Compose的核心概念、与传统方法的区别以及实际集成步骤,我们旨在提供一种高效且可靠的解决方案,以帮助开发者构建响应迅速且用户体验优良的安卓应用。
|
20天前
|
Android开发
Android开发小技巧:怎样在 textview 前面加上一个小图标。
Android开发小技巧:怎样在 textview 前面加上一个小图标。
10 0
|
20天前
|
Android开发
Android 开发 pickerview 自定义选择器
Android 开发 pickerview 自定义选择器
12 0
|
27天前
|
Java Android开发
Android开发系列全套课程
本系列课程面向有java基础,想进入企业从事android开发的计算机专业者。学习搭配实战案例,高效掌握岗位知识。
17 1
|
3月前
|
存储 Java 开发工具
Android开发的技术与开发流程
Android开发的技术与开发流程
143 1
|
3月前
|
SQL API Android开发
展望2022:Android 开发最新技术动向
展望2022:Android 开发最新技术动向
108 0
展望2022:Android 开发最新技术动向
|
SQL XML Java
展望2022:Android 开发最新技术动向
今年的 Android Dev Summit 在线上如期举行,在活动上 Google 的技术专家们会分享一些 Android 领域的技术动向以及开发心得。本文做一个全面盘点
2103 0
|
Java API Android开发
【Android 高性能音频】高性能音频简介 ( 高性能音频问题引入 | 使用场景 | 相关开发库及技术 )
【Android 高性能音频】高性能音频简介 ( 高性能音频问题引入 | 使用场景 | 相关开发库及技术 )
140 0