位置: 编程技术 - 正文

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

  • 计提税金是什么会计科目
  • 金蝶美金账户怎么开
  • 应收账款和应付账款的区别
  • 收到工伤赔偿款会计分录
  • 养老失业工伤单位一般缴纳多少钱
  • 旧公司库存如何管理
  • 车船使用税应该交哪里的税
  • 费用的完成率怎么计算
  • 环保公司开具发票怎么开
  • 耕地占用税如何申报缴纳
  • 长期待摊费用当月增加当月摊销吗
  • 进项税核定扣除试点
  • 国税发2005 9号 税屋
  • ca浏览器组件如何下载?
  • 企业为一般纳税人税率多少
  • 减税降费新政策解读
  • 网络综合布线开关在哪
  • 多扣除了应交税费怎么调整?
  • 合作保证金规定
  • 供应商开免税的发票,为何还要收3个点税金?
  • 来料加工进料加工是免税的吗?
  • 代开票扣了个人所得税怎么做账?
  • 汽车厂家金融贴息 是贴利息的还是贴车价
  • 金税盘纳税申报
  • 收取水电费如何开票
  • php 无限级分类
  • php axios
  • 蜻蜓翅膀特写怎么画
  • 旅行社的会计
  • 工伤补贴由谁发放
  • 已领待用物资
  • 盈余公积提取和结转
  • 公司想减少注册资本流程
  • 长期股权投资成本怎么计算
  • 用工会经费给员工发工资
  • python代码用什么运行
  • 企业所得税成本核定
  • 金蝶财务软件库存商品数量金额再那查看
  • 什么是俗称的汇款
  • 申请高新技术企业要具备哪些条件
  • 长期股权投资权益法账务处理
  • sql server2019实例功能的选择
  • 购买的软件属于什么资产
  • 发放职工工资是什么支出
  • 所得税申报表营业成本包括哪些
  • 委托加工账务处理受托方会计分录
  • 买的仪器
  • 双定户经营所得税税率
  • 高新技术企业外债便利化额度试点重庆
  • 研发费用加计扣除政策指引2.0
  • 差旅费住宿专票可以抵扣增值税吗
  • etc的充值发票可以报账吗
  • 企业法人个人贷款企业承担吧?
  • 社保退休金计算方法
  • 财政补助资金是什么意思
  • 同一张发票报销两次会被发现吗
  • 购货方尚未偿付的货款属于什么会计科目
  • 固定资产为什么不能直接计入费用
  • 业务提成需要缴纳个人所得税吗?
  • 免税发票可以抵扣税收农产品吗
  • 原始凭证的审核要求有哪些
  • 阿拉伯数字转大写函数
  • mac os如何安装软件
  • 使用windows防火墙禁止软件联网
  • win7系统解决数字签名问题
  • win7电脑无法上网 连接正常
  • linux Intel 845集成显示驱动下载
  • I810 Graphics LINUX Driver的安装
  • win10老是自动重启是什么原因
  • 超全面的竣工验收流程及资料
  • javascript常用函数大全
  • python调用cuda执行加法
  • nodejs深入浅出pdf百度云
  • 深入理解java
  • js中切割字符串
  • android 调用相机拍照
  • 什么是javascrip
  • javascript new fun的执行过程
  • 东莞税务申报日期
  • 出口退税的企业货币要回国内吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设