位置: 编程技术 - 正文

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详解)

  • 出口退税货物的进项税处理
  • 企业增资后需要交什么税
  • 固定资产接受捐赠的计入什么科目
  • 开增值税发票规格是否可以不用填
  • 企业净利率多少算正常
  • 销售成本结转属于收入吗
  • 刷卡收手续费吗
  • 其他收益科目是否征收企业所得税
  • 土地闲置费是否可以税前扣除
  • 怎么从银行买承兑汇票
  • 转账支票支付展览费
  • 非营利性代收代付费用会计处理怎么做?
  • 前程无忧靠什么赚钱
  • 原材料计划价实际价区别
  • 2018工资个税税率表
  • 建筑业异地预缴税款的会计分录
  • 商场超市印花税怎么样
  • 销货成本销货成本是什么类账户
  • 会员卡充值赠送金额怎么做账
  • 发票认证后失控
  • 外币账户和外汇账户一样吗?
  • 差额发票如何缴纳增值税
  • 2020年开公司优惠政策
  • 个税如何绑定新公司
  • 购买加油卡能否开发票
  • 路由器死机的表现
  • 负债率是什么指标
  • 存货跌价准备是谁的备抵账户
  • linux 匹配字符
  • PHP:oci_set_edition()的用法_Oracle函数
  • 损益类科目细分
  • 应缴纳所得税额怎么算
  • 蓝桥杯等级
  • 产品出库单什么时候入账
  • 莱茵地区在德国哪里
  • 爱丁堡几点天黑
  • php操作json文件
  • 小程序制作平台
  • php的mysql_query
  • 纳税申报表填写说明
  • 申报个体经营所得税款所属期怎么填
  • php array_search二维数组
  • npm install 的 --save 选项是什么?
  • 定额发票新旧版区别
  • 可行性研究合同印花税
  • 返利销售的增值税怎么算
  • 增值税申报表填错不影响税额
  • 借款人和还款人不一致,收据打给谁
  • 公司公账转私账违法吗
  • 商贸企业 税收 政策规定
  • 闲置土地属于哪个部门
  • 计提租金如何做账务处理
  • 税务局返还的个税手续费是否纳税
  • 本年利润是不是未分配利润
  • 企业买期货账务处理
  • 清算申报在哪里报
  • 信用证保证金的计算公式
  • 某劳务派遣公司与某传媒公司签订
  • 银行回单和发票哪个粘贴到上面
  • MySQL统计函数GROUP_CONCAT使用陷阱分析
  • excel格式变了怎么办
  • win8系统启动慢怎么办
  • iphone制造成本
  • vrvarp.exe是什么
  • centos7图形安装
  • 如何改进个人工作作风
  • win7系统检测
  • win7安装内存4g
  • Windows搭建代理服务器
  • bootstrap内容
  • 两个js文件互相取变量
  • 用android做一个简单的软件
  • JavaScript正则表达
  • python给批量图片添加文字
  • 什么是javascrip
  • jquery weui
  • 陕西国家电子税务局2.0
  • 湖北安徽是一个地方吗
  • 工会活动经费的请示
  • 广东省国家税务局电子发票系统,网络设置
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设