1、Merge
作用:直接将其中的子元素添加到Merge标签的Parent中,避免引入额外的层级。
使用时的要求:
(1)Merge只能用在布局XMl文件的根元素;
(2)使用Merge来加载一个布局时,必须指定一个ViewGroup作为其父元素,并且要设置加载的attachToRoot参数为true(参照inflate(int,ViewGroup,boolean));
(3)不能在ViewStub中使用,因为ViewStub的inflate方法中根本没有attachToRoot的设置。
具体使用:
先定义需要的布局文件(test_merge.xml):
<merge
xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:text="Test Merge 1"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
<TextView
android:text="Test Merge 2"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
</merge>
然后在其他文件中引用:
<include layout="@layout/merge_test"/>
也可以在自定义的View的布局文件中使用,此时需要将自定义View对应的布局文件的根结点换成merge
标签,然后在引用的布局文件中直接正常引用该自定义View即可。
2、ViewStub
作用:ViewStub是一个轻量级的View,它是一个看不见的,并且不占布局位置的,占用资源非常小的对象。可以为ViewStub指定一个布局,加载布局时,只有ViewStub会被初始化,然后当ViewStub被设置为可见时,或者调用了ViewStub.inflate()时,ViewStub所指向的布局会被加载和实力化,然后ViewStub的布局属性都会传给它指向的布局。
具体使用:(事先实现定义了一个供使用的布局文件viewstub_test)
然后在XML布局文件中引用:
<ViewStub
android:id="@+id/viewstub"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout="@layout/viewstub_test"/>
之后在Java代码中的具体逻辑处加载:
ViewStub stub = findViewById(R.id.viewstub);
stub.inflate();//加载布局文件实例
stub.setVisibility(View.GONE);//隐藏
其中inflate()
方法只能调用一次,用于加载初始化布局(也可以直接使用setVisibility(View.VISIBILITY)
,如果再次调用会出异常java.lang.IllegalStateException: ViewStub must have a non-null ViewGroup viewParent
,之后可用setVisibility()
设置其可见性。如果直接调用setVisibility(View.INVISIBILITY)
会在第一次调用时将布局显示出来,之后的正常将布局隐藏。无论是setVisibility(View.VISIBILITY)
还是第一次调用setVisibility(View.INVISIBILITY)
,如果之后再次调用inflate()
都会出现异常。
需要注意的:
(1)ViewStub只能用来加载一个布局文件,而不是具体的某个View,当然也可以把单独的View放到布局文件中。如果想操作一个具体的View,还是使用visibility属性。
(2)ViewStub中不能嵌套Merge标签。