对Android提供的基本布局控件进行组合,可以实现一些相对复杂的效果,下面需要实现的效果如图:
header效果:
header.xml文件:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@android:drawable/title_bar"> <Button android:id="@+id/header_button_left" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentLeft="true" android:layout_centerVertical="true" android:background="@android:drawable/ic_media_rew" /> <Button android:id="@+id/header_button_right" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignParentRight="true" android:layout_centerVertical="true" android:background="@android:drawable/ic_media_ff" /> <TextView android:id="@+id/header_text_center" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_alignBottom="@+id/button1" android:layout_centerInParent="true" android:text="文本信息" android:textAppearance="?android:attr/textAppearanceLarge" /> </RelativeLayout>
footer效果:
footer.xml文件:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@android:drawable/title_bar"> <LinearLayout android:layout_width="wrap_content" android:layout_height="fill_parent" android:layout_weight="1" android:gravity="center"> <Button android:id="@+id/footer_a" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@android:drawable/alert_light_frame" android:text="A" /> </LinearLayout> <LinearLayout android:layout_width="wrap_content" android:layout_height="fill_parent" android:orientation="vertical" android:layout_weight="1" android:gravity="center"> <Button android:id="@+id/footer_b" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@android:drawable/alert_light_frame" android:text="B" /> </LinearLayout> <LinearLayout android:layout_width="wrap_content" android:layout_height="fill_parent" android:orientation="vertical" android:layout_weight="1" android:gravity="center"> <Button android:id="@+id/footer_c" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@android:drawable/alert_light_frame" android:text="C" /> </LinearLayout> <LinearLayout android:layout_width="wrap_content" android:layout_height="fill_parent" android:orientation="vertical" android:layout_weight="1" android:gravity="center"> <Button android:id="@+id/footer_d" android:layout_width="fill_parent" android:layout_height="wrap_content" android:background="@android:drawable/alert_light_frame" android:text="D" /> </LinearLayout> </LinearLayout>
activity_include.xml文件:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:background="#cccccc"> <LinearLayout android:id="@+id/top" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_alignParentTop="true" > <include layout="@layout/header" /> </LinearLayout> <LinearLayout android:id="@+id/middle" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_below="@+id/top" android:layout_above="@+id/bottom"> </LinearLayout> <LinearLayout android:id="@+id/bottom" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_alignParentBottom="true"> <include layout="@layout/footer" /> </LinearLayout> </RelativeLayout>
说明:
- RelativeLayout内部分成top,middle,bottom三个LinearLayout,分别用于添加header,自定义布局,footer;
- top填充顶部,bottom填充底部,middle填充剩余区域;
- include标签导入外部layout文件;
下面是4个测试Activity的布局文件,基本类似,中间区域放置一个按钮,代码如下activity_a.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:gravity="center" > <Button android:id="@+id/activity_a_button" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="A" /> </LinearLayout>
剩下的activity_b.xml,activity_c.xml,activity_d.xml就不一一贴出了!:)
AActivity的代码如下:
import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.Toast; public class AActivity extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_a); findViewById(R.id.activity_a_button).setOnClickListener( new OnClickListener() { @Override public void onClick(View v) { Toast.makeText(AActivity.this, "This is activity a!", Toast.LENGTH_SHORT).show(); } }); } }
说明:
- 当点击按钮后,显示当前Activity信息;
- 其它BActivity,CActivity,DActivity代码类似,不一一贴出了!:)
看看IncludeActivity的主要代码:
import android.app.ActivityGroup; import android.content.Intent; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.view.ViewGroup.LayoutParams; import android.widget.Button; import android.widget.LinearLayout; import android.widget.TextView; import android.widget.Toast; public class IncludeActivity extends ActivityGroup implements OnClickListener { // Header private Button leftButtonHeader; private Button rightButtonHeader; private TextView centerTextHeader; // Footer private Button aButtonFooter; private Button bButtonFooter; private Button cButtonFooter; private Button dButtonFooter; private LinearLayout middleLayout; private View middleView; private LayoutParams layoutParams; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_include); setTitle("测试"); // 获得Header部分的View引用 leftButtonHeader = (Button) findViewById(R.id.header_button_left); rightButtonHeader = (Button) findViewById(R.id.header_button_right); centerTextHeader = (TextView) findViewById(R.id.header_text_center); // 获得Footer部分的View引用 aButtonFooter = (Button) findViewById(R.id.footer_a); bButtonFooter = (Button) findViewById(R.id.footer_b); cButtonFooter = (Button) findViewById(R.id.footer_c); dButtonFooter = (Button) findViewById(R.id.footer_d); // 设置点击事件监听器 leftButtonHeader.setOnClickListener(this); rightButtonHeader.setOnClickListener(this); aButtonFooter.setOnClickListener(this); bButtonFooter.setOnClickListener(this); cButtonFooter.setOnClickListener(this); dButtonFooter.setOnClickListener(this); layoutParams = new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT); // 获得自定义View的父容器 middleLayout = (LinearLayout) findViewById(R.id.middle); // 获得自定义View,并添加到当前布局 middleView = getLocalActivityManager().startActivity(null, new Intent(this, AActivity.class)).getDecorView(); middleLayout.addView(middleView, layoutParams); } @Override public void onClick(View v)getLocalActivityManager { switch (v.getId()) { case R.id.header_button_left: Toast.makeText(this, "左", Toast.LENGTH_SHORT).show(); break; case R.id.header_button_right: Toast.makeText(this, "右", Toast.LENGTH_SHORT).show(); break; case R.id.footer_a: Toast.makeText(this, "A", Toast.LENGTH_SHORT).show(); middleLayout.removeAllViews(); middleView = getLocalActivityManager().startActivity(null, new Intent(this, AActivity.class)).getDecorView(); middleLayout.addView(middleView, layoutParams); break; case R.id.footer_b: Toast.makeText(this, "B", Toast.LENGTH_SHORT).show(); middleLayout.removeAllViews(); middleView = getLocalActivityManager().startActivity(null, new Intent(this, BActivity.class)).getDecorView(); middleLayout.addView(middleView, layoutParams); break; case R.id.footer_c: Toast.makeText(this, "C", Toast.LENGTH_SHORT).show(); middleLayout.removeAllViews(); middleView = getLocalActivityManager().startActivity(null, new Intent(this, CActivity.class)).getDecorView(); middleLayout.addView(middleView, layoutParams); break; case R.id.footer_d: Toast.makeText(this, "D", Toast.LENGTH_SHORT).show(); middleLayout.removeAllViews(); middleView = getLocalActivityManager().startActivity(null, new Intent(this, DActivity.class)).getDecorView(); middleLayout.addView(middleView, layoutParams); break; default: break; } } }
说明:
- middleLayout在重新添加View的时候,要先清除已有View,即:middleLayout.removeAllViews();
- 通过getLocalActivityManager获得LocalActivityManager,然后在获得某个Activity对应的View,并添加到当前布局中;
- 虽然AActivit的UI在IncludeActivity中显示,但是有关AActivity的UI操作和逻辑代码只要在AActivity中进行编写就可以了;
- manifest文件中添加相关Activity的声明;
- 关于添加其它Activity的UI到当前Activity的代码没有做性能测试,可能需要做调整,包括连续点击A,B,C,D按钮时,控制View是否添加等;
其它效果图片:
多说一句:主要内容是布局效果处理和ActivityGroup使用!:)记录点点滴滴,以备不时之需!=^_^=
相关推荐
【Android布局文件详解】 在Android应用开发中,界面设计是一个至关重要的环节,而XML格式的布局文件正是构建这些界面的核心工具。布局文件定义了应用程序界面的结构,包括它所包含的控件、控件间的相对位置以及...
Android布局文件的属性值解析说明: 1 android:id [为控件指定相应的ID] 2 android:text [指定控件当中显示的文字 需要注意的是 这里尽量使用strings xml文件当中的字符串] 3 android:gravity [指定View组件的对齐...
【Android布局管理器】是Android应用开发中的核心概念,它决定了UI组件在屏幕上的排列方式。在Android中,布局管理器主要有五种类型:线性布局(LinearLayout)、表格布局(TableLayout)、相对布局(RelativeLayout...
本文将深入探讨Android布局的各种类型及其使用方法,旨在帮助开发者更好地理解和掌握Android应用的UI设计。 首先,我们来了解Android中的基本布局类型: 1. **线性布局(LinearLayout)**:这是最基础的布局,它...
Android布局文件是用来描述应用程序界面上组件(如按钮、文本视图、图像视图等)的结构和位置的XML文档。这些文件定义了控件的属性,如大小、位置、文本、样式等,并且可以包含多个嵌套的布局以实现复杂的屏幕设计。...
### Android布局控件之RelativeLayout详解 #### 一、概述 在Android开发中,布局是非常重要的一环,良好的布局设计能够使界面美观且适应各种屏幕尺寸。`RelativeLayout`作为Android提供的几种基本布局之一,通过...
在进行Android布局设计时,应考虑响应式设计,确保界面在不同设备和屏幕尺寸上都能良好显示。同时,合理利用`ViewGroup`的嵌套和权重分配,可以帮助创建更加动态和适应性的界面。实践过程中,不断尝试和优化布局结构...
"Xamarin.Android布局文件自动提示功能"是指在使用Visual Studio或Visual Studio for Mac等集成开发环境(IDE)时,编辑器提供的智能代码补全和提示功能,它能显著提高开发效率,减少错误。本文将深入探讨这个功能,并...
因此,使用面向对象的思想来设计Android布局,可以有效地解决这些问题,提高代码的复用性和可扩展性。 面向对象编程(Object-Oriented Programming,OOP)的核心理念是将复杂的问题分解为一系列相互协作的对象,每...
Android布局高级.doc
本教程将深入探讨Android布局的各个方面,帮助开发者掌握创建高效、可扩展且美观的用户界面的技巧。 首先,我们来了解Android布局的基础知识。Android提供了多种布局类型,每种都有其特定的用途: 1. **线性布局...
在Android开发中,有时我们需要将一个布局转换为图片,例如为了实现分享到微信的功能,或者进行屏幕截图。本文将深入探讨如何在Android中实现“布局生成图片”这一技术,以及如何将其与微信分享功能集成。 首先,让...
LinearLayout 线性布局 控制组件 横向 或者 纵向 排列 RelativeLayout 相对布局 子组件的位置总是相对兄弟组件,父容器来决定的 FrameLayout 帧布局、框架布局 创建一个空白区域, 一个区域成为一帧 TableLayout 表格...
本文将深入探讨如何利用`include`、`ViewStub`和`merge`标签进行Android布局优化。 首先,`include`标签是一种强大的布局重用机制。在大型应用中,往往有许多相似或重复的布局元素,如导航栏、头部视图等。通过`...
在Android开发中,布局属性是构建用户界面的关键组成部分。这些属性允许开发者精确地控制各个UI组件的外观和位置。以下是对几种主要布局及其关键属性的详细说明: **LinearLayout**: 这是最基础的布局,可以将子...
这个“android布局案例源代码”压缩包包含了一系列的示例,帮助开发者深入理解并掌握Android布局设计。以下是这些案例中可能涉及的一些关键知识点: 1. **树形布局(TreeView)**: 树形布局是一种层次结构的展示...
在Android开发中,布局管理器是构建用户界面(UI)的关键元素。它们负责组织和定位UI组件,确保屏幕上的元素合理、美观地排列。本文将深入探讨Android中的常见布局管理器,尤其是基于XML的布局,以及如何在Activity...
本篇文章将深入探讨Android布局的相关知识点。 1. 布局类型: Android提供了多种布局类型,包括线性布局(LinearLayout)、相对布局(RelativeLayout)、帧布局(FrameLayout)、表格布局(TableLayout)和约束...
**Android布局软件DroidDraw详解** DroidDraw是一款专为Android开发者设计的图形化界面布局工具,它使得创建XML布局文件变得更加直观和简单。在早期的Android开发中,DroidDraw因其用户友好的特性,受到了不少...
下面我们将详细探讨Android布局及其在实际应用中的使用。 Android支持多种布局管理器,每种都有其特定的用途: 1. **线性布局(LinearLayout)**:这是最基础的布局,可以将子视图水平或垂直排列。通过设置`...