mirror of
https://github.com/zenorogue/hyperrogue.git
synced 2025-01-04 14:30:35 +00:00
fixed freeze while drawing the sky in {n,infty} FPP
This commit is contained in:
parent
c11d36089d
commit
2c79a6aeff
22
sky.cpp
22
sky.cpp
@ -39,7 +39,7 @@ EX void prepare_sky() {
|
|||||||
queuepoly(T, cgi.shEuclideanSky, 0x0044e4FF);
|
queuepoly(T, cgi.shEuclideanSky, 0x0044e4FF);
|
||||||
queuepolyat(T * zpush(cgi.SKY+0.5) * xpush(cgi.SKY+0.5), cgi.shSun, 0xFFFF00FF, PPR::SKY);
|
queuepolyat(T * zpush(cgi.SKY+0.5) * xpush(cgi.SKY+0.5), cgi.shSun, 0xFFFF00FF, PPR::SKY);
|
||||||
}
|
}
|
||||||
else {
|
else if(!(cgflags & qIDEAL)) {
|
||||||
sky = &queuea<dqi_sky> (PPR::SKY);
|
sky = &queuea<dqi_sky> (PPR::SKY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -133,6 +133,12 @@ void celldrawer::draw_ceiling() {
|
|||||||
|
|
||||||
if(pmodel != mdPerspective || sphere) return;
|
if(pmodel != mdPerspective || sphere) return;
|
||||||
|
|
||||||
|
auto add_to_sky = [this] (color_t col) {
|
||||||
|
if(cgflags & qIDEAL)
|
||||||
|
draw_shapevec(c, V, qfi.fshape->levels[SIDE_HIGH], darkena(col, 0, 0xFF), PPR::WALL);
|
||||||
|
else if(sky) sky->sky.emplace_back(c, V, col);
|
||||||
|
};
|
||||||
|
|
||||||
switch(ceiling_category(c)) {
|
switch(ceiling_category(c)) {
|
||||||
/* ceilingless levels */
|
/* ceilingless levels */
|
||||||
case 1: {
|
case 1: {
|
||||||
@ -140,7 +146,7 @@ void celldrawer::draw_ceiling() {
|
|||||||
if(fieldpattern::fieldval_uniq(c) % 3 == 0) {
|
if(fieldpattern::fieldval_uniq(c) % 3 == 0) {
|
||||||
queuepolyat(V * zpush(cgi.SKY+1), cgi.shNightStar, 0xFFFFFFFF, PPR::SKY);
|
queuepolyat(V * zpush(cgi.SKY+1), cgi.shNightStar, 0xFFFFFFFF, PPR::SKY);
|
||||||
}
|
}
|
||||||
if(sky) sky->sky.emplace_back(sky_item{c, V, 0x00000F});
|
add_to_sky(0x00000F);
|
||||||
if(c->land == laAsteroids) {
|
if(c->land == laAsteroids) {
|
||||||
if(fieldpattern::fieldval_uniq(c) % 9 < 3) {
|
if(fieldpattern::fieldval_uniq(c) % 9 < 3) {
|
||||||
queuepolyat(V * zpush(-1-cgi.SKY), cgi.shNightStar, 0xFFFFFFFF, PPR::SKY);
|
queuepolyat(V * zpush(-1-cgi.SKY), cgi.shNightStar, 0xFFFFFFFF, PPR::SKY);
|
||||||
@ -201,12 +207,12 @@ void celldrawer::draw_ceiling() {
|
|||||||
default:
|
default:
|
||||||
col = skycolor(c);
|
col = skycolor(c);
|
||||||
}
|
}
|
||||||
if(sky) sky->sky.emplace_back(c, V, col);
|
add_to_sky(col);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
case 3: {
|
case 3: {
|
||||||
if(sky) sky->sky.emplace_back(c, V, 0);
|
add_to_sky(0);
|
||||||
if(camera_level <= cgi.WALL) return;
|
if(camera_level <= cgi.WALL) return;
|
||||||
if(c->land == laMercuryRiver) fcol = linf[laTerracotta].color, fd = 1;
|
if(c->land == laMercuryRiver) fcol = linf[laTerracotta].color, fd = 1;
|
||||||
if(qfi.fshape) draw_shapevec(c, V, qfi.fshape->levels[SIDE_WALL], darkena(fcol, fd, 0xFF), PPR::WALL);
|
if(qfi.fshape) draw_shapevec(c, V, qfi.fshape->levels[SIDE_WALL], darkena(fcol, fd, 0xFF), PPR::WALL);
|
||||||
@ -221,7 +227,7 @@ void celldrawer::draw_ceiling() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
case 4: {
|
case 4: {
|
||||||
if(sky) sky->sky.emplace_back(c, V, 0x00000F);
|
add_to_sky(0x00000F);
|
||||||
if(camera_level <= cgi.HIGH2) return;
|
if(camera_level <= cgi.HIGH2) return;
|
||||||
auto ispal = [&] (cell *c0) { return c0->land == laPalace && among(c0->wall, waPalace, waClosedGate, waOpenGate); };
|
auto ispal = [&] (cell *c0) { return c0->land == laPalace && among(c0->wall, waPalace, waClosedGate, waOpenGate); };
|
||||||
color_t wcol2 = 0xFFD500;
|
color_t wcol2 = 0xFFD500;
|
||||||
@ -247,7 +253,7 @@ void celldrawer::draw_ceiling() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
case 6: {
|
case 6: {
|
||||||
if(sky) sky->sky.emplace_back(c, V, skycolor(c));
|
add_to_sky(skycolor(c));
|
||||||
if(camera_level <= cgi.HIGH2) return;
|
if(camera_level <= cgi.HIGH2) return;
|
||||||
color_t wcol2 = winf[waRuinWall].color;
|
color_t wcol2 = winf[waRuinWall].color;
|
||||||
if(c->landparam == 1)
|
if(c->landparam == 1)
|
||||||
@ -264,7 +270,7 @@ void celldrawer::draw_ceiling() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
case 7: {
|
case 7: {
|
||||||
if(sky) sky->sky.emplace_back(c, V, 0x00000F);
|
add_to_sky(0x00000F);
|
||||||
if(fieldpattern::fieldval_uniq(c) % 5 < 2) {
|
if(fieldpattern::fieldval_uniq(c) % 5 < 2) {
|
||||||
queuepolyat(V * zpush(cgi.SKY+1), cgi.shNightStar, 0xFFFFFFFF, PPR::SKY);
|
queuepolyat(V * zpush(cgi.SKY+1), cgi.shNightStar, 0xFFFFFFFF, PPR::SKY);
|
||||||
}
|
}
|
||||||
@ -284,7 +290,7 @@ void celldrawer::draw_ceiling() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
case 5: {
|
case 5: {
|
||||||
if(sky) sky->sky.emplace_back(c, V, 0x00000F);
|
add_to_sky(0x00000F);
|
||||||
if(camera_level <= cgi.WALL) return;
|
if(camera_level <= cgi.WALL) return;
|
||||||
|
|
||||||
if(pseudohept(c)) {
|
if(pseudohept(c)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user