Distance / Length 深入理解

Task

Try to fill pixels in red that are within 0.25 of the texture center in normalized coordinates.
尝试以标准设备坐标中心点0.25为半径的圆内绘制成红色

Theory

函数介绍

1 length() - 测量向量的长度

  • 对于一个二维向量 vec2 v = vec2(x, y),其长度为 sqrt(x*x + y*y)
  • 对于一个三维向量 vec3 v = vec3(x, y, z),其长度为 sqrt(x*x + y*y + z*z)

length() 应用: 画圆。 圆的定义就是:平面上所有到圆心距离相等的点的集合。

glsl 复制代码
// 假设 uv 是从 (-1.0, -1.0) 到 (1.0, 1.0) 的坐标
 uv *= 2.0; 
 uv -= 1.0;
 // 圆的半径为0.5
float radius = 0.5;

// 计算当前片元坐标到原点的距离
float d = length(uv);

// 如果距离小于半径,则为白色,否则为黑色
vec3 color = vec3(step(d, radius));

// step(d, radius) 等价于 d <= radius ? 1.0 : 0.0
// 我们可以用 smoothstep 获得更平滑的边缘
// float smooth_edge = 1.0 - smoothstep(radius - 0.01, radius + 0.01, d);
// vec3 color = vec3(smooth_edge);

gl_FragColor = vec4(color, 1.0);

2 distance() - 测量两点间的距离

  • distance(p1, p2): 用于计算两个点 p1p2 之间的直线距离。

它计算的同样是欧几里得距离,公式如下: distance(p1, p2) = sqrt(pow(p1.x - p2.x, 2) + pow(p1.y - p2.y, 2) + ...)
distance应用:同样的画一个圆

glsl 复制代码
// 假设 uv 是从 (0.0, 0.0) 到 (1.0, 1.0) 的坐标
vec2 center = vec2(0.5, 0.5);
float radius = 0.3;

// 计算当前片元坐标到指定圆心的距离
float d = distance(uv, center);

// 根据距离上色
vec3 color = vec3(step(d, radius));

gl_FragColor = vec4(color, 1.0);

总结

两个位置向量的差 (p1 - p2),会得到一个从 p2 指向 p1 的新向量 。而这个新向量的长度 ,恰好就是 p1p2 两点之间的距离

这意味着,前面那个在任意位置画圆的例子,我们也可以这样写:

glsl 复制代码
// ...
vec2 diff = uv - center;
float d = length(diff); // 效果与 distance(uv, center) 完全相同

Answer

glsl 复制代码
uniform vec2 iResolution;

void main() {
  vec2 uv = gl_FragCoord.xy / iResolution.xy;
  
   // 假设 uv 是从 (-1.0, -1.0) 到 (1.0, 1.0) 的坐标
   vec2 center = vec2(0.5, 0.5);
   float radius = 0.25;

   // 计算当前片元坐标到指定圆心的距离
   float d = distance(uv, center);

   // 根据距离上色
   vec3 color = vec3(step(d, radius));
   color.gb =vec2(0.0, 0.0);

   gl_FragColor = vec4(color, 1.0);
}

效果

练习

Distance / Length

最后

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

相关推荐
少年姜太公2 小时前
什么?还不知道git cherry pick?
前端·javascript·git
白兰地空瓶3 小时前
🏒 前端 AI 应用实战:用 Vue3 + Coze,把宠物一键变成冰球运动员!
前端·vue.js·coze
Liu.7744 小时前
vue3使用vue3-print-nb打印
前端·javascript·vue.js
松涛和鸣5 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
dly_blog5 小时前
Vue 逻辑复用的多种方案对比!
前端·javascript·vue.js
万少5 小时前
HarmonyOS6 接入分享,原来也是三分钟的事情
前端·harmonyos
烛阴5 小时前
C# 正则表达式:量词与锚点——从“.*”到精确匹配
前端·正则表达式·c#
wyzqhhhh6 小时前
京东啊啊啊啊啊
开发语言·前端·javascript
JIngJaneIL6 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
想学后端的前端工程师6 小时前
【Java集合框架深度解析:从入门到精通-后端技术栈】
前端·javascript·vue.js