Android 高效布局的几点建议

简介: 在Android应用开发过程中,布局是一项最基础的工作。如何进行高效布局,提高开发效率呢? 我经过长期实践,总结了以下几条建议: 一、 静态布局为主,动态布局为辅 1.静态布局 就是我们最常用的,通过xml来进行布局。 优点:所见即所得。布局创建,修改,预览都非常的方便。缺点:灵活性稍差。

同步发布在:http://snowdream.github.io/blog/2016/03/16/android-effective-layout/

在Android应用开发过程中,布局是一项最基础的工作。
如何进行高效布局,提高开发效率呢? 我经过长期实践,总结了以下几条建议:

一、 静态布局为主,动态布局为辅

  1. 静态布局

就是我们最常用的,通过xml来进行布局。

优点:所见即所得。布局创建,修改,预览都非常的方便。
缺点:灵活性稍差。

  1. 动态布局

通过Java代码来实现布局。

优点:灵活性好。在应用运行过程中,可以随时去调整布局,例如:增加未加载的新控件,调整控件的位置等。
缺点:可见性差,维护非常的繁琐。

大家都知道,一个项目,一个功能,不可能自始至终都是同一个人进行维护的。人员流动,工作调整,这些都可能造成以下结果:你去接手别人维护的功能/模块,别人接手你维护的功能/模块。基于这种现状,在Android应用布局方面,可见性,可维护性显得尤为重要。 因此,我推荐的布局原则是:“静态布局为主,动态布局为辅。”

推荐的理由有两点:

  1. 布局是一个相对持续的过程。可能UI/UE会随时让你调整下控件之间的间距,位置等。动态布局,需要每次修改后,编译运行在手机上才能看到实际的效果。而静态布局,可以随时修改,随时预览效果。
  2. 静态布局,你可以通过阅读xml,预览效果,对于整个界面,可以快速的熟悉和掌握。而对于动态布局,你必须确认你对所有有关的代码熟悉后,静态布局和动态布局相结合,在脑海中对整个界面进行拼接,才能有一个整体把握。而随着布局变得复杂,这将变得越来越难。

二、 善用tools工具

有些布局,预览效果非常差。咋一看上去,一片空白。这样其实丧失了静态布局的一大优点“所见即所得。”整个布局之后,你编译运行到手机上,才能看到你设置的属性,间距等是否正常生效了。

这里,我推荐一个原则:“尽量在布局中展示你要的效果。”
怎么实现呢?这里需要用到一个工具,tools。

Tools 简介和用法

Tools工具的使用仅仅针对IDE有效,并不会被打包进应用。

具体步骤如下:

  1. 在布局最外层,加上下面这句话,声明一下。
xmlns:tools="http://schemas.android.com/tools"
  1. 一般的控件属性以“android:”开头。新增一个同样的属性,改为以“tools:”开头。

例如:一个TextView控件,需要设置默认状态为不可见。

<TextView
            android:text="Name"
            android:visiblity="gone"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

但是你想预览它,又担心改为android:visiblity="visible"之后忘了改回来,直接提交了。现在你不必担心,新增一个同样名称的属性,以“tools:”开头,就可以了。

<TextView
            android:text="Name"
            android:visiblity="gone"
            tools:visiblity="visible"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />

三、 时刻谨记UI适配

由于Android开源的特性,造成Android手机种类繁多。这些手机拥有不同版本的系统,不同的屏幕分辩率,不同的配置等。
我们在进行布局的时候,要时刻谨记UI适配,尽最大限度去适配不同的分辨率。
这里,我总结几点经验:

  1. Android控件,默认会带有一点padding。 有些背景切图,可能会留有较大的余白。而UI/UE的标注图可能并没有考虑这些因素,因此,UI/UE的标注图仅供参考。实际布局过程中,可能需要稍微调整。
  2. 保留重要标注尺寸,忽略次要标注尺寸。举个简单的例子。假设一个顶部区域,固定高度。需要放置主标题,副标题两个文本控件。 建议这么布局,主标题和副标题使用一个竖直的LinearLayout进行包裹。主标题和副标题控件之间按照标注图设置精准的间距。之后,把整个LinearLayout竖直居中在顶部区域。
  3. 设置android:weight,来进行按照比例布局。
  4. 文本控件,需要考虑,文本过长时的省略策略。
  5. 防止控件相互压盖
  6. 切图至少提供两套,hdpi和xhdpi

参考

  1. Designtime Layout Attributes
  2. Tools Attributes
相关文章
|
4天前
|
XML Android开发 数据格式
android点击FrameLayout、LinearLayout等父布局没响应的原因以及解决方案
android点击FrameLayout、LinearLayout等父布局没响应的原因以及解决方案
42 2
|
4天前
|
Android开发
Android梅花布局
Android梅花布局
23 1
|
4天前
|
Android开发
android 布局常见调整手段,怎样查看margin,padding等等
android 布局常见调整手段,怎样查看margin,padding等等
19 0
|
7月前
|
XML 前端开发 Android开发
android 前端常用布局文件升级总结(二)
android 前端常用布局文件升级总结(二)
|
4天前
|
开发框架 搜索推荐 .NET
Android之ListActivity 布局与数据绑定
Android之ListActivity 布局与数据绑定
11 0
|
4天前
|
XML Android开发 数据格式
Android六大布局
Android六大布局
39 1
|
4天前
|
存储 传感器 Android开发
构建高效Android应用:从优化布局到提升性能
【5月更文挑战第13天】 在竞争激烈的移动应用市场中,一个高效的Android应用不仅需要具备直观的用户界面和丰富的功能,还要确保流畅的性能和快速的响应时间。本文将深入探讨如何通过优化布局设计、减少资源消耗以及利用系统提供的API来提升Android应用的性能。我们将分析布局优化的策略,讨论内存使用的常见陷阱,并介绍异步处理和电池寿命的考量。这些技术的综合运用将帮助开发者构建出既美观又高效的Android应用。
|
4天前
|
Android开发 容器
Android Layout 布局
Android Layout 布局
11 1
|
4天前
|
搜索推荐 Android开发
自定义Android标题栏TitleBar布局
自定义Android标题栏TitleBar布局
11 1
|
4天前
|
XML Android开发 数据格式
Android五大布局对象---FrameLayout,LinearLayout ,Absolute
Android五大布局对象---FrameLayout,LinearLayout ,Absolute