Android Note - 布局优化

栏目: IOS · Android · 发布时间: 5年前

内容简介:首先了解一下刷新率的概念。刷新率 Refresh Rate,代表了然后是帧率的概念。帧率 Frame Rate,代表了Android就是

首先了解一下刷新率的概念。刷新率 Refresh Rate,代表了 屏幕在一秒内刷新屏幕的次数 。刷新率跟屏幕硬件有关,即特定的屏幕只会有特定刷新率。比如一般电子设备刷新率为60HZ。

然后是帧率的概念。帧率 Frame Rate,代表了 GPU在一秒内操作的屏幕的次数 ,例如60fps,表示GPU在一秒内对屏幕进行了60次渲染。

Android就是 通过VSYNC信号来同步UI绘制和动画,使得它们可以获得一个达到60fps的固定的帧率 。如果刷新率跟帧率不一致(一般是帧率小于刷新率)就会出现卡顿。

在上面提到了帧率为60fps。为什么是这个数呢,这是因为 人眼与大脑之间的协作无法感知超过60fps的画面更新 ,一般到了60fps,人脑就会认为相当流畅了。所以一般就是60fps。

为了能够使得APP流畅,我们需要在每一帧以内完成所有的CPU与GPU计算,绘制,渲染等等操作。而 一帧在60fps下对应的时间为 1000ms / 60 ≈ 16.6ms ,所以这就是 16ms这个数字的由来。

优化方案

具体到布局上,优化的核心无非就是 减少嵌套,避免过度绘制

使用相对布局或者约束布局,避免使用线性布局

其实使用“避免”这个词也不太妥当,毕竟每一种布局都有其存在的意义。但是 LinearLayout 这个布局确实使用起来局限性挺大。它只适合那种简单的行或者列的排布,稍微复杂一点的布局使用 LinearLayout 的话,嵌套层级简直惨不忍睹。复杂一点的布局使用 RelativeLayout 或者 ConstraintLayout 是比较好的选择。

尤其是 ConstraintLayout ,真的很好用,推荐。

使用抽象布局标签

抽象布局标签,指的是 include merge ViewStub 这几个标签。大家也已经很熟悉了,其作用就是 复用布局,减少嵌套,延迟加载 ,总之也是帮助优化布局。使用方法就不赘述了,网上介绍很多,自己试试就知道了。

避免在每个布局上都添加背景

我们布局的时候,往往喜欢顺手给布局添加一个背景。虽然这样做可以保证你的布局任何时候都和设计稿一样,但是 这样特别影响性能 。亲身经历,某页面非常卡顿,去掉了多余的 background ,就流畅很多。所以,请去掉不必要的 background 。 你可以 Activity 定义一个 Theme ,通过 Theme 定义背景

使用LinearLayoutCompat绘制分隔线

之前绘制线性布局的时候,往往需要给每一项之间绘制一个分隔线,我们往往都是直接加一个 ViewLinearLayoutCompat 带有一个 divider 属性,使用它就可以在布局中生成分隔线了。

这点是我在网上找到的,自己试了下,发现不生效。有可能是我的用法不太对吧。不过现在布局一般都用 ConstraintLayout 了,这个布局用到的场景也不多。

多使用Lint检查代码

这个就不用说了,跑一遍还是能发现蛮多问题的。关于布局的问题,主要集中在 Android -> Lint -> Performance 目录下,里边提到的问题要优先解决。另外,阿里代码规范也会检测出一些不规范的问题,也要注意一下。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Google御用網頁語言Node.js

Google御用網頁語言Node.js

郭家寶 / 佳魁資訊 / 2013-4-26 / NT 490

這是一本 Node.js 的入門教學,寫給想要學習 Node.js,但沒有任何系統的經驗的開發者。如果你聽說過 Node.js,並被它許多神奇的特性吸引,本書就是為你準備的。 透過閱讀本書,你可以對 Node.js 有全面的認識,學會如何用 Node.js 程式設計,了解事件驅動、非同步式 I/O 的程式設計模式,同時還可以了解一些使用JavaScript 進行函數式程式設計的方法。 ......一起来看看 《Google御用網頁語言Node.js》 这本书的介绍吧!

MD5 加密
MD5 加密

MD5 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具