2024年4月30日发(作者:)
Android布局技巧
Android平台提供了大量的UI构件,你可以将这些小的视觉块(构件)搭建在一起,呈现给用户复杂且
有用的画面。然而,应用程序有时需要一些高级的视觉组件。为了满足这一需求,并且能高效的实现,你
可以把多个标准的构件结合起来成为一个单独的、可重用的组件。
例如,你可以创建一个可重用的组件包含一个进度条和一个取消按钮,一个Panel包含两个按钮(确定和
取消动作),一个Panel包含图标、标题和描述等等。简单的,你可以通过书写一个自定义的View来创
建一个UI组件,但更简单的方式是仅使用XML来实现。
在Android XML布局文件里,一般,每个标签都对应一个真实的类实例(这些类一般都是View的子类)。
UI工具包还允许你使用三个特殊的标签,它们不对应具体的View实例:、、。这篇文章将描述如何使用
来创建一个单纯的XML视觉组件。了解更多关于如何使用的资料,请参看《合并布局》文章,尤其是它与
结合起来使用体现出来的强大威力。
元素的作用如同它的名字一样;它用于包含其它的XML布局。使用这个标签如下面的例子所示:
android:id="@+id/workspace" android:layout_width="fill_parent" android:layout_height="fill_parent" launcher:defaultScreen="1"> layout="@layout/workspace_screen" /> layout="@layout/workspace_screen" /> layout="@layout/workspace_screen" />
在中,只需要layout特性。这个特性,不带android命名空间前缀,它表示你想包含的布局的引用。在
这个例子中,相同的布局被包含了三次。这个标签还允许你重写被包含布局的一些特性。上面的例子显示
了你可以使用android:id来指定被包含布局中根View的id;它还可以覆盖已经定义的布局id。相似的,
你可以重写所有的布局参数。这意味着任何android:layout_*的特性都可以在中使用。下面是例子:
layout="@layout/image_holder" /> 1 2 3 layout="@layout/image_holder" /> 这个标签,在依据设备设置定制UI时表现得尤为有用。举个例子,Activity的主要布局放置在layout/ 文件夹下,其它布局放置在layout-land/和layout-port/下。这样,在垂直和水平方向时你可以共享大 多数的UI布局。 Android UI工具包提供了一些布局管理器,它们使用起来相当容易,而且,大多数的时候,你只需要使用 它们最基本的特征来实现UI。 执着于基本特征的使用对于创建UI来说,往往不是最高效的。一个常见的例子就是滥用LinearLayout, 它将会导致View树中的View数量激增。View——更糟的是,布局管理器——添加到应用程序里都会带 来一定的消耗:初始化,布局和绘制变得更加缓慢。嵌套布局的花销尤其“昂贵”,例如,如果你嵌套了一 些LinearLayout,并使用了weight参数,这会导致子元素要计算两次。 让我们看一个非常简单且常见的布局例子:一个列表项,左边是一个图标,右边是标题和描述,上方是标 题,下方是可选的描述。列表项可能看起来如下图:


发布评论