1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-24 02:17:40 +00:00

ray:: renamed rot_* functions to twist_*

This commit is contained in:
Zeno Rogue
2024-06-16 17:47:33 +02:00
parent de3ad6d718
commit 30b9f3e4c7

View File

@@ -341,7 +341,7 @@ struct raygen {
void create(); void create();
string f_xpush() { return hyperbolic ? "xpush_h3" : "xpush_s3"; } string f_xpush() { return hyperbolic ? "xpush_h3" : "xpush_s3"; }
string f_len() { return hyperbolic ? "len_h3" : mtwisted ? "rot_flatdist" : sphere ? "len_s3" : "len_x"; } string f_len() { return hyperbolic ? "len_h3" : mtwisted ? "twist_flatdist" : sphere ? "len_s3" : "len_x"; }
string f_len_prod() { return in_h2xe() ? "len_h2" : in_s2xe() ? "len_s2" : "len_e2"; } string f_len_prod() { return in_h2xe() ? "len_h2" : in_s2xe() ? "len_s2" : "len_e2"; }
void add_functions(); void add_functions();
}; };
@@ -867,7 +867,7 @@ void raygen::move_forward() {
" }\n"; " }\n";
if(mtwisted) fmain += if(mtwisted) fmain +=
" if(which == -1) {\n" " if(which == -1) {\n"
" mediump float z = rot_zlevel(nposition, sides-2);\n" " mediump float z = twist_zlevel(nposition, sides-2);\n"
" if(z > uPLevel) which = sides-1;\n" " if(z > uPLevel) which = sides-1;\n"
" if(z <-uPLevel) which = sides-2;\n" " if(z <-uPLevel) which = sides-2;\n"
" }\n"; " }\n";
@@ -1408,7 +1408,7 @@ void raygen::emit_iterate(int gid1) {
if(nil && nilv::nil_structure_index == 0) fmain += "if(which == 2 || which == 5) pos.z = 0.;\n"; if(nil && nilv::nil_structure_index == 0) fmain += "if(which == 2 || which == 5) pos.z = 0.;\n";
if(nil && nilv::nil_structure_index == 2) fmain += "if(which == 6 || which == 7) pos.z = 0.;\n"; if(nil && nilv::nil_structure_index == 2) fmain += "if(which == 6 || which == 7) pos.z = 0.;\n";
else if(mtwisted) { else if(mtwisted) {
fmain += "pos = rot_coordinates(pos, sides-2, which);\n"; fmain += "pos = twist_coordinates(pos, sides-2, which);\n";
string spinner = "h = cspin(0, 1, PI) * h;\n"; string spinner = "h = cspin(0, 1, PI) * h;\n";
string calc_dxy = sl2 ? string calc_dxy = sl2 ?
"dx = -2. * (h.y*h.z - h.x*h.w);\n" "dx = -2. * (h.y*h.z - h.x*h.w);\n"
@@ -1425,7 +1425,7 @@ void raygen::emit_iterate(int gid1) {
"vec4 h1 = lorentz(1, 3, -vy) * lorentz(0, 2, -vy) * lorentz(0, 3, -vx) * lorentz(2, 1, vx) * h;\n" : "vec4 h1 = lorentz(1, 3, -vy) * lorentz(0, 2, -vy) * lorentz(0, 3, -vx) * lorentz(2, 1, vx) * h;\n" :
"vec4 h1 = cspin(0, 3, vy) * cspin(1, 2, -vy) * cspin(1, 3, -vx) * cspin(0, 2, -vx) * h;\n"; "vec4 h1 = cspin(0, 3, vy) * cspin(1, 2, -vy) * cspin(1, 3, -vx) * cspin(0, 2, -vx) * h;\n";
fsh += fsh +=
"vec4 rot_coordinates(vec4 h, int ks, int id) {\n" "vec4 twist_coordinates(vec4 h, int ks, int id) {\n"
+spinner+ +spinner+
"if(id < ks) h = cspin(0, 1, -TAU * float(id) / float(ks)) * h;\n" "if(id < ks) h = cspin(0, 1, -TAU * float(id) / float(ks)) * h;\n"
+dcalc_dxy + +dcalc_dxy +
@@ -1435,17 +1435,17 @@ void raygen::emit_iterate(int gid1) {
"return vec4(vx, vy, vz, 1);\n" "return vec4(vx, vy, vz, 1);\n"
"}\n\n"; "}\n\n";
fsh += fsh +=
"mediump float rot_flatdist(mediump vec4 h) {\n" + dcalc_dxy + "mediump float twist_flatdist(mediump vec4 h) {\n" + dcalc_dxy +
"return dx*dx+dy*dy;\n" "return dx*dx+dy*dy;\n"
"}\n"; "}\n";
fsh += fsh +=
"mediump float rot_zlevel(vec4 h, int ks) {\n" + spinner + dcalc_dxy + "mediump float twist_zlevel(vec4 h, int ks) {\n" + spinner + dcalc_dxy +
"float alpha = (floor(atan2(dy, dx) * float(ks) / TAU + 0.5)) * TAU / float(ks);\n" "float alpha = (floor(atan2(dy, dx) * float(ks) / TAU + 0.5)) * TAU / float(ks);\n"
"h = cspin(1, 0, alpha) * h;\n" + calc_dxy + calc_vxy + calc_h1 + "h = cspin(1, 0, alpha) * h;\n" + calc_dxy + calc_vxy + calc_h1 +
"return atan2(h1[2], h1[3]);\n" "return atan2(h1[2], h1[3]);\n"
"}\n\n"; "}\n\n";
fsh += fsh +=
"mediump bool rot_dark(vec4 h, int ks) {\n" + spinner + dcalc_dxy + "mediump bool twist_dark(vec4 h, int ks) {\n" + spinner + dcalc_dxy +
"float alpha = atan2(dy, dx) * float(ks);\n" "float alpha = atan2(dy, dx) * float(ks);\n"
"return cos(alpha) < -0.99;\n" "return cos(alpha) < -0.99;\n"
"}\n\n"; "}\n\n";
@@ -1483,7 +1483,7 @@ void raygen::emit_iterate(int gid1) {
" col.xyz = col.xyz * d + uFogColor.xyz * (1.-d);\n"; " col.xyz = col.xyz * d + uFogColor.xyz * (1.-d);\n";
if(mtwisted) fmain += if(mtwisted) fmain +=
" if(rot_dark(position, sides-2)) col.xyz /= 2.;\n"; " if(twist_dark(position, sides-2)) col.xyz /= 2.;\n";
if(nil && nilv::nil_structure_index == 0) fmain += if(nil && nilv::nil_structure_index == 0) fmain +=
" if(abs(abs(position.x)-abs(position.y)) < .005) col.xyz /= 2.;\n"; " if(abs(abs(position.x)-abs(position.y)) < .005) col.xyz /= 2.;\n";