【混合开发】Android+WebView视频图片播放硬件加速详解

webview视频播放出现白屏、蓝屏、花屏、黑屏等等

但由于布局结构是android+webview+H5+本地视频等。视频播放导致的异常排查起来十分复杂且没有原生的相关日志

于是需要给webview播放视频进行硬件加速,刚开始以为是一件很简单的配置而已。本着无经验从头开始的原则(虽然搞了十多年android开发)。从头查资料核实,结果发现还真有些不一样的说法和讲究。资料只是资料,实际效果还是要看设备运行情况

硬件加速配置

Application 级别(全局)

在 AndroidManifest.xml 的 节点加一行:

xml 复制代码
<application
    android:hardwareAccelerated="true"
    ... />

这个是常规配置,大家都知道

Activity 级别(单个界面)

xml 复制代码
<activity
    android:name=".YourActivity"
    android:hardwareAccelerated="true" />

这个是为了开启webView里的视频加速设置的,资料显示如果要在webView里进行硬件加速Application和Activity都需要配置这个。

Java 代码里动态打开,在 Activity.onCreate()早于 setContentView() 处写

java 复制代码
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
    getWindow().addFlags(WindowManager.LayoutParams.FLAG_HARDWARE_ACCELERATED);
}

针对某个 View 硬件加速(可选)

java 复制代码
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
    someView.setLayerType(View.LAYER_TYPE_SOFTWARE, null);
}

在14以上的API默认都是打开的,但是国内的手机厂家会做哪些骚操作并不确定,所以还是加上硬件加速配置比较好

注意事项

• 硬件加速默认在 Android 4.0(API 14)及以上自动开启,但 WebView 必须手动确认第 1 或第 2 步,否则会出现视频黑屏、Canvas 异常等问题。

• 运行时标志位(第 3 步)不能关闭硬件加速,只能检测或开启;如想关闭需回退到 Manifest 配置或 setLayerType--确认是否关闭

后记

事实上按以上配置后,实际效果并没有肉眼可见的改善,此方案只是基础支撑,但视频播放问题并不在硬件加速方面

好用的开发工具

推荐理由

postman在国内使用已经越来越困难:

1、登录问题严重

2、Mock功能服务基本没法使用

3、版本更新功能已很匮乏

4、某些外力因素导致postman以后能否使用风险较大

5、postman会导致电脑卡顿,而且使用的功能越多越慢,尤其是win电脑,太让人郁闷了

出于以上考虑因此笔者自己开发了一款api调试开发工具SmartApi,满足基本日常开发调试api需求

SmartApi

win版本不大于1M;运行消耗性能极低

macos 版本不大于100M;运行消耗性能极低

SmartApi只为开发服务

官网地址SmartApi

http://www.smartapi.site/


旧版本已停止维护

相关推荐
RainbowC02 小时前
从Dalvik字节码角度优化安卓编码
android·java/jvm
河铃旅鹿2 小时前
Android开发-java版:布局
android·笔记·学习
Meteors.3 小时前
安卓进阶——RxJava
android·rxjava
EasyCVR4 小时前
智能守护绿水青山:视频融合平台EasyCVR在森林防火监控中的实战应用
音视频
ACP广源盛139246256734 小时前
GSV1016/ACP#HDMI2.0 HDCP1.4 发射器(TTL/LVDS 输入 + 音频插入)技术解析
单片机·嵌入式硬件·音视频
卜锦元5 小时前
Mediasoup的SFU媒体服务转发中心详解(与传统SFU的区别)
音视频·webrtc·媒体
小影译片5 小时前
zmaiFy音频转录介绍
音视频
drsonxu5 小时前
Android开发自学笔记 --- 构建简单的UI视图
android·compose
ACP广源盛139246256735 小时前
GSV6505F---1 In to 4 Out HDMI 2.1 Splitter with Embedded MCU
单片机·嵌入式硬件·音视频
onthewaying6 小时前
在Android平台上使用Three.js优雅的加载3D模型
android·前端·three.js