Android開發優化之——對界面UI的優化(2)

在一個應用程序中,通常都會存在多個Activity,每一個Activity對應着一個UI佈局文件。通常來講,爲了保持不一樣窗口之間的風格統一,在這些UI佈局文件中,幾乎確定會用到不少相同的佈局。若是咱們在每一個xml文件中都把相同的佈局都重寫一遍,一個是代碼冗餘,可讀性不好;另外一個是修改起來比較麻煩,對後期的修改和維護很是不利。因此,通常狀況下,咱們須要把相同佈局的代碼單獨寫成一個模塊,而後在用到的時候,能夠經過<include /> 標籤來重用layout的代碼。java

常見的,有的應用在最上方會有一個標題欄。相似下圖所示。android

圖 標題欄的示例web

   若是項目中大部分Activity的佈局都包含這樣的標題欄,就能夠把標題欄的佈局單獨寫成一個xml文件。佈局

<RelativeLayout
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:background="@drawable/navigator_bar_bg"
    xmlns:android="http://schemas.android.com/apk/res/android">
    <TextView
        android:id="@android:id/title"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_centerVertical="true"
        android:gravity="center"
        android:hint="title"
        android:textAppearance="?android:attr/textAppearanceMedium" />
    <ImageView
        android:id="@android:id/closeButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:src="@drawable/close" />
</RelativeLayout>

咱們將上面的xml文件命名爲「navigator_bar.xml」,其它須要標題欄的Activity的xml佈局文件就能夠直接引用此文件了。ui

<include layout="@layout/navigator_bar" />

 

經驗分享:spa

通常狀況下,在項目的初期就可以大體肯定總體UI的風格。因此早期的時候就能夠作一些規劃,將通用的模塊先寫出來。.net

下面是可能能夠抽出的共用的佈局:code

1)背景。有的應用在不一樣的界面裏會用到統一的背景。後期可能會常常修改默認背景,因此能夠將背景作成一個通用模塊。orm

2)頭部的標題欄。若是應用有統一的頭部標題欄,就能夠抽取出來。xml

3)底部的導航欄。若是應用有導航欄,並且大部分的Activity的底部導航欄是相同的,就能夠將導航欄寫成一個通用模塊。

4)ListView。大部分應用都會用到ListView展現多條數據。項目後期可能會常常調整ListView的風格,因此將ListView做爲一個通用的模塊比較好。

 

---------------------------------------------------------------------------

http://blog.csdn.net/arui319

《Android應用開發精解》已出版,本文是初稿的部份內容。歡迎購買閱讀。

本文能夠轉載,可是請保留以上做者信息。

謝謝。

---------------------------------------------------------------------------

相關文章
相關標籤/搜索