代码拉取完成,页面将自动刷新
同步操作将从 子龙山人/Learning-WebGL 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
function createGLContext(canvasId)
{
var canvas = document.getElementById(canvasId);
var names = ["webgl",
"experimental-webgl",
"webkit-3d",
"moz-webgl"];
var gl;
for (var i = 0; i < names.length; ++i)
{
try
{
gl = canvas.getContext(names[i]);
}
catch(e)
{
throw("contex can't be created!");
}
if (gl) break;
}
if (gl == null){
alert("WebGL is not available");
}
return gl;
}
function createShader(gl, str, type){
var shader = gl.createShader(type);
gl.shaderSource(shader,str);
gl.compileShader(shader);
if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {
throw gl.getShaderInfoLog(shader);
}
return shader;
}
function createProgram(gl, vstr,fstr){
var program = gl.createProgram();
var vshader = createShader(gl,vstr,gl.VERTEX_SHADER);
var fshader = createShader(gl, fstr, gl.FRAGMENT_SHADER);
gl.attachShader(program,vshader);
gl.attachShader(program,fshader);
gl.linkProgram(program);
if (!gl.getProgramParameter(program, gl.LINK_STATUS)) {
throw gl.getProgramInfoLog(program);
}
return program;
}
function createProgramFromElementId(gl, vertexId, fragmentId)
{
var vertex = document.getElementById(vertexId);
var fragment = document.getElementById(fragmentId);
return createProgram(gl,vertex.text, fragment.text);
}
function setupRectangle(gl, x, y , width, height){
var x1 = x;
var x2 = x + width;
var y1 = y;
var y2 = y + height;
gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
x1,y1,
x2,y1,
x1,y2,
x1,y2,
x2,y2,
x2,y1
]), gl.STATIC_DRAW);
}
function randomInt(range){
return Math.floor(Math.random() * range);
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。