位置: 编程技术 - 正文

OpenGL ES2.0 的三种变量类型(uniform,attribute和varying)(opengl es 3.2)

编辑:rootadmin
1.uniform变量

推荐整理分享OpenGL ES2.0 的三种变量类型(uniform,attribute和varying)(opengl es 3.2),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:opengl es 3.0编程指南,opengl es3.0,opengl es3,opengl es3.0metal,opengl es3.1,opengl es3.0,opengl es3.0,opengl es 3.2,内容如对您有帮助,希望把文章链接给更多的朋友!

uniform变量是外部application程序传递给(vertex和fragment)shader的变量。因此它是application通过函数glUniform**()函数赋&#;的。在(vertex和fragment)shader程序内部,uniform变量就像是C语言里面的常量(const ),它不能被shader程序修改。(shader只能用,不能改)

如果uniform变量在vertex和fragment两者之间声明方式完全一样,则它可以在vertex和fragment共享使用。(相当于一个被vertex和fragment shader共享的全局变量)

uniform变量一般用来表示:变换矩阵,材质,光照参数和颜色等信息。

以下是例子:

uniform mat4 viewProjMatrix; //投影&#;视图矩阵uniform mat4 viewMatrix; //视图矩阵uniform vec3 lightPosition; //光源位置

2.attribute变量

attribute变量是只能在vertex shader中使用的变量。(它不能在fragment shader中声明attribute变量,也不能被fragment shader中使用)

OpenGL ES2.0 的三种变量类型(uniform,attribute和varying)(opengl es 3.2)

一般用attribute变量来表示一些顶点的数据,如:顶点坐标,法线,纹理坐标,顶点颜色等。

在application中,一般用函数glBindAttribLocation()来绑定每个attribute变量的位置,然后用函数glVertexAttribPointer()为每个attribute变量赋&#;。

以下是例子:

uniform mat4 u_matViewProjection;attribute vec4 a_position;attribute vec2 a_texCoord0;varying vec2 v_texCoord;void main(void){gl_Position = u_matViewProjection * a_position;v_texCoord = a_texCoord0;}

3.varying变量

varying变量是vertex和fragment shader之间做数据传递用的。一般vertex shader修改varying变量的&#;,然后fragment shader使用该varying变量的&#;。因此varying变量在vertex和fragment shader二者之间的声明必须是一致的。application不能使用此变量。

以下是例子:

// Vertex shaderuniform mat4 u_matViewProjection;attribute vec4 a_position;attribute vec2 a_texCoord0;varying vec2 v_texCoord; // Varying in vertex shadervoid main(void){gl_Position = u_matViewProjection * a_position;v_texCoord = a_texCoord0;}

// Fragment shaderprecision mediump float;varying vec2 v_texCoord; // Varying in fragment shaderuniform sampler2D s_baseMap;uniform sampler2D s_lightMap;void main(){vec4 baseColor;vec4 lightColor;baseColor = texture2D(s_baseMap, v_texCoord);lightColor = texture2D(s_lightMap, v_texCoord);gl_FragColor = baseColor * (lightColor &#; 0.);}

【OpenGL】理解GL_TRIANGLE_STRIP等绘制三角形序列的三种方式 GL_TRIANGLE_STRIP绘制三角形方式很多时候令人疑惑,在这里对其运作机理进行解释。一般情况下有三种绘制一系列三角形的方式,分别是GL_TRIANGLES、GL_TRIANG

Qt新渲染底层Scene Graph研究(一) Qt新渲染底层SceneGraph研究(一)Qt5提出了一个新的渲染底层,以替代Qt4时期的GraphicsView,这个渲染底层就是SceneGraph。其实这个底层的作用和OpenSceneGraph

GLWallpaperService分析一 WallpaperService是用来实现动态壁纸的服务,使用WallpaperService的典型方式是实现自定义的继承自WallpaperService的动态壁纸类。并实现它的WallpaperService.Engine。

标签: opengl es 3.2

本文链接地址:https://www.jiuchutong.com/biancheng/369642.html 转载请保留说明!

上一篇:OpenGL学习09_裁剪平面ClipPlane(opengl裁剪平面)

下一篇:【OpenGL】理解GL_TRIANGLE_STRIP等绘制三角形序列的三种方式(opengl详解)

  • 跨区域涉税事项报验是什么意思
  • 银行承兑的商业汇票计入什么科目
  • 工资是当月计提下月发放吗
  • 盈余公积是否必要交税
  • 企业所得税年报过了申报期还能修改吗
  • 电子记账凭证需要划线吗
  • 个体商户多少钱需要报税
  • 接受劳务是进项还是销项
  • 电子发票冲红处理
  • 增值税进项税转出文件
  • 非同一控制企业合并下,购买日将
  • 增值税出口退税政策
  • 代销手续费怎么做账
  • 非居民企业股权转让协议
  • 拆迁补偿款使用范围
  • 未结清全额是逾期吗
  • 有发票的福利费可以不交个税吗
  • 出口当月开票当月申报吗
  • 拒绝税务检查的情形
  • 增值税普票需要进项吗
  • 五证合一后地税编码怎么查
  • 加油发票税号错误怎么补救
  • 附加税减半征收计提和缴纳的会计分录
  • 所得税亏损财务处理办法
  • 有限合伙企业需要承担无限连带责任吗
  • 建筑公司一般纳税人增值税税率
  • 个人股权转让印花税在哪里申报
  • 异常抵扣凭证进项税转出入哪个所属期
  • 发票开出多久可以作废
  • 企业债券投资利息怎么算
  • 商标续展费用入什么科目
  • vagrant 安装centos7
  • ocxdll.exe - ocxdll是什么进程 有什么用
  • 付给他人押金的会计分录
  • php-cgi
  • php改编码
  • yolov教程
  • 灯光璀璨的夜晚
  • laravel 5.4中实现无限级分类的方法示例
  • 可以享受企业所得税加计扣除的有
  • 企业和银行未达账项
  • Vue Element UI 中 el-table 树形数据 tree-props 多层级使用避坑
  • 如何做架构规划图
  • Win11系统自带输入法怎么卸载
  • update-initramfs -u命令
  • php与其他语言的比较
  • php调用网址
  • 待处理财产损溢在资产负债表中填哪里
  • 进项税额转出可以为负数吗
  • 白酒贴牌酒是真酒还是假酒
  • g郭敬明
  • 商誉的会计核算怎么核算
  • 可供出售金融资产属于什么科目
  • 企业银行基本户和一般户的区别
  • 分公司企业所得税怎么缴纳
  • 垃圾清运费属于什么服务
  • 公司向个人借款怎么做账
  • 红字冲销发票流程
  • 已抵扣未申报的税额如何转出
  • 财务的材质怎么写
  • 农业公司土地租赁
  • 一般性企业
  • 未分配利润如何计算
  • 企业控股情况分析报告
  • 总账会计工作流程表
  • ubuntu终端终止正在执行的命令
  • 盗版win7升级win10
  • win10录音机不能用
  • 在Linux操作系统中哪些命令可以正确关闭系统防火墙
  • linux播放mp3命令
  • win8.1无法关机怎么回事
  • 日亚海淘官网
  • 一个简单的灵魂
  • jquery遍历表单元素
  • android:imeOptions属性
  • 为什么需要报税
  • 房产税从价计征税率
  • 税务局文化建设实施方案
  • 抚顺交车辆购置税在哪交
  • 世界近代史的改革有哪些
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设