1 Star 0 Fork 0

shark-dynamics/web_video_player

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
renderer_webgl.js 3.17 KB
一键复制 编辑 原始数据 按行查看 历史
hy 提交于 2022-12-28 17:19 +08:00 . modify player
class WebGLRenderer extends Renderer {
#canvas = null;
#context = null;
static vertexShaderSource = `
attribute vec2 inXY;
attribute vec2 inUV;
varying highp vec2 uv;
void main(void) {
gl_Position = vec4(inXY.x, inXY.y * -1.0, 0.0, 1.0);
uv = inUV;
}
`;
static fragmentShaderSource = `
varying highp vec2 uv;
uniform sampler2D texture;
void main(void) {
gl_FragColor = texture2D(texture, uv);
}
`;
constructor(type, canvas) {
super(type);
this.#canvas = canvas;
const gl = this.#context = canvas.getContext(type);
const vertexShader = gl.createShader(gl.VERTEX_SHADER);
gl.shaderSource(vertexShader, WebGLRenderer.vertexShaderSource);
gl.compileShader(vertexShader);
if (!gl.getShaderParameter(vertexShader, gl.COMPILE_STATUS)) {
throw gl.getShaderInfoLog(vertexShader);
}
const fragmentShader = gl.createShader(gl.FRAGMENT_SHADER);
gl.shaderSource(fragmentShader, WebGLRenderer.fragmentShaderSource);
gl.compileShader(fragmentShader);
if (!gl.getShaderParameter(fragmentShader, gl.COMPILE_STATUS)) {
throw gl.getShaderInfoLog(fragmentShader);
}
const shaderProgram = gl.createProgram();
gl.attachShader(shaderProgram, vertexShader);
gl.attachShader(shaderProgram, fragmentShader);
gl.linkProgram(shaderProgram);
if (!gl.getProgramParameter(shaderProgram, gl.LINK_STATUS)) {
throw gl.getProgramInfoLog(shaderProgram);
}
gl.useProgram(shaderProgram);
// Vertex coordinates, clockwise from bottom-left.
const vertexBuffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, vertexBuffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
-1.0, -1.0,
-1.0, +1.0,
+1.0, +1.0,
+1.0, -1.0
]), gl.STATIC_DRAW);
const xyLocation = gl.getAttribLocation(shaderProgram, "inXY");
gl.vertexAttribPointer(xyLocation, 2, gl.FLOAT, false, 0, 0);
gl.enableVertexAttribArray(xyLocation);
//
const uvBuffer = gl.createBuffer();
gl.bindBuffer(gl.ARRAY_BUFFER, uvBuffer);
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
0.0, 0.0,
0.0, 1.0,
1.0, 1.0,
1.0, 0.0
]), gl.STATIC_DRAW);
let uvLocation = gl.getAttribLocation(shaderProgram, "inUV");
gl.vertexAttribPointer(uvLocation, 2, gl.FLOAT, false, 0, 0);
gl.enableVertexAttribArray(uvLocation);
const texture = gl.createTexture();
gl.bindTexture(gl.TEXTURE_2D, texture);
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MAG_FILTER, gl.NEAREST);
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_MIN_FILTER, gl.NEAREST);
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_S, gl.CLAMP_TO_EDGE);
gl.texParameteri(gl.TEXTURE_2D, gl.TEXTURE_WRAP_T, gl.CLAMP_TO_EDGE);
}
render(frame) {
super.render(frame);
let factor = this.chromeWidth * 1.0 / frame.displayWidth;
this.#canvas.width = frame.displayWidth * factor;
this.#canvas.height = frame.displayHeight * factor;
const gl = this.#context;
gl.texImage2D(gl.TEXTURE_2D, 0, gl.RGBA, gl.RGBA, gl.UNSIGNED_BYTE, frame);
frame.close();
gl.viewport(0, 0, gl.drawingBufferWidth, gl.drawingBufferHeight);
gl.clearColor(1.0, 0.0, 0.0, 1.0);
gl.clear(gl.COLOR_BUFFER_BIT);
gl.drawArrays(gl.TRIANGLE_FAN, 0, 4);
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/shark-dynamics/web_video_player.git
git@gitee.com:shark-dynamics/web_video_player.git
shark-dynamics
web_video_player
web_video_player
master

搜索帮助