Android透明视频的实现(适用于直播间全屏礼物、弹屏广告等场景)

一、对于这样一个需求:
播放一个普通的视频,但是要求能看见视频下面的视图,也就是视频实现透明的功能
二、实现方法
1.简单方法:制作帧动画
2.网络开源:yy的svgaPlayer可以达到效果
三、方法比较
对于一个时长十秒的全屏幕动画效果,做出来的帧动画有5M之大,不忍直视,太大了,太大了,带宽也不便宜啊。
用svgaPlayer来播放,动画体积有很大改善,相同时长,效果的动画,大小只有500k左右,能接受,但是在使用的时候发现,内存占用很大,播放一次动画,内存增加了大概八十M,svga的包是由pb格式编码而来,大小上是有减小,但是客户端在播放的时候,还是要将很多位图解码出来,最终绘制到屏幕上的时候依旧会占用相当多的内存,另外解码之后产生了一大串的产物,一堆动画帧的实体,这通过studio的profile工具是可以检测出来的。
四、视频实现
1.先想想几个问题:
1)有没有包含透明通道的视频,有哪些格式
2)包含了透明通道的视频体积是否会增加
3)Android平台是否支持播放含有透明通道的视频
通过调研发现,是有支持透明通道的视频格式的,具体参见:[https://developer.android.com/guide/topics/media/media-formats]
具体的编码方式和文件格式是
VP8/VP9 + mkv
VP8/VP9 + webm
我们发现,支持透明通道的视频文件的体积增加了不少,并且Android平台原生是不支持播放的
2.实现原理
1).通过原始mp4文件保留原始的RGB信息,使用另一个相同大小的文件保留视频的alpha信息,原始视频对应的像素是完全透明的的话,对应的这个视频的点就是白色的,完全不透明的对应的就是黑色的,半透明的对应就是灰色的。
2).使用工具将两个视频左右拼接
3).使用系统mediaPlayer解码mp4文件,使用opengles渲染出视频画面,目标像素的RGB使用原始视频的RGB分量,A使用黑白视频对应像素的alpha分量
3.实现
1)透明视频的制作
a.设计师通过设计工具先设计好原始视频,当然是有透明效果啦
b.通过工具生成一个和原始视频相同分辨率的黑白视频
ffmpeg -i origin.mp4 -vf lutyuv="u=128:v=128" output.mp4
c.通过工具将两个视频左右拼接好
ffmpeg -re -i left.mp4 -re -i right.mp4 -filter_complex "nullsrc=size=1500x1400 [base]; [0:v] scale=750x1400 [left]; [1:v] scale=750x1400 [right]; [base][left] overlay=shortest=1 [tmp1]; [tmp1][right] overlay=shortest=1:x=750" -c:v libx264 -pix_fmt yuv420p -movflags faststart -f mp4 left_right.mp4

2)视频渲染
使用opengl播放视频,这个网上的讲解和例子非常多,这里就略过,直接进入关键处理,也就是两个着色器的部分,
private final String fragmentShader = "#extension GL_OES_EGL_image_external : require\n"
+ "precision mediump float;\n"
+ "varying vec2 v_texcoord;\n"
+ "uniform samplerExternalOES sTexture;\n"
+ "void main() {\n"
+ " gl_FragColor = vec4(texture2D(sTexture, v_texcoord).rgb, texture2D(sTexture, " +
"v_texcoord + vec2(-0.5, 0)).r);\n"
+ "}\n";
这里就是透明视频的还原部分了,拿到原始视频的RGB,和黑白视频的r分量作为最终像素点的alpha的分量,组合好ARGB,渲染到屏幕就可以了。
五:总结
使用视频方案做出来的视频素材作为全屏动画有诸多好处:
1)体积小,相对于原来的几M减小到几百k,有利于节省带宽资源
2)性能好,使用系统播放器解码mp4,使用opengl来渲染,性能比其他方案要好很多,虽然播放的时候cpu使用会升一些,但是相对内存的飙升还是值得的
3)兼容性好,使用视同播放器和opengl,基本不用考虑适配的问题
4)对设计师友好,使用AE工具很容易制作动画,并且也有工具制作出左右对称的目标视频
但是也有一些值得注意的地方:
分辨率的限制,毕竟最终视频的分辨率是原始的两倍,所以在系统解码的时候,是需要考虑到限制的,系统在解码时有最大分辨率限制,超过最大限制,自然就无法解码,系统将跑出异常,所以视频需要考虑不同机型的分辨率,按需加载。

demo:https://github.com/mc2012/AndroidTransparentVideo

参考:http://dopro.io/animation-solution-alpha-video.html?replytocom=9

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容