Smoothstep

Task

Create a gradient effect that smoothly transitions from red to green. The color change should be most noticeable between the x-coordinates of 0.25 and 0.75.
创建一个从红色平滑过渡到绿色的渐变效果。颜色变化设置为x坐标的 0.25 和 0.75 的 x 之间

Requirements

The shader should avoid using branching or conditional statements in its code, and instead rely on the smoothstep and mix functions to determine the color of each pixel.
着色器应避免在其代码中使用分支或条件语句,而是依赖 Smoothstepmix函数来确定每个像素的颜色。

Theory

smoothstep函数基于第三个线性插值因子在两个值之间进行平滑插值。该函数通过在插值过程中应用平滑曲线,提供了比线性插值更为平滑的过渡。

函数

ini 复制代码
smoothInterpolation = smoothstep(edge0, edge1, x)

smoothstep函数有三个参数:

  • edge0: 下限阈值
  • edge1 : 上限阈值
  • x : 插值因子

插值因子说明

  1. 如果 x 小于或等于 edge0, 结果为 0。

  2. 如果 x 大于或等于 edge1, 结果为 1。

  3. 如果 x 介于 edge0edge1 之间,则使用埃尔米特特插值函数在 0 和 1 之间平滑插值。

示例代码

scss 复制代码
// result will be a smooth color interpolation between red and blue
vec3 out = mix(color1, color2, smoothstep(0.2, 0.8, factor));

在这个例子中,输出颜色值根据因子值从 0.2 平滑地过渡到 0.8:

  • 当因子小于 0.2 时:smoothstep 函数的值为 0.0, 导致输出更接近 color1。
  • 当 factor 大于 0.8 时:smoothstep 函数求值为 1.0, 导致输出更接近 color2。
  • 当 factor 介于 0.2 和 0.8 之间时:转换是平滑连续的,为混合发生的位置提供了更多的控制。

Answer

glsl 复制代码
uniform vec2 iResolution;

void main() {
  // Normalized pixel coordinates (from 0 to 1)
  vec2 uv = gl_FragCoord.xy / iResolution.xy;
  vec3 redColor = vec3(1.0, 0.0, 0.0);
  vec3 greenColor = vec3(0.0, 1.0, 0.0);
  vec3 outColor = mix(redColor, greenColor, smoothstep(0.25, 0.75, uv.x));
  gl_FragColor = vec4(outColor, 1.0);
}

效果

练习

Smoothstep

最后

如果你觉得这篇文章有用,记得点赞、关注、收藏,学Shader更轻松!!

相关推荐
donecoding1 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马1 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren1 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川1 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo1 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技1 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE2 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀3 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3604 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库