? <script src="http://www.google.com/buzz/api/button.js" type="text/javascript"></script>
使用<include /> 標簽來重用layout代碼
如果在一個項目中需要用到相同的布局設計,可以通過<include /> 標簽來重用layout代碼,該標簽在android開發文檔中沒有相關的介紹。在
android主屏程序中
用到了這個標簽:
<com.android.launcher.Workspace
android:id="@+id/workspace"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
launcher:defaultScreen="1">
<include android:id="@+id/cell1" layout="@layout/workspace_screen" />
<include android:id="@+id/cell2" layout="@layout/workspace_screen" />
<include android:id="@+id/cell3" layout="@layout/workspace_screen" />
</com.android.launcher.Workspace>
這樣可以多次引用一個布局片段而不用重復的復制、粘貼。通過include標簽也可以覆寫一些屬性的值,例如上面的示例就覆寫了引用的layout中的id值。下面是另外一個示例:
<include android:layout_width="fill_parent" layout="@layout/image_holder" />
<include android:layout_width="256dip" layout="@layout/image_holder" />
使用<merge /> 標簽來減少視圖層級結構
在Android layout文件中需要一個頂級容器來容納其他的組件,而不能直接放置多個組件,例如如下的代碼
:
<
FrameLayout
?
xmlns:android
=
"http://schemas.android.com/apk/res/android"
????
android:layout_width
=
"fill_parent"
????
android:layout_height
=
"fill_parent"
>
????
<
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:text
=
"Golden?Gate"
?
/>
</
FrameLayout
>
?
上面的代碼顯示一個圖片,然后在圖片上方顯示一個title, 結果如下圖:
android activity的默認布局為FrameLayout,這樣上面的布局代碼就有2層
FrameLayout
,通過HierarchyViewer
工具看到的結構如下:
如果能在layout文件中把
FrameLayout
聲明去掉就可以進一步優化布局代碼了。 但是由于布局代碼需要外層容器容納,如果
直接刪除
FrameLayout
則該文件就不是合法的布局文件。這種情況下就可以使用<merge /> 標簽了。
修改為如下代碼就可以消除多余的FrameLayout了:
<
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:text
=
"Golden?Gate"
?
/>
</
merge
>
通過HierarchyViewer工具看到的結構如下:
merge也有一些使用限制: 只能用于xml layout文件的根元素;在代碼中inflate一個以merge為根元素的
布局文件時候,你需要指定一個ViewGroup 作為其容器,并且要設置attachToRoot 為true,詳細信息參考
inflate()函數doc。
上面示例項目代碼:
http://progx.org/users/Gfx/android/MergeLayout.zip