1
0
Fork 0
mirror of https://github.com/TerryCavanagh/VVVVVV.git synced 2025-01-09 02:19:45 +01:00

Move tele/activity/trophytext conds to collision detection

This moves the teleporter, activity prompt, and trophy text "don't draw"
conditionals to the part where the game checks collision with them,
instead of whenever the game draws them.

This makes it so that the game smoothly does the fade-in/fade-out
animation instead of suddenly stopping rendering them whenever their
"don't draw" conditions apply. Now, the "Press ENTER to activate
terminal" prompt will no longer suddenly disappear whenever you activate
one, and the "- Press ENTER to Teleport -" prompt will smoothly fade
back in after teleporting, instead of suddenly popping in on screen.
This commit is contained in:
Misa 2020-08-02 21:02:27 -07:00 committed by Ethan Lee
parent 95d4465e3e
commit f07a8d2143
3 changed files with 8 additions and 7 deletions

View file

@ -5,6 +5,7 @@
#include "Graphics.h"
#include "Map.h"
#include "Music.h"
#include "Script.h"
#include "UtilityClass.h"
bool entityclass::checktowerspikes(int t)
@ -3083,7 +3084,7 @@ bool entityclass::updateentities( int i )
//wait for collision
if (entities[i].state == 1)
{
trophytext+=2;
if (!script.running) trophytext+=2;
if (trophytext > 30) trophytext = 30;
trophytype = entities[i].para;

View file

@ -1599,7 +1599,7 @@ void gamelogic()
game.activeactivity = obj.checkactivity();
game.oldreadytotele = game.readytotele;
if (game.activetele)
if (game.activetele && !game.advancetext && game.hascontrol && !script.running && !game.intimetrial)
{
int i = obj.getplayer();
if (i > -1)
@ -1637,7 +1637,7 @@ void gamelogic()
#endif
game.prev_act_fade = game.act_fade;
if (game.activeactivity > -1)
if (game.activeactivity > -1 && game.hascontrol && !script.running)
{
if (game.act_fade < 5)
{

View file

@ -1483,7 +1483,7 @@ void gamerender()
if (game.advancetext) graphics.bprint(5, 5, "- Press ACTION to advance text -", 220 - (help.glow), 220 - (help.glow), 255 - (help.glow / 2), true);
}
if ((game.readytotele > 100 || game.oldreadytotele > 100) && !game.advancetext && game.hascontrol && !script.running && !game.intimetrial)
if (game.readytotele > 100 || game.oldreadytotele > 100)
{
int alpha = graphics.lerp(game.oldreadytotele, game.readytotele);
if(graphics.flipmode)
@ -1675,7 +1675,7 @@ void gamerender()
}
float act_alpha = graphics.lerp(game.prev_act_fade, game.act_fade) / 10.0f;
if (game.activeactivity > -1 && game.hascontrol && !script.running)
if (game.activeactivity > -1)
{
game.activity_lastprompt = obj.blocks[game.activeactivity].prompt;
game.activity_r = obj.blocks[game.activeactivity].r;
@ -1684,13 +1684,13 @@ void gamerender()
graphics.drawtextbox(16, 4, 36, 3, game.activity_r*act_alpha, game.activity_g*act_alpha, game.activity_b*act_alpha);
graphics.Print(5, 12, game.activity_lastprompt, game.activity_r*act_alpha, game.activity_g*act_alpha, game.activity_b*act_alpha, true);
}
else if((game.act_fade>5 || game.prev_act_fade>5) && game.hascontrol && !script.running)
else if(game.act_fade>5 || game.prev_act_fade>5)
{
graphics.drawtextbox(16, 4, 36, 3, game.activity_r*act_alpha, game.activity_g*act_alpha, game.activity_b*act_alpha);
graphics.Print(5, 12, game.activity_lastprompt, game.activity_r*act_alpha, game.activity_g*act_alpha, game.activity_b*act_alpha, true);
}
if ((obj.trophytext > 0 || obj.oldtrophytext > 0) && !script.running)
if (obj.trophytext > 0 || obj.oldtrophytext > 0)
{
graphics.drawtrophytext();
}