Android 重用Layout

本文介绍如何在Android开发中使用<merge>和<include>标签实现布局文件的复用,通过实例展示了如何创建Activity并处理按钮点击事件以启动不同Activity。
<include> tag basically means ‘take that file and paste it’s contents here’

<merge > The layout which we have to use must be enclosed under merge tag, so that we can include layouts from other xmls.

[u][/u]
<merge xmlns:android="http://schemas.android.com/apk/res/android">
<LinearLayout android:id="@+id/LinearLayout01"
android:layout_width="wrap_content" android:layout_height="wrap_content">
<Button android:layout_width="wrap_content"
android:layout_height="wrap_content" android:id="@+id/Button11"
android:text="Button11"></Button>
<Button android:layout_below="@id/Button01"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:id="@+id/Button12" android:text="Button12"></Button>
</LinearLayout>
</merge>


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout android:id="@+id/RelativeLayout01"
android:layout_width="fill_parent" android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android">
<RelativeLayout android:id="@+id/RelativeLayout02"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_centerInParent="true">
<Button android:id="@+id/Button01" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:text="Next Activity "></Button>
</RelativeLayout>
<RelativeLayout android:id="@+id/RelativeLayout03"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_alignParentBottom="true">
<include layout="@layout/footer" />
</RelativeLayout>
</RelativeLayout>


public class Splash extends Activity implements OnClickListener {

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

findViewById(R.id.Button01).setOnClickListener(this);
findViewById(R.id.Button11).setOnClickListener(this);
findViewById(R.id.Button12).setOnClickListener(this);
}

@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.Button01:
startActivity(new Intent(this, Act2.class));
break;
case R.id.Button11:
Toast.makeText(this, "Button 11 - Activity 1 ....",
Toast.LENGTH_SHORT).show();
break;
case R.id.Button12:
Toast.makeText(this, "Button 12 - Activity 1 ....",
Toast.LENGTH_SHORT).show();
break;
}
}

}


You can download its complete source code from here .[url]http://www.megaupload.com/?d=XZ3KTOGI[/url]
### Android Studio Layout 布局设计与实现 #### 1. 初识Layout布局 在Android开发中,`Layout` 是用于定义UI界面的主要工具之一。它决定了屏幕上各个控件的位置和排列方式。常见的两种基本布局是线性布局 (`LinearLayout`) 和相对布局 (`RelativeLayout`)。 #### 2. 创建一个新的Android项目 要开始学习 `Layout` 的设计与实现,首先需要创建一个新的Android项目。打开Android Studio后,选择 **"Start a new Android Studio project"** 并按照提示输入应用名称、公司域名以及其他必要信息[^2]。 #### 3. 编辑布局文件 编辑器中的布局文件通常位于 `res/layout/activity_main.xml` 路径下。开发者可以在其中编写XML代码来定义UI界面的外观和行为。 以下是关于常见布局及其属性的一些说明: - **线性布局 (LinearLayout)** 线性布局是一种简单的容器,它可以将子视图按水平或垂直方向排列。其常用属性如下: - `android:id`: 设置唯一标识符以便于程序中访问此控件。 - `android:layout_width`: 定义宽度,常用的值有 `match_parent`, `wrap_content`。 - `android:layout_height`: 定义高度,同样支持上述选项。 - `android:background`: 可以为控件指定背景颜色或者图像资源。 - `android:orientation`: 控制子元素的方向,取值为 `horizontal`(横向) 或 `vertical`(纵向)[^3]。 下面是一个简单的线性布局示例: ```xml <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <Button android:id="@+id/button1" android:text="Button 1" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </LinearLayout> ``` - **相对布局 (RelativeLayout)** 相对布局允许更灵活地控制子视图之间的位置关系。例如,可以让某个按钮始终处于屏幕底部中央,或将一个文本框放置在一个图片上方等。 以下是一段使用相对布局的例子: ```xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/textView" android:text="Hello World!" android:layout_centerInParent="true" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </RelativeLayout> ``` #### 4. 使用Include标签重用布局 为了减少重复工作并提高效率,在多个地方需要用到相同的布局时,可以利用 `<include>` 标签引入已有的布局文件[^5]。比如如果有一个通用的导航栏,则只需将其单独保存成一个 `.xml` 文件,然后通过 include 插入到其他页面里即可。 #### 5. 准备发布APK 当完成了所有的功能测试并对应用程序感到满意之后,就可以着手准备发布了。此时需生成带有签名的 APK 文件,整个过程并不繁琐,因为 Android Studio 提供了详尽的帮助指引[^4]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值