UV Coordinates & Uniforms -- OpenGL UV坐标和Uniform变量

Task

A shader is a set of instructions that are executed simultaneously for each pixel on the screen. It can produce different color result depending on the pixel data such as position on the screen.
Use the x component of the pixel's normalized coordinates as the red and the y component as the green when writing pixel's color. As a result, you should notice that the intensity of the red color increases from left to right, and the intensity of the green color increases from bottom to top. In the upper right corner we get yellow color as a result of mixing green and red.
着色器是一组针对屏幕上每个像素同时执行的指令。它可以根据像素数据(例如屏幕上不同的位置)产生不同的颜色效果。
在写入像素颜色时,使用x像素标准化坐标的分量作为红色,使用y分量作为绿色。因此,你可以注意到红色的强度从左到右增加,而绿色的强度从下到上增加。在右上角,我们得到了黄色,这是绿色和红色混合的结果。

Theory

着色器程序用于创建 2D 图像或纹理。为了避免处理生成的纹理的具体尺寸,我们将使用UV坐标。这是纹理坐标的规范化,其中纹理的左下角为(0, 0),右上角为(1.0, 1.0)

规范化像素坐标

要获取当前像素的标准化坐标,请将其位置除以纹理的分辨率:

ini 复制代码
vec2 uv = gl_FragCoord.xy / iResolution.xy;

gl_FragCoord

gl_FragCoord是着色器程序中的一个内置变量,用于表示正在处理的片段的像素坐标。它是一个四维向量,包含片段位置的 X、Y、Z 和 W 分量:

  • X 和 Y:片段的屏幕空间坐标。
  • Z:深度值。
  • W:分别为透视除法值。

gl_FragCoord变量通常用于根据片段的位置执行各种计算。

iResolution

iResolution是一个用于保存纹理分辨率的Uniform变量。Uniform用于将CPU的一些输入发送到所有着色器程序。每个程序接收相同的数据,它们可以读取但无法更改。Uniform的目的是为应用程序提供一种方法来控制着色器的行为,而无需修改着色器代码本身。这使得渲染更加灵活,因为同一个着色器可以使用不同的数据输入来产生不同的效果。

Answer

glsl 复制代码
uniform vec2 iResolution;

void main() {
  vec2 uv = gl_FragCoord.xy / iResolution.xy;
  gl_FragColor = vec4(uv, 0.0, 1.0);
}

练习

UV Coordinates & Uniforms

相关推荐
小鹏linux2 小时前
Ubuntu 22.04 部署开源免费具有精美现代web页面的Casdoor账号管理系统
linux·前端·ubuntu·开源·堡垒机
前端若水2 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
Bigger3 小时前
mini-cc:一个轻量级 AI 编程助手的诞生
前端·ai编程·claude
涵涵(互关)3 小时前
Naive-ui树型选择器只显示根节点
前端·ui·vue
BY组态3 小时前
Ricon组态系统最佳实践:从零开始构建物联网监控平台
前端·物联网·iot·web组态·组态
BY组态3 小时前
Ricon组态系统vs传统组态软件:为什么选择新一代Web组态平台
前端·物联网·iot·web组态·组态
SoaringHeart3 小时前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
放下华子我只抽RuiKe53 小时前
React 从入门到生产(四):自定义 Hook
前端·javascript·人工智能·深度学习·react.js·自然语言处理·前端框架
IT_陈寒5 小时前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu5 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript