GLSL ES 语言 | 数组

数组

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值