我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android的UI调优教程

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android的UI调优教程

对于一个App的UI而言,在流畅性上的改进目标其实就是降低屏幕绘制的延迟,创建流畅和稳定的帧率以避免卡顿。

在理想情况下,全部的测量、布局和绘制的时间最好在16ms以内,这样才能保证屏幕运行的顺畅性。而如何对屏幕渲染和UI性能进行评估和分析呢,在Android SDK中集成了一些工具用来策略APP的渲染性能问题。

一、视图的层级分析:

对于每一个视图而言,都需要经过三个步骤:测量、布局和渲染。而App如何绘制视图,它需要从顶部节点开始测量,沿着布局树逐个渲染,视图树的层级越多,嵌套测量的次数越多,测量的时间也会越长。而一旦测量完毕就会进行布局,每个视图都会对自己的子视图进行布局,子视图布局完毕后回到父视图,然后再到根视图,布局完成后,每个视图都会被绘制在屏幕上。

显然,App的视图越多,层级越深就需要越长的时间测量、布局和绘制,为了减少这些时间,需要尽可能保持视图层级的扁平化并删除所有没有必要渲染的视图。

虽然在XML布局文件中可以查看布局的节点视图,单很难找到多余的视图,为了找到这些多余的视图,可以利用Android Studio中的Hierarchy Viewer工具来分析Android App中的视图。

Hierarchy Viewer(层次结构查看器)能够便捷地以可视化方式查看各种视图嵌套关系,可用于研究XML视图结构。(需要一个运行Android App的设备)

利用这个工具可以查看我们的View的层次,从而借助它修改我们的布局。

一般的建议:

使用抽象布局标签(include, viewstub, merge)主要是为了优化布局,去除不必要的嵌套和View节点。

  • 视图重用

多用于ListView和RecylerView等列表形式

  • 使用include嵌套布局,实现布局的模块化设计,这里需要考虑到下面谈到的merge标签的使用。
  • <merge>标签

在使用了include后可能导致布局嵌套过多,多余不必要的layout节点,从而导致解析变慢,不必要的节点和嵌套可通过hierarchy viewer或设置->开发者选项->显示布局边界查看。merge标签在UI的结构优化中起着非常重要的作用,它可以删减多余的层级,优化UI。 
merge多用于替换FrameLayout或者当一个布局包含另一个时,merge标签消除视图层次结构中多余的视图组。

merge标签可用于两种典型情况: 
a. 布局顶结点是FrameLayout且不需要设置background或padding等属性,可以用merge代替,因为Activity内容视图的parent view就是个FrameLayout,所以可以用merge消除只剩一个。 
b. 某布局作为子布局被其他布局include时,使用merge当作该布局的顶节点,这样在被引入时顶结点会自动被忽略,而将其子节点全部合并到主布局中。

<ViewStub>

viewstub标签同include标签一样可以用来引入一个外部布局,不同的是,viewstub引入的布局默认不会扩张,即既不会占用显示也不会占用位置,从而在解析layout时节省cpu和内存。 
viewstub常用来引入那些默认不会显示,只在特殊情况下显示的布局,如进度布局、网络失败显示的刷新布局、信息出错出现的提示布局等。

比如说,假设network_error.xml为只有在网络错误时才需要显示的布局,默认不会被解析。 
当我们要使用的时候,有两种方法可以使用,效果是一样的:

((ViewStub) findViewById(R.id.layout_error)).setVisibility(View.VISIBLE); 

// 或者

View importPanel = ((ViewStub) findViewById(R.id.layout_error)).inflate(); 

二、资源缩减

第一点提到的是将App的视图结构变扁平,减少视图的数量后,其实我们还可以尝试减少每个视图里使用的资源数量。(如加载时引用一个资源,在运行时进行着色)

三.屏幕的过度绘制

屏幕的过度绘制这个概念有点类似于PhotoShop中的图层的概念,上面的图层会覆盖住下面的图层,而使得下面的图层不可见。当Android系统绘制屏幕时,首先绘制父视图而后是子视图,子视图位于其父视图上。

重绘屏幕的行为被称为过度绘制,多次的屏幕绘制会增加延迟,并且可以导致布局卡顿。

既然过度绘制的影响那么大,我们应该怎么检测呢?

Android提供了一些很好的工具来检测过度绘制,而一般采用的方式是在Debug GPU Overdraw菜单中选择“Show Overdraw area”,(在本人手机中为开发者选项中的调试GPU过度绘制),选择之后会在App的不同区域覆盖不同的颜色来表示过度绘制的次数。比较屏幕上的这些不同颜色,可以快速定位问题。

白色:没有过度绘制

蓝色:1次过度绘制(屏幕绘制了2次)

绿色:2次过度绘制

浅红色:3次过度绘制

深红色:4次或更多次过度绘制

而另外一种查看方法是借助于前面提到的Hierarchy Viewer工具,将view hierarchy保存为Photoshop文档,打开这些视图后可以看到不同层次的过度绘制情况。

四、分析卡顿(策略GPU的渲染能力)

在优化视图的层次结构和过度绘制后,App还存在丢帧或者不流畅的情况,为了获得获得更加全面的卡顿检测信息,Android系统中有一个Profile GPU Rendering的开发者选项,它能够检测出每一帧在屏幕上用了多久,策略数据可以保存到日志文件中,或者在设备上实时显示。一般而言,在屏幕上直接展示GPU的渲染数据能够更加直观地看到。

在本人的手机中,在开发者选项中找到【GPU呈现模式分析】,选择【在屏幕上显示为条形图】,然后打开一个手机QQ,就发现如下图所示情况

需要关注的是底部的那一条水平绿线,它表示设备渲染一帧要16ms,每一帧就是一个水平条,如果有很多帧超过了这条绿线就说明设备出现了卡顿情况。

五、让它看起来更快

前面讲到了如果通过测试发现问题优化布局使得UI绘制更加流畅,其实还有一个方法使得UI绘制更快:让它看起来更快。

  • 进度条
  • 动画
  • 即时更新:指用户更新了一个页面后,页面上的数据就会立刻发生变化,即使数据还没有达到服务器(这里需要确定这些数据最终一定可以更新到服务器)(离线上传,离线发送网络请求)

或者是另外一种思路,在用户添加有关图片帖子的文字时提前上传图片到服务器。

以上就是Android的UI调优教程的详细内容,更多关于Android UI调优的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android的UI调优教程

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android的UI怎么调优

这篇文章主要讲解了“Android的UI怎么调优”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android的UI怎么调优”吧!一、视图的层级分析:对于每一个视图而言,都需要经过三个步骤:测
2023-06-29

android开发教程之handler异步更新ui

其实文字游戏程序很简单,就是一个view和一个Activity,在利用下handier和postInvalidate()更新UI 调用Handler.post(Runnable r)方法,Runnable运行在UI所在线程,所以可以直接调用
2022-06-06

Android中使用GridView进行应用程序UI布局的教程

0.简介 GridView 和 ListView 有共同的父类:AbsListView,因此 GridView 和 ListView 具有一定 的相似性。GridView与ListView的主要区别在于:ListView只是在一个方向上分布
2022-06-06

Android远程服务编写和调用教程

网上汗牛充栋的文章都是介绍Android远程服务的,一个个将Binder机制、AIDL讲得头头是道,然而没有几个人能够给出清晰的范例说明如何用最快的方法学会编写和调用一个Android远程服务。若你仅仅是想如何编写或者调用Android的远
2022-06-06

Android数据结构优化教程

这篇文章主要介绍了Android数据结构优化方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
2023-01-31

Android App开发的自动化测试框架UI Automator使用教程

Android的自动化测试有很多框架,其中ui automator是google官方提供的黑盒UI相关的自动化测试工具,(GitHub主页:case使用java写,今天实践了一下官方文档中样例程序,其中还是有一些小问题需要总结一下的。 环境
2022-06-06

Android异步回调中的UI同步性问题分析

Android程序编码过程中,回调无处不在。从最常见的Activity生命周期回调开始,到BroadcastReceiver、Service以及Sqlite等。Activity、BroadcastReceiver和Service这些基本组件
2022-06-06

解析Android开发优化之:对界面UI的优化详解(一)

通常,在这个页面中会用到很多控件,控件会用到很多的资源。Android系统本身有很多的资源,包括各种各样的字符串、图片、动画、样式和布局等等,这些都可以在应用程序中直接使用。这样做的好处很多,既可以减少内存的使用,又可以减少部分工作量,也可
2022-06-06

解析Android开发优化之:对界面UI的优化详解(二)

如果我们在每个xml文件中都把相同的布局都重写一遍,一个是代码冗余,可读性很差;另一个是修改起来比较麻烦,对后期的修改和维护非常不利。所以,一般情况下,我们需要把相同布局的代码单独写成一个模块,然后在用到的时候,可以通过
2022-06-06

解析Android开发优化之:对界面UI的优化详解(三)

有时候,我们的页面中可能会包含一些布局,这些布局默认是隐藏的,当用户触发了一定的操作之后,隐藏的布局才会显示出来。比如,我们有一个Activity用来显示好友的列表,当用户点击Menu中的“导入”以后,在当前的Activity中才会显示出一
2022-06-06

Android 子线程 UI 操作真的不可以?

我们知道Android编码规范在要求子线程不能操作UI,但一定是这样吗?通过我们的优化,我们可以达到最终达成完美的效果,动效流畅,互不干涉。

Win8系统关闭UI中的App应用的教程

Windows8系统如何关闭UI中的App。 1、在打开的App中使用Alt+F4快捷键可以关闭 2、将鼠标移动到屏幕左上角,在打开的App上右键,选择”关闭”;3、使用Ctrl+Shift+Esc快捷键调用&rdq
2022-06-04

服务器调优入门教程:从基础到精通,轻松掌握调优技巧

服务器调优是优化服务器性能和稳定性的过程,包括硬件调优和软件调优。硬件调优包括选择合适的服务器硬件、配置合适的内存和硬盘、优化网络连接等。软件调优包括优化操作系统、优化应用程序、优化数据库等。
服务器调优入门教程:从基础到精通,轻松掌握调优技巧
2024-02-07

Android编程UI设计之GridView和ImageView的用法

本文实例讲述了Android编程UI设计之GridView和ImageView的用法。分享给大家供大家参考,具体如下: GridView: A view that shows items in two-dimensional scrolli
2022-06-06

Android开发教程之调用摄像头功能的方法详解

本文实例讲述了Android调用摄像头功能的方法。分享给大家供大家参考,具体如下: 我们要调用摄像头的拍照功能,显然 第一步必须加入调用摄像头硬件的权限,拍完照后我们要将图片保存在SD卡中,必须加入SD卡读写权限,所以第一步,我们应该在An
2022-06-06

从新手到专家:数据库性能调优教程

数据库性能调优是一门技术,它需要对数据库的结构、索引、查询语句等进行优化,以提高数据库的运行速度和效率。本文将从新手到专家,详细讲解数据库性能调优的技巧和方法,帮助您提高数据库的性能。
从新手到专家:数据库性能调优教程
2024-02-13

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录