GLSL ES 语言 | 数组

  • Post author:
  • Post category:其他


数组

GLSL ES 只支持一维数组,且没有 pop()、push() 等操作,声名数组只需要在变量后加上中括号”[ ]” 和数组长度,如下:

//声明含有4个数浮点数的数组	
float floatArray[4];    	
//声明含2个vec4的对象数组	
vec4 vec4Array[2];

数组的长度必须大于 0 的整型常量表达式,如下定义:

  • 整型字面量

  • 用const 限定字修饰的全局变量或局部变量,不包括参数

  • 由上面两条中的项目组成的表达式

如下面代码会出错:

int size = 4;	
vec4 vec4Array[size]; //错误,如果size使用const修饰则不会出错

注意,不可以使用const来修饰数组本身。

数组元素可以通过索引值来访问,索引值从 0 开始,且只有

整型常量表达式



uniform变量

可以被用作数组的索引值。

数组不能在声明时一次性初始化,只能显式地对每个元素进行初始化,如下所示:

vec4Array[0] = vec4(4.0, 5.0, 6.0, 1.0);	
vec4Array[1] = vec4(3.0, 2.0, 0.0, 1.0);

数组本身只支持[ ]运算符,但数组元素能够参与其自身类型支持的任意运算,如下:

//将floatArray的第2个元素乘以3.14	
float f = floatArray[1] * 3.14	
//将vec4Array的第1个元素乘以vec4	
vec4 v4 = vec4Array[0] * vec4(1.0, 2.0, 3.0, 4.0); 


640?wx_fmt=jpeg

《WebGL编程指南》是入门WebGL的绝佳好书,对了解游戏引擎底层渲染原理大有裨益,「奎特尔星球」公众号计划将书中内容拆解成若干篇的知识点笔记,方便大家在碎片时间学习,邀你一起学习!

640?wx_fmt=jpeg


  1. WebGL学习笔记 | 使用着色器绘制一个点


  2. WebGL学习笔记 | 创建着色器程序




  3. GLSL ES 笔记—取样器


  4. GLSL 语言—矢量和矩阵 [ ] 运算符


  5. GLSL ES 语言—矢量点(.)运算符


  6. GLSL ES 语言—矢量和矩阵的赋值构造函数


  7. GLSL ES 语言—变量数值类型


  8. GLSL ES 语言基础


  9. GitChat新作,如何较为优雅地实现新手引导功能!


  10. 大神驾到 |「大掌教」Cocos3D组件详解

640?wx_fmt=png