网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

如何实现glsurfaceview播放视频代码-创新互联

这篇文章将为大家详细讲解有关如何实现glsurfaceview播放视频代码,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

成都创新互联是一家专业提供江南企业网站建设,专注与成都做网站、成都网站制作、成都h5网站建设、小程序制作等业务。10年已为江南众多企业、政府机构等服务。创新互联专业网站设计公司优惠进行中。

整个流程就是,创建一个GLSurfaceView用来装载视频,GLSurfaceView中设置renderer,自己自定义renderer,主要绘制流程都在这个,里面,主要有三个方法onSurfaceCreated(),onSurfaceChanged(),onDrawFrame()。

glsurfaceview播放视频代码

下面一段代码是初始化着色器代码,至于着色器里面的代码需要了解着色器语言

StringvertexShader=ShaderUtils.readRawTextFile(context,R.raw.vetext_sharder);

StringfragmentShader=ShaderUtils.readRawTextFile(context,R.raw.fragment_sharder);

programId=ShaderUtils.createProgram(vertexShader,fragmentShader);

aPositionLocation=GLES20.glGetAttribLocation(programId,"aPosition");

uMatrixLocation=GLES20.glGetUniformLocation(programId,"uMatrix");

uSTMMatrixHandle=GLES20.glGetUniformLocation(programId,"uSTMatrix");

uTextureSamplerLocation=GLES20.glGetUniformLocation(programId,"sTexture");

aTextureCoordLocation=GLES20.glGetAttribLocation(programId,"aTexCoord");

这一串代码是绑定纹理,设置mediaplayer每一帧作为纹理关联起来

glsurfaceview播放视频格式

textureId=textures[0];

GLES20.glBindTexture(GLES11Ext.GL_TEXTURE_EXTERNAL_OES,textureId);

ShaderUtils.checkGlError("glBindTexturemTextureID");

/*GLES11Ext.GL_TEXTURE_EXTERNAL_OES的用处?

之前提到视频解码的输出格式是YUV的(YUV420p,应该是),那么这个扩展纹理的作用就是实现YUV格式到RGB的自动转化,

关于“如何实现glsurfaceview播放视频代码”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


本文名称:如何实现glsurfaceview播放视频代码-创新互联
分享地址:http://bjjierui.cn/article/doidcc.html

其他资讯