首页 > 其他分享 >【WebGL系列-02】创建program上下文

【WebGL系列-02】创建program上下文

时间:2023-07-24 13:46:48浏览次数:33  
标签:02 对象 WebGL shader program WebGLRenderingContext gl 着色器

WebGL程序program对象的创建

program对象由顶点着色器对象片元着色器对象构成,因此,创建program对象包含了两部分,一个是着色器对象的创建,一个是program对象的创建。

总体流程

  1. 创建顶点着色器对象
  2. 创建片元着色器对象
  3. 创建program对象
  4. 将顶点着色器和片元着色器添加到程序中
  5. 将程序链接到webgl上下文
  6. 使用创建的program对象

着色器对象的创建

着色器对象的创建包含三步:

  1. 创建着色器对象
  2. 将着色器源码送入对象
  3. 编译着色器

代码实现

/**
 * 创建shader对象
 * @param {*} gl webgl上下文对象
 * @param {*} type 创建的shader的类型,顶点着色器为gl.VERTEX_SHADER,片元着色器为gl.FRAGMENT_SHADER
 * @param {*} source glsl源码
 */
function loadShader(gl, type, source) {
  // 创建shader
  const shader = gl.createShader(type);
  // 将glsl源码送入shader对象
  gl.shaderSource(shader, source);
  // 编译shader
  gl.compileShader(shader);

  // 检查shader是否编译成功
  if (!gl.getShaderParameter(shader, gl.COMPILE_STATUS)) {
    alert("编译shader时发生错误:" + gl.getShaderInfoLog(shader));
    // 编译失败,删除shader
    gl.deleteShader(shader);
    return null;
  }

  return shader;
}

接口

WebGLShader WebGLRenderingContext.createShader(type)

创建一个Shader对象

  • type:为WebGLRenderingContext.VERTEX_SHADERWebGLRenderingContext.FRAGMENT_SHADER中的一个,表示创建的是顶点着色器还是片元着色器

void WebGLRenderingContext.shaderSource(WebGLShader shader, string source)

设置WebGLShader着色器对象的GLSL代码

  • shader:用于设置程序代码的WebGLShader
  • source:包含glsl程序代码的字符串

void WebGLRenderingContext.compileShader(WebGLShader shader)

编译GLSL着色器,使其称为一个二进制数据,然后被WebGLProgram所使用

  • shader:WebGLShader,顶点着色器或片元着色器

Object WebGLRenderingContext.getShaderParameter(WebGLShader shader, pname)

返回给定的着色器信息

  • shader:需要获取信息的着色器对象
  • pname:指定要查询的信息的属性名称,可以是以下值:
    • WebGLRenderingContext.DELETE_STATUS:标识着色器是否被删除,删除GL_TRUE,未删除GL_FALSE
    • WebGLRenderingContext.COMPILE_STATUS:标识着色器是否编译成功,成功GL_TRUE,不成功GL_FALSE
    • WebGLRenderingContext.SHADER_TYPE:标识着色器的类型
      • WebGLRenderingContext.VERTEX_SHADER:顶点着色器
      • WebGLRenderingContext.FRAGMENT_SHADER:片元着色器

Object WebGLRenderingContext.getShaderInfoLog(WebGLShader shader)

获取着色器的信息日志,包含警告、debug和编译信息

  • shader:需要获取信息的着色器对象

void WebGLRenderingContext.deleteShader(WebGLShader shader)

删除参数提供的shader对象,如果该对象已经被删除,这个方法无效

  • shader:需要删除的shader对象

DOMString WebGLRenderingContext.getShaderSource(shader)

以DOMString的形式返回shader的源码

  • shader:WebGLShader,要获取源码的shader

创建着色器程序对象

创建着色器程序对象需要四步:

  1. 创建program对象
  2. 将着色器程序与着色器对象绑定
  3. 将上下文链接到着色器程序
  4. 使用着色器程序

代码实现

/**
 * 初始化着色器程序
 * @param {*} gl webgl上下文
 * @param {*} vsSource 顶点着色器源码字符串
 * @param {*} fsSource 片元着色器源码字符串
 */
function initShaderProgram(gl, vsSource, fsSource) {
  // 创建着色器对象
  const vertexShader = loadShader(gl, gl.VERTEX_SHADER, vsSource);
  const fragmentShader = loadShader(gl, gl.FRAGMENT_SHADER, fsSource);

  // 创建着色器程序
  const shaderProgram = gl.createProgram();
  // 将着色器程序与shader绑定
  gl.attachShader(shaderProgram, vertexShader);
  gl.attachShader(shaderProgram, fragmentShader);
  
  // 将上下文链接到着色器程序
  gl.linkProgram(shaderProgram);

  // gl.validateProgram(shaderProgram);

  // 检查着色器程序是否创建成功
  if (!gl.getProgramParameter(shaderProgram, gl.LINK_STATUS)) {
    alert("初始化着色器程序错误:" + gl.getProgramInfoLog(shaderProgram));
    // 如果创建失败,则删除着色器对象和着色器程序对象
    gl.deleteProgram(shaderProgram);
    gl.deleteShader(vertexShader);
    gl.deleteShader(fragmentShader);

    return null;
  }

  // 使用着色器程序
  gl.useProgram(shaderProgram);

  return shaderProgram;
}

接口

WebGLProgram WebGLRenderingContext.createProgram()

初始化一个WebGLProgram对象


void WebGLRenderingContext.attachShader(program, shader)

向WebGLProgram中添加一个着色器

  • program:WebGLProgram对象
  • shader:WebGLShader对象

void WebGLRenderingContext.linkProgram(program)

链接给定的WebGLProgram,完成为程序的片元顶点着色器准备GPU代码的过程

  • program:WebGLProgram,指定的着色器程序

Object WebGLRenderingContext.getProgramParameter(program, pname)

返回program的信息

  • program:指定的program
  • pname:Glenum,可以是以下类型:
    • WebGLRenderingContext.DELETE_STATUS:GLboolean,是否被删除
    • WebGLRenderingContext.LINK_STATUS:GLboolean,是否成功地链接
    • WebGLRenderingContext.VALIDATE_STATUS:GLboolean,最后一次验证操作是否成功
    • WebGLRenderingContext.ATTACHED_SHADERS:GLint,返回添加的着色器的数量,之后可以使用WebGLRenderingContext.getAttachedShaders()获取这些shader
    • WebGLRenderingContext.ACTIVE_ATTRIBUTES:GLint,返回shader中激活的attribute变量的数量,之后可以使用WebGLRenderingContext.getActiveAttrib()方法获取这些变量
    • WebGLRenderingContext.ACTIVE_UNIFORMS:GLint,返回shader中激活的uniform变量的数量,之后可以使用WebGLRenderingContext.getActiveUniform()方法获取这些变量
    • WebGLRenderingContext.TRANSFORM_FEEDBACK_BUFFER_MODE [ WebGL2 only ]:GLenum,返回transform feedback激活时的buffer mode
      • WebGLRenderingContext.SEPARATE_ATTRIBS
      • WebGLRenderingContext.INTERLEAVED_ATTRIBS
    • WebGLRenderingContext.TRANSFORM_FEEDBACK_VARYINGS [ WebGL2 only ]:GLint,indicating the number of varying variables to capture in transform feedback mode
    • WebGLRenderingContext.ACTIVE_UNIFORM_BLOCKS [ WebGL2 only ]:GLint, indicating the number of uniform blocks containing active uniforms.

Object WebGLRenderingContext.getProgramInfoLog(program)

获取program中的信息,包括在link中的错误以及合法性的检查

  • program:WebGLProgram对象

void WebGLRenderingContext.deleteProgram(program)

删除一个program,如果已经删除,则不会产生任何效果

  • program:WebGLProgram,需要删除的program

void WebGLRenderingContext.useProgram(program)

将定义好的program对象添加到当前的渲染状态中

  • program:WebGLProgram对象

void WebGLRenderingContext.validateProgram(program)

检查program是否链接成功,同时检查能否在当前webgl中使用

注意一点,在WebGLProgram对象创建成功后,加入的WebGLShader对象就没有用了,可以调用deleteShader将其删除,防止占用内内存

标签:02,对象,WebGL,shader,program,WebGLRenderingContext,gl,着色器
From: https://www.cnblogs.com/masakulayou/p/17576995.html

相关文章

  • 【WebGL系列-03】获取shader变量地址及赋值
    获取shader变量地址及赋值上一节创建了WebGL程序对象,创建好program对象后,对象中包含顶点着色器和片元着色器,着色器中含有变量,我们需要对其进行赋值后才能够进行绘制。着色器代码如下:constVSHADER_SOURCE=/*glsl*/`attributevec4a_Position;voidmain(){gl_P......
  • 【WebGL系列-04】清除缓冲区并绘制图形
    清除缓冲区并绘制图形前文中已经准备好了webgl程序和绘制所用的数据,但是在绘制图像之前,还要对画布进行处理。清除缓冲区由于图像的绘制是一帧一帧绘制,每一帧针对当前的状态,计算屏幕上每个像素的颜色,得到最终的绘制结果。这些状态被保存在一个叫帧缓冲区的地方。帧缓冲区不仅能......
  • vs2022使用cocos2d-x4.0创建新项目
    cocos源码编译方法:cocos2d-x-4.0.zip解压到如:E:\cocos2d-x-4.0, 进入目录运行下setup.py设置cocos环境变量(这个要python2.x,要先安装python)创建个目录,如win32-build,进入win32-build,运行cmd,然后再运行cmake(cmake后面..表示运行上一级目录的cmake脚本)cmake..-G"Vi......
  • centos7 安装 minio RELEASE.2021-06-17
    1、下载执行包wgethttps://dl.min.io/server/minio/release/linux-amd64/archive/minio.RELEASE.2021-06-17T00-10-46Z2、创建数据、日志文件夹mkdir-p/data/project/minio/data/mkdir-p/data/project/minio/log/touch/data/project/minio/log/minio.log3、授......
  • 成语积累 20230724
    难兄难弟:nan4xiongnan4di:处于同样困境的人。(nan2:兄弟二人都非常好,难分高下。或讥讽两者同样低劣。出处:元方难为兄,季方难为弟。近义:难分伯仲)暴虎冯河:暴:通"虣",和老虎打斗;冯:通"淜",指无舟渡河。空手打虎,徒步过河。多用于比喻有勇无谋,冒险蛮干。也比喻勇猛果敢。例句:我原以为他......
  • 剑指offer_20230723
    剑指Offer50.第一个只出现一次的字符题目说明在字符串s中找出第一个只出现一次的字符。如果没有,返回一个单空格。s只包含小写字母。解题思路1:HashMap使用传统的HashMap,对整一个数组进行遍历,更新记录每个字母的出现次数。在遍历结束之后重新遍历一遍数组,获取每个字母对......
  • CVE-2022-24481
    一、漏洞信息CVE-2022-24481是发生在CLFS驱动中的一个类型混淆漏洞,通过精巧的对blf文件的部分数据进行构造,可使LogBlockHeader中的ClientContextOffset指向ContainContext,从而造成类型混淆。二、测试环境及漏洞复现测试环境POC:4c1579c6a14bb8f3985be8a1a83c731c靶机:win10......
  • Toyota Programming Contest 2023#4(AtCoder Beginner Contest 311)
    ToyotaProgrammingContest2023#4(AtCoderBeginnerContest311)A-FirstABC(atcoder.jp)记录一下\(ABC\)是否都出现过了然后输出下标#include<bits/stdc++.h>#defineintlonglongusingnamespacestd;signedmain(){ios::sync_with_stdio(false);cin.tie(n......
  • Mac版多平台Java开发工具JetBrains IntelliJ IDEA 2023
    JetBrainsIntelliJ是一个多平台的Java开发工具,可以用于Java开发。它可以帮助您在Linux、Windows、Mac和Linux上开发基于Java的应用程序、软件和服务。它还提供了一个跨平台的工具包,可以为开发者提供Java开发者的基础设施设计支持。JetBrainsIntelliJ与Linux有很多相似之处:Java......
  • 打造原生 WebGL 2D 引擎:一场创意与技术的融合
    打造原生WebGL2D引擎:一场创意与技术的融合1.引言在当今数字化时代,网页的功能越来越丰富,已经远远超越了传统的文本和图片呈现。我们生活在一个充满交互性和视觉魅力的网络世界。每天都会遇到许多令人惊叹的网页效果和动画。作为一个Web3D图形的开发,希望可以通过网页来实现更多......