glsl - 关于椭圆的旋转
问题描述
我有一个在 GLSL 中旋转矩形的着色器,如下所示。
const float PI = 3.14159265359;
mat2 rotate2d (float _angle) {
return mat2 (cos (_angle), -sin (_angle),
sin (_angle), cos (_angle));
}
void main (void) {
vec2 st = (gl_FragCoord.xy * 2.0 - resolution) /min(resolution.x,resolution.y);
float p = 0.0;
st = rotate2d (sin (time) * PI) * st;
vec2 c = max (abs (st) - 0.2,0.0);
p = length (c);
p = ceil (p);
vec3 color = vec3 (1.0-p);
gl_FragColor = vec4 (color, 1.0);
}
我想把这个shader的矩形改成下面的椭圆,并在中心点p处旋转,它是一个椭圆。我应该怎么办?它是r.x, r.y
在椭圆的水平和垂直方向rotate2d (sin (time) * PI)
上乘以旋转还是在整体上乘?
// Center point
vec2 p = vec2 (0.0,0.0);
// radius
vec2 r = vec2 (2.0,1.0);
// oval shape
float d = (length (p / r) - 1.0) * min (r.x, r.y);
解决方案
旋转坐标并计算该点到椭圆中心的距离。根据距离设置颜色:
const float PI = 3.14159265359;
mat2 rotate2d(float _angle)
{
return mat2(cos(_angle), -sin(_angle), sin(_angle), cos(_angle));
}
void main (void)
{
vec2 st = (gl_FragCoord.xy * 2.0 - resolution) / min(resolution.x, resolution.y);
st = rotate2d(time * PI) * st;
vec2 center = vec2(0.0, 0.0);
vec2 ab = vec2(0.2, 0.1);
vec2 e = (st - center) / vec2(0.2, 0.1);
float d = length(e);
vec3 color = d < 1.0 ? vec3(1.0) : vec3(0.0);
gl_FragColor = vec4(color, 1.0);
}
推荐阅读
- c++ - 如何链接目录中的所有库?
- javascript - 将一组名称相似的属性设置为 false
- excel - 是否可以创建一个不活动的新工作簿?
- javascript - 如何设置 JavaScript 对象的属性值?
- r - 拆分字符串并转换为R中的data.frame/tibble?
- python - Django html 表单数据抛出 NoReverseMatch
- angular - SnackBar 在 HTTPInterceptor 中使用时不显示
- html - 更少的编译器生成空规则
- asp.net-core-mvc - 查询字符串绑定在 RazorPage 上不起作用,即使 SupportsGet = true
- ruby-on-rails - Rails、EC2、Nginx、Unicorn - 新资产不再在生产环境中渲染