`
iaiai
  • 浏览: 2196987 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

android之merge布局

 
阅读更多
<merge />标签闪亮登场了。当LayoutInflater遇到这个标签时,它会跳过它,并将<merge />内的元素添加到<merge />的父元素里。迷惑了吗?让我们用<merge />来替换FrameLayout,并重写之前的XML布局:
<merge xmlns:android="http://schemas.android.com/apk/res/android">
    <ImageView  
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent" 
        android:scaleType="center"
        android:src="@drawable/golden_gate" />
    <TextView
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_marginBottom="20dip"
        android:layout_gravity="center_horizontal|bottom"
        android:padding="12dip"
        android:background="#AA000000"
        android:textColor="#ffffffff"
        android:text="Golden Gate" />
</merge>

新的代码中,TextView和ImageView都直接添加到上一层的FrameLayout里。虽然视觉上看起来一样,但View的层次更加简单了:

很显然,在这个场合使用<merge />是因为Activity的ContentView的父元素始终是FrameLayout。如果你的布局使用LinearLayout作为它的根标签(举例),那么你就不能使用这个技巧。<merge />在其它的一些场合也很有用的。例如,它与<include />标签结合起来就能表现得很完美。你还可以在创建一个自定义的组合View时使用<merge />。让我们看一个使用<merge />创建一个新View的例子——OkCancelBar,包含两个按钮,并可以设置按钮标签。下面的XML用于在一个图片上显示自定义的View:
<merge
    xmlns:android="http://schemas.android.com/apk/res/android"    xmlns:okCancelBar="http://schemas.android.com/apk/res/com.example.android.merge">
    <ImageView  
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent" 
        android:scaleType="center"
        android:src="@drawable/golden_gate" />
    <com.example.android.merge.OkCancelBar
        android:layout_width="fill_parent" 
        android:layout_height="wrap_content" 
        android:layout_gravity="bottom"
        android:paddingTop="8dip"
        android:gravity="center_horizontal"
        android:background="#AA000000"
        okCancelBar:okLabel="Save"
        okCancelBar:cancelLabel="Don't save" />
</merge>

新的布局效果如下图所示:

OkCancelBar的代码很简单,因为这两个按钮在外部的XML文件中定义,通过LayoutInflate类导入。如下面的代码片段所示,R.layout.okcancelbar以OkCancelBar为父元素:
public class OkCancelBar extends LinearLayout {
    public OkCancelBar(Context context, AttributeSet attrs) {
        super(context, attrs);
        setOrientation(HORIZONTAL);
        setGravity(Gravity.CENTER);
        setWeightSum(1.0f);
        
        LayoutInflater.from(context).inflate(R.layout.okcancelbar, this, true);
        
        TypedArray array = context.obtainStyledAttributes(attrs, R.styleable.OkCancelBar, 0, 0);
        
        String text = array.getString(R.styleable.OkCancelBar_okLabel);
        if (text == null) text = "Ok";
        ((Button) findViewById(R.id.okcancelbar_ok)).setText(text);
        
        text = array.getString(R.styleable.OkCancelBar_cancelLabel);
        if (text == null) text = "Cancel";
        ((Button) findViewById(R.id.okcancelbar_cancel)).setText(text);
        
        array.recycle();
    }
}

两个按钮的定义如下面的XML所示。正如你所看到的,我们使用<merge />标签直接添加两个按钮到OkCancelBar。每个按钮都是从外部相同的XML布局文件包含进来的,便于维护;我们只是简单地重写它们的id:
<merge xmlns:android="http://schemas.android.com/apk/res/android">
    <include
        layout="@layout/okcancelbar_button"
        android:id="@+id/okcancelbar_ok" />        
    <include
        layout="@layout/okcancelbar_button"
        android:id="@+id/okcancelbar_cancel" />
</merge>

我们创建了一个灵活且易于维护的自定义View,它有着高效的View层次:

<merge />标签极其有用。然而它也有以下两个限制:
·         <merge />只能作为XML布局的根标签使用
·         当Inflate以<merge />开头的布局文件时,必须指定一个父ViewGroup,并且必须设定attachToRoot为true(参看inflate(int, android.view.ViewGroup, Boolean)方法)。
  • 大小: 21 KB
  • 大小: 285.6 KB
  • 大小: 29.7 KB
分享到:
评论

相关推荐

    android include merge标签

    需要注意的是,`merge`标签必须作为顶级元素,并且不能包含根布局属性(如`android:layout_width`和`android:layout_height`)。此外,由于`merge`标签不会生成实际的View对象,所以它不能直接设置属性,所有属性...

    android merge 标签使用介绍

    在Android开发中,`merge`标签是一个非常实用的布局优化工具,它可以帮助开发者减少XML布局文件中的层级,提高应用的性能。本篇文章将详细介绍`merge`标签的使用方法及其优势。 `merge`标签最初被引入是为了减少...

    android layout merge

    在Android开发中,布局(Layout)是构建用户界面的关键元素,而`merge`布局是一种优化UI性能和提高代码可读性的特殊技术。本篇文章将深入探讨`merge`布局的使用,以及它如何与Genymotion模拟器关联。 `merge`布局在...

    android merge和include简单使用

    在Android开发中,`merge`和`include`是两种非常重要的布局管理工具,它们能够帮助开发者更有效地管理和优化布局文件,提高代码的可维护性和性能。这篇博客将深入讲解这两个概念,以及它们如何在实际项目中应用。 ...

    android中include和merge标记的区别和使用

    `include`和`merge`标签是Android XML布局文件中两个非常重要的元素,它们帮助开发者实现布局的重用和优化,提高代码的可维护性和效率。接下来,我们将深入探讨这两个标记的区别和使用方法。 ### `include`标签 `...

    android布局_Android布局_android_

    `merge`布局可以减少视图层次,提高性能;自定义布局则可以根据需求扩展标准布局的功能。 总的来说,理解和熟练运用Android的布局机制是每个开发者必备的技能。通过合理地选择和组合不同的布局类型,我们可以创建出...

    Android中include和merge标签的使用

    `include`和`merge`标签是Android XML布局文件中两个非常重要的元素,它们帮助开发者实现布局的重用和优化,提高代码的可维护性和效率。本篇文章将深入探讨这两个标签的使用方法以及它们在Android开发中的作用。 ##...

    Android UI 优化之merge标签的使用

    "merge"标签是Android XML布局文件中的一个特殊元素,主要用于减少视图层次,提高布局加载效率,从而提升UI性能。本文将深入探讨merge标签的原理、使用场景以及注意事项。 ### 1. merge标签简介 merge标签源自`...

    Android开发之merge结合include优化布局

    merge结合include优化android布局,效果不知道,个人感觉使用上也有很大的局限,不过还是了解一下,记录下来。 布局文件都要有根节点,但android中的布局嵌套过多会造成性能问题,于是在使用include嵌套的时候我们...

    Android开发 - 布局

    - **性能优化**:使用轻量级布局,例如替换LinearLayout为ConstraintLayout,使用`merge`标签减少视图层次。 ### 4. 源码解析 理解布局的源码有助于优化性能。例如,LinearLayout的`onMeasure()`方法负责计算子...

    Android开发——布局管理

    除了基本布局外,Android还提供了组合布局,如`Merge`布局(减少嵌套,提高性能)和`include`标签(复用布局)。`&lt;merge&gt;`标签主要用于减少视图层级,提高渲染效率;`&lt;include&gt;`标签则允许在多个布局文件中重用相同...

    android常用布局的使用

    在实际开发中,开发者往往需要根据需求组合使用这些布局,或者使用`&lt;merge&gt;`标签减少视图层级,提高性能。同时,了解并熟练运用布局转换工具,如Android Studio的布局编辑器和Live Preview功能,能显著提高开发效率...

    Android、教程<经典> 2 Android布局

    3. **使用merge标签**:在`include`标签中,使用`merge`作为根元素可以消除父布局的冗余。 4. **使用布局引用(layout引用)**:避免复制粘贴代码,可以创建多个布局并引用它们。 5. **考虑使用数据绑定**:...

    Android textview 自定义布局

    本教程将详细讲解如何实现一个自定义的TextView布局,使得文本每四行平均分布,若内容超过四分之一屏幕宽度,则占据屏幕的一半。 首先,我们需要创建一个新的XML布局文件来描述这个自定义的TextView。在res/layout...

    java android 布局文件

    - 使用merge标签:当一个布局被包含时,可以减少视图层次,提高渲染速度。 - 使用ViewStub:延迟加载不立即显示的视图。 - 动态加载:根据需要动态加载部分视图,避免一次性加载过多资源。 六、布局变量与数据绑定 ...

    android布局

    在实际应用中,还可以利用`include`标签和`merge`布局来提高代码复用性和性能。 在进行Android布局设计时,应考虑响应式设计,确保界面在不同设备和屏幕尺寸上都能良好显示。同时,合理利用`ViewGroup`的嵌套和权重...

    android 布局文件

    - 使用`merge`标签:在包含布局时,使用`&lt;merge&gt;`代替`&lt;LinearLayout&gt;`可以减少视图层次,提高性能。 - 使用`ViewStub`:对于不常用或延迟加载的视图,可以使用`ViewStub`,只有在需要时才加载。 ### 5. 动态布局 ...

    Android布局控件之linearlayout案例

    在Android开发中,LinearLayout是一种非常基础且常用的布局控件,它是Android SDK提供的布局管理器之一。本教程将深入探讨LinearLayout的使用,通过实际案例来帮助理解其工作原理和功能。 线性布局(LinearLayout)...

    Android布局

    Android提供了多种布局类型,包括线性布局(LinearLayout)、相对布局(RelativeLayout)、帧布局(FrameLayout)、表格布局(TableLayout)和约束布局(ConstraintLayout)。线性布局按照垂直或水平方向排列子视图...

    Android 布局优化

    本文将深入探讨如何利用`include`、`ViewStub`和`merge`标签进行Android布局优化。 首先,`include`标签是一种强大的布局重用机制。在大型应用中,往往有许多相似或重复的布局元素,如导航栏、头部视图等。通过`...

Global site tag (gtag.js) - Google Analytics