发现自己的手机上某个界面出现了花屏,某些控件背景被拉伸过多遮住了其他控件,很难看。这种现象高概率出现,分析了下发现:一旦发生这种现象,必然会打印下面这种log,google了下,这种log应该是硬件加速引入的。在从view层级关闭了硬件加速开关之后,问题没有再出现。
D/OpenGLRenderer(10887): GL error from OpenGLRenderer: 0x501
E/OpenGLRenderer(10887): GL_INVALID_VALUE
硬件加速开关是android3.0开始引入的,大致有个印象,但是我们代码中并没有打开过硬件加速开关。自己写了个demo,log显示硬件加速开关确实已经被打开。看来是google做了些什么,去官方文档上看了看,有下面一句话:
Beginning with Android 4.0, hardware acceleration for all windows is enabled by default if your application has set either targetSdkVersion or minSdkVersion to “14" or higher.
到这里,硬件加速开关打开的原因找到了,为什么在这个应用的这个界面才会引入问题呢。
先学习下android硬件加速的一些概念再说。android自3.0引入了硬件加速,即使用GPU进行绘图,旨在得到更加平滑的动画更加平滑滚动,和更好的总体性能和响应用户的交互。但是硬件加速并不能完善的支持所有的绘图,通常表现为内容不可见,异常或渲染错误。一般出现了问题,就需要关闭硬件加速开关。为了方便控制硬件加速开关,android在四个层面提供了支持:
1.Application level:在AndroidManifes文件中给application标签增加如下配置语句,即可打开硬件加速开关,这个开关对整个应用起作用。
<application android:hardwareAccelerated="true" ...>
2.Activity level:同样还是在AndroidManifes文件中,给activity标签增加如下配置语句,即可关闭硬件加速开关,这个开关对当前activity起作用,可以覆盖1中的application开关:
<application android:hardwareAccelerated="true">
<activity ... />
<activity android:hardwareAccelerated="false" />
</application>
3.Window level:在代码中增加下面代码,即可在窗口级别打开硬件加速开关。注意在窗口级别,只能打开硬件加速开关,不能关闭,不同上面1,2。
getWindow().setFlags(
WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED,
WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED);
4.View level:在代码中给view设置如下属性,即可从view层级关闭硬件加速开关。在这里只能关闭硬件加速开关,不能打开。这个层面决定权是最高的,可以覆盖上面三个级别。
myView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
到这里还是不清楚为什么只有这个界面的view发生了问题。这个view不是应用覆盖重写的,并不复杂。看了下google后面提供的一些高效使用硬件加速开关的技巧:
Reduce the number of views in your application
Avoid overdraw
Don't create render objects in draw methods
Don't modify shapes too often
Don't modify bitmaps too often
后来打开android开发人员选项的检查是否过度绘制的功能,发现这个界面有很明显的过度绘制。到这里基本可以得出,这个界面由于打开硬件加速器高概率出现花屏,应该是违反了第二条:Avoid overdraw。去看了下google的Android Drawing Models说明,还是没有从根本上弄清楚硬件加速是怎么一个回事。没有从代码上看到这些总是感觉不太清楚,不过对于硬件加速了解到这里已经足够解决开发过程中遇到的问题。最后补充说明在分析上述的花屏问题时,发现将.9图片去掉换成普通资源,该问题也会得到修正。
分享到:
相关推荐
android硬件加速离线网页一份
使用硬件加速会让动画绘制的更快,因为硬件会把图层缓存在GPU上。 >用法 用法很简单关键方法是View.setLayerType() 1. 在开始动画时调用View.setLayerType(View.LAYER_TYPE_HARDWARE, null) 2. 运行...
Android开发模拟器加速器,让Android模拟器在PC下运行更加迅速!
android 模拟器加速器,安装了这个 模拟器打开的速度非常快
安卓在加载大图的时候经常会出现oom的错误,给大家分享我的一些处理经验。这个版本关闭了硬件加速。
主要介绍了理解Android硬件加速原理(小白文),详细的介绍了硬件加速的概念和原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
Android x86 的加速器 模拟器必须要安装,英特尔® 硬件加速执行管理器(英特尔® HAXM)是一款硬件辅助虚拟引擎(管理程序),可通过英特尔® 虚拟化技术 (VT) 来帮助提升在主机上进行 Android 应用模拟的速度。...
主要介绍了浅谈Android硬件加速原理与实现简介,本文尝试从底层硬件原理,一直到上层代码实现,对硬件加速技术进行简单介绍,感兴趣的小伙伴们可以参考一下
android基于linphone实现视频通话小结
Android2.2、2.3、4.0_中如何使用GPU硬件加速原理和游戏3D性能的提升 实现GPU渲染 介绍。
Android从3.0(API Level 11)开始,在绘制View的时候支持硬件加速,充分利用GPU的特性,使得绘制更加平滑,但是会多消耗一些内存。 开启或关闭硬件加速: 由于硬件加速自身并非完美无缺,所以Android提供选项来...
Android硬件抽象层从开发到使用有一个清晰的层次。这个层次恰好对应了Android系统的架构层次,它向下涉及到Linux内核,向上涉及到应用程序框架层的服务,以及应用程序层对它的使用。Android硬件抽象层模块的开发本身...
英特尔硬件加速器,如果你的Android SDk Manager无法下载Intel(x86) emulator accelerater,就下载这个吧
Android系统的图形本地框架硬件加速技术优化
AnyChat支持使用外部音视频编解码器,开放了内部API接口,在Android(或Linux)平台,可以通过该接口与硬件芯片的Codec进行集成,实现硬件加速。
1.3 小结 第2章 Android开发环境搭建 2.1 Android开发准备工作 2.2 开发包及其工具的安装和 配置 2.2.1 安装JDK和配置Java开发 环境 2.2.2 Eclipse的安装与汉化 2.2.3 SDK和ADT的安装和 配置 2.3 创建第一个Android...
用于加速Android模拟器的Intel组件,欢迎下载使用~