Android 优化布局层次结构

最后更新于:2022-04-01 20:40:59

前面介绍过使用HierarchyViewer和Android lint来优化我们的程序,这一篇算是总结性的,借助一个小例子来说用怎么优化应用布局。这个例子是android官网给出的,作者也当一把翻译。     多数开发者可能会这样认为,使用基本的布局结构会产生高效的布局性能,其实这个想法是不完全正确的。我们每一个添加到应用的控件和布局,都需要初始化、布局、绘制,这些多是需要时间降低显示速度的。另外,嵌套多个使用layout_weight属性的LinearLayout实例会花费更大的代价,因为每一个子布局都要测量两次。如果这种布局使用在ListView或者GridView中,渲染时会更耗时。     下面,我们根据一个布局示例使用HierarchyViewer和Android lint来检测优化布局结构。 ## 使用HierchyViewer     HierchyViewer需要你选择一个已连接的设备或者模拟器中的一个运行的程序,显示出布局的树结构。每个块上的红绿灯代表它的测量,布局,以及绘图性能,帮助你找出潜在的问题。有读者在读完[《Android UI 优化——使用HierarchyViewer工具》](http://blog.csdn.net/xyz_lmn/article/details/14222975)后提出HierarchyViewer没有显示出红绿黄灯和时间,这怎么解决。在tool目录启动HierarchyViewer确实没有相应的设置去显示,但是可以在eclipse中启动HierarchyViewer去设置。Window->Open Perspective->others->hierarchyviewer。在Tree View点击三个圆圈的按钮,如图一: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c09ca04.jpg)                         图一 图一图二给出了显示绘制时间和不显示绘制时间的区别: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c0b7031.jpg)    图二 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c0d854c.jpg) 图三 我们开始分析一个ListView的item布局,如图四,这个布局的左边显示了一幅图片,两个文字item放在右边。当布局被重复加载的时优化显得尤为重要。 ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c0eee9f.jpg)                      图四 图四的布局文件在HierarcheyViewer中显示的层次结构如图五,选中LinearLayout会显示各种性能参数,如图六: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c10b9e9.jpg)                         ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c12eeb5.jpg)                                                    图五                                                                    图六              在图五中显示视图有三层结构,并且有些显示了红灯黄灯,这就需要我们优化,图六中也显示了绘制时间。     上述布局性能较低的原因主要是由一个内嵌的LinearLayout所引起,为了提高性能,我们使用RelativeLayout,将该布局浅而广的扁平化结构代替为深而窄的树形结构,这样该布局变为一个2层的结构,修改后的布局结构如图七: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-01-11_569392c141c12.jpg) 图七      此时,绘制时间减少了,并且去掉了红灯、黄灯显示。 ## 使用lint [《Android代码优化——使用Android lint工具》](http://blog.csdn.net/xyz_lmn/article/details/14222939)简单说明了lint的使用,在布局文件内运行Lint工具,可以找出那些可能要优化的布局结构。Lint工具代替Layoutopt工具,并且有更大的功能。如下是Lint的一些示例: 1、Use compound drawables,在LineraLayout布局中包含一个ImageView和一个TextView,可以使用compound drawable代替,性能会更好。 2、Merge root frame,如果root布局是FrameLayout,可以使用代替,具体可参考[《Android抽象布局——include、merge 、ViewStub》](http://blog.csdn.net/xyz_lmn/article/details/14524567)。 3、Useless leaf,没有子布局的layout可以去掉 4、Useless parent ,一个布局不是ScrollView或者不是一个根布局,也没有背景,只有一个孩子节点,可以被删掉。 5、Deep layouts,布局若有太多内嵌,则性能很差。考虑使用RelativeLayout 以及GridLayout等扁平化布局代替。默认布局最大深度是10. Android使用Lint请移步至[《Android代码优化——使用Android lint工具》](http://blog.csdn.net/xyz_lmn/article/details/14222939)。
';