WebGL编程指南案例解析之绘制三角形
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了WebGL编程指南案例解析之绘制三角形,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1843字,纯文字阅读大概需要3分钟。
内容图文
// 案例3.绘制三角形,将顶点数据存到缓冲区对象(gl.ARRAY_BUFFER)中,然后顶点着色器从里面读数据(3个顶点) // 顶点着色器中去掉gl_PointSize = 10.0,绘制三角不能设置顶点的大小 // gl.drawArrays(gl.TRIANGLES,0,n);第一个参数改为三角,因为此时不是绘制点了 var vShader = ` attribute vec4 a_Position; void main(){ gl_Position = a_Position; } `; var fShader = ` void main(){ gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0); } `; function main(){ //获取canvas元素var canvas = document.getElementById(‘webgl‘); //获取webgl上下文var gl = getWebGLContext(canvas); if(!gl){ console.log(‘Failed to get the rendering context for WebGL!‘); return; } //初始化着色器if(!initShaders(gl,vShader,fShader)){ console.log(‘Failed to initialize shaders.‘); return; } var n = initVertexBuffers(gl); if(n < 0){ console.log(‘Failed to set the positions of the vertices!‘); return; } //用指定颜色填充webgl容器,就是设置背景 gl.clearColor(0.4, 0.5, 0.0, 1.0); gl.clear(gl.COLOR_BUFFER_BIT); gl.drawArrays(gl.TRIANGLES,0,n); function initVertexBuffers(gl){ var vertices = new Float32Array([ 0.0,0.5,-0.5,-0.5,0.5,-0.5 ]); var n = 3;//点的个数 //创建缓冲区对象var vertexBuffer = gl.createBuffer(); if(!vertexBuffer){ console.log(‘Failed to create the buffer object!‘); return -1; } //将缓冲区对象绑定到目标ARRAY_BUFFER gl.bindBuffer(gl.ARRAY_BUFFER,vertexBuffer); //往ARRAY_BUFFER gl.bufferData(gl.ARRAY_BUFFER,vertices,gl.STATIC_DRAW); //获取shaderProgram中attribute变量‘a_Position’的地址var a_Position = gl.getAttribLocation(gl.program,‘a_Position‘); if (a_Position < 0) { console.log(‘Failed to get the storage location of a_Position‘); return -1; } //将缓冲区对象分配给a_Position变量 gl.vertexAttribPointer(a_Position,2,gl.FLOAT,false,0,0); //开启着色器对缓冲区数据的访问 gl.enableVertexAttribArray(a_Position); return n; } } main();
其实,绘制三角形和之前的绘制三个点的代码很相似,只是:
在顶点着色器里面,我们不能设置点的size了(gl_PointSize);
绘图函数将从gl.drawArrays(gl.POINTS,0,n)变成gl.drawArrays(gl.TRIANGLES,0,n);
效果如下:
原文:https://www.cnblogs.com/eco-just/p/10673736.html
内容总结
以上是互联网集市为您收集整理的WebGL编程指南案例解析之绘制三角形全部内容,希望文章能够帮你解决WebGL编程指南案例解析之绘制三角形所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。