在一个主界面中做Activity切换一般都会用TabActivity,使用方便,Activity互相之间相对独立,但是可定制性不强,而且修改起来
很麻烦。当然也可以把layout分开,把逻辑代码全写在主界面的逻辑代码中,但是很明显可维护性相当差,这里通过ActivityGroup来解决这个
问题。
要求点击底部不同图片按钮切换不同的Activity,并在中间显示Activity对应的ContentView。
二、 实现代码
2.1 layout.xml
<?
xml version="1.0" encoding="utf-8"
?>
<
LinearLayout
xmlns:android
="http://schemas.android.com/apk/res/android"
android:layout_width
="fill_parent"
android:orientation
="vertical"
android:layout_height
="fill_parent"
>
<
LinearLayout
android:gravity
="center_horizontal"
android:background
="@drawable/myinfor2"
android:layout_width
="fill_parent"
android:layout_height
="wrap_content"
>
<
TextView
android:id
="@+id/cust_title"
android:textColor
="@android:color/white"
android:textSize
="28sp"
android:text
="模块1"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
></
TextView
>
</
LinearLayout
>
<!--
中间动态加载View
-->
<
ScrollView
android:measureAllChildren
="true"
android:id
="@+id/containerBody"
android:layout_weight
="1"
android:layout_height
="fill_parent"
android:layout_width
="fill_parent"
>
</
ScrollView
>
<
LinearLayout
android:background
="@android:color/black"
android:layout_gravity
="bottom"
android:orientation
="horizontal"
android:layout_width
="fill_parent"
android:layout_height
="wrap_content"
>
<!--
功能模块按钮1
-->
<
ImageView
android:id
="@+id/btnModule1"
android:src
="@android:drawable/ic_dialog_dialer"
android:layout_marginLeft
="7dp"
android:layout_marginTop
="3dp"
android:layout_marginBottom
="3dp"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
/>
<!--
功能模块按钮2
-->
<
ImageView
android:id
="@+id/btnModule2"
android:src
="@android:drawable/ic_dialog_info"
android:layout_marginLeft
="7dp"
android:layout_marginTop
="3dp"
android:layout_marginBottom
="3dp"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
/>
<!--
功能模块按钮3
-->
<
ImageView
android:id
="@+id/btnModule3"
android:src
="@android:drawable/ic_dialog_alert"
android:layout_marginLeft
="7dp"
android:layout_marginTop
="3dp"
android:layout_marginBottom
="3dp"
android:layout_width
="wrap_content"
android:layout_height
="wrap_content"
/>
</
LinearLayout
>
</
LinearLayout
>
2.2 TestView.java
/**
* 使用ActivityGroup来切换Activity和Layout
*
@author
农民伯伯
*
@version
2010-9-7
*
*/
public
class
TestView
extends
ActivityGroup {
private
ScrollView container
=
null
;
@Override
protected
void
onCreate(Bundle savedInstanceState) {
super
.onCreate(savedInstanceState);
//
隐藏标题栏
requestWindowFeature(Window.FEATURE_NO_TITLE);
//
设置视图
setContentView(R.layout.layout);
container
=
(ScrollView) findViewById(R.id.containerBody);
//
模块1
ImageView btnModule1
=
(ImageView) findViewById(R.id.btnModule1);
btnModule1.setOnClickListener(
new
OnClickListener() {
@Override
public
void
onClick(View v) {
container.removeAllViews();
container.addView(getLocalActivityManager().startActivity(
"
Module1
"
,
new
Intent(TestView.
this
, ModuleView1.
class
)
.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP))
.getDecorView());
}
});
//
模块2
ImageView btnModule2
=
(ImageView) findViewById(R.id.btnModule2);
btnModule2.setOnClickListener(
new
OnClickListener() {
@Override
public
void
onClick(View v) {
container.removeAllViews();
container.addView(getLocalActivityManager().startActivity(
"
Module2
"
,
new
Intent(TestView.
this
, ModuleView2.
class
)
.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP))
.getDecorView());
}
});
//
模块3
ImageView btnModule3
=
(ImageView) findViewById(R.id.btnModule3);
btnModule3.setOnClickListener(
new
OnClickListener() {
@Override
public
void
onClick(View v) {
container.removeAllViews();
container.addView(getLocalActivityManager().startActivity(
"
Module3
"
,
new
Intent(TestView.
this
, ModuleView3.
class
)
.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP))
.getDecorView());
}
});
}
}
代码说明:
a). ModuleView1、ModuleView2
、
ModuleView3
分别继承自Activity。
b). 想动态改变标题可以通过cust_title获取TextView进行设置。
- 大小: 13.2 KB
分享到:
相关推荐
本篇文章将深入探讨如何在VC++中巧妙地实现这样一个功能。 首先,我们需要理解VC++的基本环境。Visual C++(简称VC++)是微软公司推出的一款强大的C++编程工具,它集成了开发环境、编译器、调试器等多种功能,为...
《HR如何巧妙运用网络招聘》 随着互联网技术的飞速发展,网络招聘已成为现代企业招聘人才的重要手段。然而,许多企业在运用网络招聘时遇到了困扰,投入了大量的时间和精力,却收效甚微,甚至吸引到的人才质量不高...
总的来说,逃跑按钮是一种兼顾用户体验和安全性的设计策略,通过巧妙的实现方式,既保证了程序的正常运行,又为用户提供了一种在必要时快速退出的途径。了解并掌握逃跑按钮的设计与实现,对于提升软件的安全性和易用...
如何写好对话——提示语的巧妙运用 本篇课件主要讲述如何写好对话,着重于提示语的巧妙运用。通过对提示语的定义、分类、位置和作用的讲解,帮助读者掌握写好对话的技巧。 一、对话的定义 对话是指两个人以上的...
"巧妙运用Cookie技术进行Browser_Server通信.pdf" 本文主要介绍了巧妙运用Cookie技术进行Browser_Server通信的方法。在浏览器和服务器之间进行通信时,Cookie技术可以巧妙地实现信息交换。本文首先介绍了Cookie技术...
八字算命中如何巧妙运用八卦知识.pdf
在本主题“巧妙运用ViewStub写出类似Tab选项卡”中,我们将探讨如何利用ViewStub的特性来实现灵活、自定义的Tab选项卡效果。 首先,理解Tab选项卡在移动应用中的常见用途。通常,Tab 用于展示多视图内容,用户可以...
### 巧妙运用移动终端提升企业生产过程质量检验效率 #### 一、引言 在当前竞争激烈的市场环境中,企业为了提高产品质量并降低成本,需要不断探索新的管理方法和技术手段。移动终端作为一种新兴的信息技术工具,在...
在本课程“第八课 逃跑按钮的巧妙实现 1”中,我们将深入探讨如何在软件或应用程序中设计和实现一个有效的“逃跑按钮”。这个概念通常指的是一个能够快速让用户退出或安全离开当前界面的功能,比如在浏览敏感信息...
在商务谈判中,面对紧张激烈的讨论,如何巧妙地运用幽默来化解僵局,是一个非常重要的策略。幽默不仅可以缓解气氛,还能增进双方的理解和信任,推动谈判进程。以下是一些关于运用幽默来破解谈判僵局的关键点: 1. *...
巧妙运用NoScript阻止脚本攻击 NoScript 是一款 Firefox 扩展程序,可以提供对 Firefox 浏览器的额外保护,同时还支持 Flock、Seamonkey 等基于 Mozilla 的浏览器。它是一个开源的插件,可以准许浏览器执行可信任...
提示语的巧妙运用微课制作PPT学习教案.pptx
【多媒体在小学美术教学中的巧妙运用】 随着信息技术的飞速发展,多媒体技术逐渐渗透到教育领域,为教学提供了丰富的手段和资源。在小学美术教学中,巧妙运用多媒体能够极大地激发学生的学习兴趣,拓宽他们的视野,...
### 选项按钮组与组合框的巧妙配合 在软件开发过程中,为了提高用户界面的友好性和操作效率,经常需要对控件进行巧妙的设计与搭配。本文将深入探讨如何利用选项按钮组(Option Button Group)与组合框(Combo Box)...
巧妙运用多媒体,优化小学数学课堂提高教学效率.doc
民间舞《一片绿叶》中扇子的巧妙运用.doc
在第八课 "逃跑按钮的巧妙实现 2" 中,我们可能会深入学习如何在各种编程环境中创建这样一个功能,以提高用户体验和程序的易用性。 在实现逃跑按钮时,我们需要考虑以下几个关键知识点: 1. **事件监听**:首先,...
excel的填充柄在哪 Excel巧妙运用填充柄方法介绍.docx
【描述】: "本文探讨了如何巧妙地利用多媒体技术改进初中语文教学,以提升教学效果和学生的学习兴趣。" 【标签】: "教学方法", "信息技术", "教学资源" 在当今科技高速发展的时代,传统的一书一尺的教学方式已无法...