当前位置: 首页 > news >正文

公司做网站一定要钱吗Wordpress 自用主题 免费 分享

公司做网站一定要钱吗,Wordpress 自用主题 免费 分享,电子商务这个专业怎么样,word做网站框架目录 uniform变量命名规范 获取 uniform 变量的存储地址 gl.getUniformLocation 向uniform变量赋值 gl.uniform4f ​编辑 gl.uniform4f()的同族函数 demo:点击webgl坐标系的四个象限绘制各自不同颜色的点 uniform变量命名规范 var FSHADER_SOURCE uniform vec4…

目录

uniform变量命名规范

获取 uniform 变量的存储地址 gl.getUniformLocation

向uniform变量赋值 gl.uniform4f

​编辑 gl.uniform4f()的同族函数

demo:点击webgl坐标系的四个象限绘制各自不同颜色的点


uniform变量命名规范

 

var FSHADER_SOURCE ='uniform vec4 u_FragColor;\n' + 'void main() {\n' +'  gl_FragColor = u_FragColor;\n' +'}\n';

着色器将 uniform 变量 u_FragColor 赋值给 gl_FragColor,后者直接决定点的颜色,向 uniform 变量传数据的方式与向 attribute 变量传数据相似:首先获取变量的存储地址,然后在JS程序中按照地址将数据传递过去

获取 uniform 变量的存储地址 gl.getUniformLocation

可以使用以下方法来获取uniform变量的存储地址。

 

 var u_FragColor = gl.getUniformLocation(gl.program, 'u_FragColor');if (!u_FragColor) {console.log('Failed to get the storage location of u_FragColor');return;}

这个函数的功能和参数与 gl.getAttribLocation() 一样,但是如果uniform变量不存在或者其命名使用了保留字前缀,那么函数的返回值将是null而不是-1(gl.getAttribLocation()在此情况下返回-1)。因此,在获取uniform变量的存储地址后,需要检查其是否为null

向uniform变量赋值 gl.uniform4f

有了uniform变量的存储地址,就可以使用WebGL函数 gl.uniform4f() 向变量中写入数据,该函数的功能和参数与 gl.vertexAttrib[1234]f() 类似

gl.uniform4f(u_FragColor, r, g, b, a);

 gl.uniform4f()的同族函数

gl.uniform4f()也有一系列同族函数。gl.uniform1f()函数用来传输1个值(v0),gl.uniform2f()传输2个值(v0和v1),gl.uniform3f()传输3个值(v0,v1和v2)。

demo:点击webgl坐标系的四个象限绘制各自不同颜色的点

 

var VSHADER_SOURCE ='attribute vec4 a_Position;\n' +'void main() {\n' +'  gl_Position = a_Position;\n' +'  gl_PointSize = 10.0;\n' +'}\n';var FSHADER_SOURCE ='precision mediump float;\n' +'uniform vec4 u_FragColor;\n' + 'void main() {\n' +'  gl_FragColor = u_FragColor;\n' +'}\n';function main() {var canvas = document.getElementById('webgl');var gl = getWebGLContext(canvas);if (!gl) {console.log('Failed to get the rendering context for WebGL');return;}if (!initShaders(gl, VSHADER_SOURCE, FSHADER_SOURCE)) {console.log('Failed to intialize shaders.');return;}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;}var u_FragColor = gl.getUniformLocation(gl.program, 'u_FragColor');if (!u_FragColor) {console.log('Failed to get the storage location of u_FragColor');return;}// 注册点击事件canvas.onmousedown = function(ev){ click(ev, gl, canvas, a_Position, u_FragColor) };gl.clearColor(0.0, 0.0, 0.0, 1.0);// Clear <canvas>gl.clear(gl.COLOR_BUFFER_BIT);
}var g_points = [];  // The array for the position of a mouse press
var g_colors = [];  // The array to store the color of a point
function click(ev, gl, canvas, a_Position, u_FragColor) {var x = ev.clientX; // x coordinate of a mouse pointervar y = ev.clientY; // y coordinate of a mouse pointervar rect = ev.target.getBoundingClientRect();x = ((x - rect.left) - canvas.width/2)/(canvas.width/2);y = (canvas.height/2 - (y - rect.top))/(canvas.height/2);// 将点存储到g_points数组中g_points.push([x, y]);// 将点的颜色存储到g_colors数组中if (x >= 0.0 && y >= 0.0) {      // 如果点在第一象限g_colors.push([1.0, 0.0, 0.0, 1.0]);  // 红色} else if (x < 0.0 && y < 0.0) { // 如果点在第三象限g_colors.push([0.0, 1.0, 0.0, 1.0]);  // 绿色} else {                         // 否则g_colors.push([1.0, 1.0, 1.0, 1.0]);  // 白色}// 每次绘制前必须显示清除gl.clear(gl.COLOR_BUFFER_BIT);var len = g_points.length;for(var i = 0; i < len; i++) {var xy = g_points[i];var rgba = g_colors[i];// 将点的位置传递给a_position变量gl.vertexAttrib3f(a_Position, xy[0], xy[1], 0.0);// 将点的颜色传递给u_FragColor变量gl.uniform4f(u_FragColor, rgba[0], rgba[1], rgba[2], rgba[3]);// Drawgl.drawArrays(gl.POINTS, 0, 1);}
}

 

 

http://www.yayakq.cn/news/521332/

相关文章:

  • 轻松建站淘宝请人做网站被骗
  • 昆山网站建设公司哪家好seo点击优化
  • 宁波市住房和城乡建设局网站首页众志seo
  • 资源下载类网站如何做外链wordpress cenos
  • 常州网站建设优质商家哪个网站做阿里首页模板
  • 道客网站建设推广小程序网站建设服务器选择
  • 做一个网站前端页面多少钱网站开发 自学
  • 手工做环保衣的网站做网站友汇网
  • 医院行业网站如何管理企业网站
  • 深圳网页网站设计手机版 pc 版本 网站 跳转 seo
  • 网站设计培训学校网页设计的毕业设计
  • 行业网站名称一对一优势的网络营销方式
  • 程序员给女盆友做的网站建设广告网站费用
  • 精品课程网站建设毕业设计论文下载百度app最新版到桌面
  • 成品网站5668入口的功能介绍如何做运营推广
  • 自己建服务类收费网站要多少钱网站推广方式都有哪些
  • 做网站要用多少钱厦门市集美区建设局网站
  • 网站建设 有聊天工具的吗上线了怎么做网站
  • 做网站域名重要吗网站模板 外贸工厂
  • 做徒步网站怎么样wordpress禁用媒体库
  • 做网站哪一家比较好wordpress创建登录页
  • 开发网站用什么语言最好吗旅游公司网站建设
  • 直播网站建设费用个人音乐网站源码搭建
  • 信誉比较好的商家可做网站英语网站大全免费
  • wordpress能大网站wordpress搬家 后台错乱
  • 有哪些网站开发技术共享充电宝app开发
  • 南宁市建设厅网站wordpress在哪下载模板
  • 青岛快速建站模板佛山网站推广优化公司
  • ftp网站后台茌平网站制作
  • 宿迁建设公司网站推广网站排名