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

glsl着色器学习(三)

前面两篇文章已经创建好了顶点着色器和片段着色器并编译成功,下面将创建program(程序),将着色器链接起来

创建Program
const prg = gl.createProgram();
gl.attachShader(prg, vertexShader);
gl.attachShader(prg, fragmentShader);
gl.linkProgram(prg);
if (!gl.getProgramParameter(prg, gl.LINK_STATUS)) {
  throw new Error(gl.getProgramInfoLog(prg))
};
  1. const prg = gl.createProgram();
    1. 使用Webgl的createProgram创建一个程序对象。这个程序对象包涵一个顶点着色对象和一个片段着色器对象,用于图形渲染。
    2. 如图,生成了一个prg对象。属性都为空。
    3. 此时,程序对象和顶点着色器对象以及片段着色器对象还没有关联起来
  2. gl.attachShaer(prg,vertexShader);
    1. 将之前创建并编译好的顶点着色器(vertexShader)附加到新创建的着色器程序对象(prg)上。
    2. 关联顶点着色器
  3. gl.attachShader(prg,fragmentShaer);
    1. 将之前创建并编译好的片段着色器(fragmentShader)附加到新创建的着色器程序对象(prg)上。这样,在后续的链接操作中,WebGL 会将这两个着色器组合成一个完整的渲染程序。
    2. 关联fragmentShader。
  4. gl.linkProgram(prg);
    1. 对附加了顶点着色器和片段着色器的程序对象进行链接操作。链接的过程会检查两个着色器之间的接口是否匹配,例如顶点着色器输出的变量是否能正确地被片段着色器接收等。同时,链接操作还会生成最终可在图形硬件上执行的程序代码。
  5. if (!gl.getProgramParameter(prg, gl.LINK_STATUS)) {... }
    1. 检查着色器程序的链接状态。如果gl.getProgramParameter返回的链接状态为false,则表示链接失败,此时会抛出一个错误,错误信息为通过gl.getProgramInfoLog(prg)获取的链接错误日志。
    2. link成功后的状态。

http://www.kler.cn/a/290419.html

相关文章:

  • ESLint 使用教程(七):ESLint还能校验JSON文件内容?
  • Android OpenGL ES详解——纹理:纹理过滤GL_NEAREST和GL_LINEAR的区别
  • wordpress搭建主题可配置json
  • Python酷库之旅-第三方库Pandas(208)
  • 准确--FastDFS快速单节点部署
  • AI大模型:重塑软件开发流程的优势、挑战及应对策略
  • 随时随地远程启动家里设备,极空间部署一键网络唤醒工具『UpSnap』
  • C++ 消息分发类:详细示例应用
  • Python 数据分析笔记— Numpy 基本操作(上)
  • zdppy_cache缓存框架升级,支持用户级别的缓存隔离,支持超级管理员管理普通用户的缓存
  • 【MySql】面试问答:在使用mysql时,遇到分页查询慢的情况怎么处理?
  • 观测云核心技术解密:eBPF Tracing 实现原理
  • Java项目:137 springboot基于springboot的智能家居系统
  • 1. 深度学习基础:从神经网络到深度学习
  • CSS系列之浮动清除clear(三)
  • ztree搜索结果高亮变颜色(非highlight属性)
  • upload文件上传靶场
  • 在react中用three.js 渲染模型 在上面创建标签
  • 传统CV算法——基于opencv的答题卡识别判卷系统
  • 【大数据】Java与Python的无缝对接:探讨Java调用Python的方法与原理
  • <数据集>车辆识别数据集<目标检测>
  • 你必须知道的C语言问题(8)
  • Go 中间件学习
  • 【CanMV K230】边缘检测
  • 羊大师:白露养生经,羊奶不可少
  • docker实战基础一 (Docker基础命令)