- 1、本文档共47页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
android布局技巧大全
Android 布局技巧
Android 平台提供了大量的UI 构件,你可以将这些小的视觉块(构件)搭建在一起,呈现给用户复杂且
有用的画面。然而,应用程序有时需要一些高级的视觉组件。为了满足这一需求,并且能高效的实现,你
可以把多个标准的构件结合起来成为一个单独的、可重用的组件。
例如,你可以创建一个可重用的组件包含一个进度条和一个取消按钮,一个Panel 包含两个按钮(确定和
取消动作),一个Panel 包含图标、标题和描述等等。简单的,你可以通过书写一个自定义的View 来创
建一个UI 组件,但更简单的方式是仅使用XML 来实现。
在Android XML 布局文件里,一般,每个标签都对应一个真实的类实例(这些类一般都是View 的子类)。
UI 工具包还允许你使用三个特殊的标签,它们不对应具体的View 实例:、、。这篇文章将描述如何使用
来创建一个单纯的XML 视觉组件。了解更多关于如何使用的资料,请参看《合并布局》文章,尤其是它与
结合起来使用体现出来的强大威力。
元素的作用如同它的名字一样;它用于包含其它的XML 布局。使用这个标签如下面的例子所示:
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
在中,只需要layout 特性。这个特性,不带android 命名空间前缀,它表示你想包含的布局的引用。在
这个例子中,相同的布局被包含了三次。这个标签还允许你重写被包含布局的一些特性。上面的例子显示
了你可以使用android:id 来指定被包含布局中根View 的id;它还可以覆盖已经定义的布局id。相似的,
你可以重写所有的布局参数。这意味着任何android:layout_*的特性都可以在中使用。下面是例子:
include android:layout_width=fill_parent
1layout=@layout/image_holder /
2
3include android:layout_width=256dip
layout=@layout/image_holder /
这个标签,在依据设备设置定制UI 时表现得尤为有用。举个例子,Activity 的主要布局放置在layout/
文件夹下,其它布局放置在layout-land/和layout-port/下。这样,在垂直和水平方向时你可以共享大
多数的UI 布局。
Android UI 工具包提供了一些布局管理器,它们使用起来相当容易,而且,大多数的时候,你只需要使用
它们最基本的特征来实现UI。
执着于基本特征的使用对于创建UI 来说,往往不是最高效的。一个常见的例子就是滥用LinearLayout,
它将会导致View 树中的View 数量激增。View——更糟的是,布局管理器——添加到应用程序里都会带
来一定的消耗:初始化,布局和绘制变得更加缓慢。嵌套布局的花销尤其“ 昂贵”,例如,如果你嵌套了一
些LinearLayout,并使用了weight 参数,这会导致子元素要计算两次。
让我们看一个非常简单且常见的布局例子:一个列表项,左边是一个图标,右边是标题和描述,上方是标
题,下方是可选的描述。列表项可能看起来如下图:
为了清楚地认识View 之间(一个ImageView 和两个TextView )的相对位置,下图是使用HierarchyViewer
抓获的布局剪影:
实现这个布局,直接使用LinearLayout 就可以了。列表项本身是一个水平的LinearLayout,里面有一
个ImageView 和一个垂直的LinearLayout,垂直的LinearLayout 里包含两个TextView 。以下是这个
布局的源代码:
LinearLayout
您可能关注的文档
最近下载
- PBL糖尿病病例教师版(复旦大学上海医学院).docx VIP
- 马工程文学理论习题集(答案版).docx
- 2025年芜湖市运达轨道交通建设运营有限公司校园招聘笔试模拟试题及答案解析.docx
- 通桥(2016)2321A-Ⅴ:时速350公里高速铁路预制有砟轨道后张法预应力混凝土简支箱梁(双线) 跨度:23.5m(直、曲线).pdf
- 马工程文学理论全套PPT课件.ppt
- 商品信息采编全套教学课件.pptx
- 简历表格 个人简历模板2021简历模板.docx VIP
- 无人驾驶车辆的路径规划算法研究与实现 .pdf VIP
- 《设计心理学》全套教学课件(共五章完整版).pptx
- 无人驾驶车辆的动态路径规划算法研究 .pdf VIP
文档评论(0)