1
0
mirror of https://github.com/zenorogue/hyperrogue.git synced 2025-10-25 19:07:40 +00:00

rogueviz/smoothcam:: better smoothcam for embedded_plane

This commit is contained in:
Zeno Rogue
2023-02-10 15:37:10 +01:00
parent d0f6a94418
commit c7de7df6fe

View File

@@ -505,34 +505,63 @@ void handle_animation(ld t) {
total += f.interval; total += f.interval;
} }
hyperpoint pts[3]; transmatrix V = View;
for(int j=0; j<3; j++) { if(embedded_plane) {
for(int i=0; i<4; i++) { hyperpoint interm = C03;
for(int j=0; j<3; j++) {
vector<ld> values;
for(auto& f: anim.frames)
values.push_back(cgi.emb->actual_to_intermediate(f.V*tile_center())[j]);
interm[j] = interpolate(values, times, t);
}
transmatrix Rot = Id;
for(int j=0; j<3; j++) for(int k=0; k<3; k++) {
vector<ld> values; vector<ld> values;
for(auto& f: anim.frames) { for(auto& f: anim.frames) {
hyperpoint h; transmatrix Rot = inverse(cgi.emb->map_relative_push(f.V*tile_center())) * f.V;
if(j == 0) if(j == 0 && k == 0) println(hlog, "Rot = ", kz(Rot));
h = tC0(f.V); if(nisot::local_perspective_used) Rot = Rot * f.ori;
if(j == 1) { values.push_back(Rot[j][k]);
h = tC0(shift_object(f.V, f.ori, ztangent(f.front_distance), smGeodesic));
}
if(j == 2) {
h = tC0(shift_object(f.V, f.ori, ctangent(1, -f.up_distance), smGeodesic));
}
prepare_for_interpolation(h);
values.push_back(h[i]);
} }
Rot[j][k] = interpolate(values, times, t);
pts[j][i] = interpolate(values, times, t);
} }
after_interpolation(pts[j]); View = inverse(cgi.emb->intermediate_to_actual_translation(interm)); NLP = Id;
println(hlog, "got Rot = ", kz(Rot));
fix_rotation(Rot);
rotate_view(inverse(Rot));
}
else {
hyperpoint pts[3];
for(int j=0; j<3; j++) {
for(int i=0; i<4; i++) {
vector<ld> values;
for(auto& f: anim.frames) {
hyperpoint h;
if(j == 0)
h = tC0(f.V);
if(j == 1) {
h = tC0(shift_object(f.V, f.ori, ztangent(f.front_distance), smGeodesic));
}
if(j == 2) {
h = tC0(shift_object(f.V, f.ori, ctangent(1, -f.up_distance), smGeodesic));
}
prepare_for_interpolation(h);
values.push_back(h[i]);
}
pts[j][i] = interpolate(values, times, t);
}
after_interpolation(pts[j]);
}
set_view(pts[0], pts[1], pts[2]);
println(hlog, "V = ", View);
c_front_dist = geo_dist(pts[0], pts[1]);
c_up_dist = geo_dist(pts[0], pts[2]);
} }
transmatrix V = View;
set_view(pts[0], pts[1], pts[2]);
c_front_dist = geo_dist(pts[0], pts[1]);
c_up_dist = geo_dist(pts[0], pts[2]);
transmatrix T = View * inverse(last_view_comp); transmatrix T = View * inverse(last_view_comp);
last_view_comp = View; last_view_comp = View;
@@ -540,14 +569,7 @@ void handle_animation(ld t) {
View = T * V; View = T * V;
fixmatrix(View); fixmatrix(View);
if(invalid_matrix(View)) { if(invalid_matrix(View)) println(hlog, "invalid_matrix ", View, " at t = ", t);
println(hlog, "invalid_matrix ", View);
println(hlog, pts[0]);
println(hlog, pts[1]);
println(hlog, pts[2]);
println(hlog, "t = ", t);
exit(1);
}
last_time = t; last_time = t;
} }