首页 > 代码库 > android开发之merge结合include优化布局

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

merge结合include优化android布局,效果不知道。个人感觉使用上也有非常大的局限。只是还是了解一下。记录下来。

布局文件都要有根节点,但android中的布局嵌套过多会造成性能问题,于是在使用include嵌套的时候我们能够使用merge作为根节点,这样能够降低布局嵌套,提高显示速率。

<?xml version="1.0" encoding="utf-8"?>
<merge xmlns:android="http://schemas.android.com/apk/res/android" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="张三" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="李四" />

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="王五" />

</merge>

上面的界面在显示的时候会自己主动嵌套到以下的文件里。

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal"
    tools:context="com.example.viewstub.MainActivity" >

    <include layout="@layout/top"/>
    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

    <Button
        android:id="@+id/toggle"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="onClick"
        android:text="显示/隐藏" />

    <ViewStub
        android:id="@+id/vs"
        android:layout_margin="50dp"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:inflatedId="@+id/inflated_id"
        android:layout="@layout/view_stub_layout" />

</LinearLayout>

我为什么说这个局限性比較大呢?由于merge中的空间显示的使用会採用主布局文件的方式来显示。比方我这里主布局是linearlayout且是水平排列,那么merge中的元素显示出来之后也是水平排列,但是我假设想让merge中的元素垂直排列呢?抱歉,做不到。

<script type="text/javascript"> $(function () { $(‘pre.prettyprint code‘).each(function () { var lines = $(this).text().split(‘\n‘).length; var $numbering = $(‘
    ‘).addClass(‘pre-numbering‘).hide(); $(this).addClass(‘has-numbering‘).parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($(‘
  • ‘).text(i)); }; $numbering.fadeIn(1700); }); }); </script>

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