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

Fix gravity/warp lines being modified during draw

While warp lines were being drawn, they also got resized to
automatically fit between collision. In renderfixed, gravity lines are
resized the same way. Doing logic while drawing is very poor practice,
so resizing of these has been moved into logic, and merged together.

Aside from some more cleanup, this commit also removes the very poorly
done right click emulation, when you hold CTRL and click. It never
worked well in the past, and even requires a right click to use, so
there's not really any point to keeping it around.
This commit is contained in:
AllyTally 2023-03-02 16:28:02 -04:00 committed by Misa Elizabeth Kai
parent 84c6d44c52
commit 7b5ef40926
2 changed files with 128 additions and 153 deletions

View file

@ -977,6 +977,66 @@ static void draw_edgeguides(void)
} }
} }
static void update_entities(void)
{
extern editorclass ed;
for (size_t i = 0; i < customentities.size(); ++i)
{
CustomEntity* entity = &customentities[i];
if (entity->x / 40 != ed.levx || entity->y / 30 != ed.levy)
{
// It's not in this room, so just continue
continue;
}
bool grav_line = (entity->t == 11);
bool warp_line = (entity->t == 50);
if ((grav_line || warp_line) && entity->p4 != 1)
{
// If it's a grav line or a warp line, and it's not locked
if ((grav_line && entity->p1 == 0) || (warp_line && entity->p1 >= 2))
{
/* Horizontal */
int tx = entity->x % 40;
int tx2 = tx;
int ty = entity->y % 30;
while (!ed.spikefree(tx, ty))
{
--tx;
}
while (!ed.spikefree(tx2, ty))
{
++tx2;
}
++tx;
entity->p2 = tx;
entity->p3 = (tx2 - tx) * 8;
}
else
{
/* Vertical */
int tx = entity->x % 40;
int ty = entity->y % 30;
int ty2 = ty;
while (!ed.spikefree(tx, ty))
{
--ty;
}
while (!ed.spikefree(tx, ty2))
{
++ty2;
}
++ty;
entity->p2 = ty;
entity->p3 = (ty2 - ty) * 8;
}
}
}
}
static void draw_entities(void) static void draw_entities(void)
{ {
extern editorclass ed; extern editorclass ed;
@ -1200,50 +1260,17 @@ static void draw_entities(void)
case 50: // Warp Lines case 50: // Warp Lines
if (entity->p1 >= 2) // Horizontal if (entity->p1 >= 2) // Horizontal
{ {
int left = x / 8;
int right = left;
int tile_y = y / 8;
if (entity->p4 != 1) int left = entity->p2;
{ int right = left + entity->p3 / 8;
// Unlocked
while (ed.free(left, tile_y) == 0) left--;
while (ed.free(right, tile_y) == 0) right++;
left++;
entity->p2 = left;
entity->p3 = (right - left) * 8;
}
else
{
// Locked
left = entity->p2;
right = left + entity->p3 / 8;
}
graphics.draw_rect((left * 8), y + 1, (right - left) * 8, 6, graphics.getRGB(194, 255, 255)); graphics.draw_rect((left * 8), y + 1, (right - left) * 8, 6, graphics.getRGB(194, 255, 255));
graphics.draw_rect(x, y, 8, 8, graphics.getRGB(164, 255, 255)); graphics.draw_rect(x, y, 8, 8, graphics.getRGB(164, 255, 255));
} }
else // Vertical else // Vertical
{ {
int tile_x = x / 8; int top = entity->p2;
int top = y / 8; int bottom = top + entity->p3 / 8;
int bottom = top;
if (entity->p4 != 1)
{
// Unlocked
while (ed.free(tile_x, top) == 0) top--;
while (ed.free(tile_x, bottom) == 0) bottom++;
top++;
entity->p2 = top;
entity->p3 = (bottom - top) * 8;
}
else
{
// Locked
top = entity->p2;
bottom = top + entity->p3 / 8;
}
graphics.draw_rect(x + 1, (top * 8), 6, (bottom - top) * 8, graphics.getRGB(194, 255, 255)); graphics.draw_rect(x + 1, (top * 8), 6, (bottom - top) * 8, graphics.getRGB(194, 255, 255));
graphics.draw_rect(x, y, 8, 8, graphics.getRGB(164, 255, 255)); graphics.draw_rect(x, y, 8, 8, graphics.getRGB(164, 255, 255));
@ -1418,6 +1445,8 @@ static void draw_cursor(void)
static void draw_tile_toolbox(int tileset) static void draw_tile_toolbox(int tileset)
{ {
extern editorclass ed;
// Tile toolbox for direct mode // Tile toolbox for direct mode
int t2 = 0; int t2 = 0;
if (ed.dmtileeditor > 0) if (ed.dmtileeditor > 0)
@ -1898,12 +1927,13 @@ void editorrenderfixed(void)
ghost.realcol = graphics.getcol(ghost.col); ghost.realcol = graphics.getcol(ghost.col);
} }
if (ed.currentghosts + 1 < (int) ed.ghosts.size()) {
ed.currentghosts++; ed.currentghosts++;
if (ed.zmod) ed.currentghosts++; if (ed.zmod)
} else { {
ed.currentghosts = (int) ed.ghosts.size() - 1; ed.currentghosts++;
} }
ed.currentghosts = SDL_min(ed.currentghosts, ed.ghosts.size());
} }
if (!ed.settingsmod) if (!ed.settingsmod)
@ -1931,57 +1961,6 @@ void editorrenderfixed(void)
graphics.updatetowerbackground(graphics.titlebg); graphics.updatetowerbackground(graphics.titlebg);
} }
/* Correct gravity lines */
for (size_t i = 0; i < customentities.size(); ++i)
{
if (customentities[i].x / 40 != ed.levx
|| customentities[i].y / 30 != ed.levy
|| customentities[i].t != 11
/* Is the gravity line locked? */
|| customentities[i].p4 == 1)
{
continue;
}
if (customentities[i].p1 == 0)
{
/* Horizontal */
int tx = customentities[i].x % 40;
int tx2 = tx;
int ty = customentities[i].y % 30;
while (!ed.spikefree(tx, ty))
{
--tx;
}
while (!ed.spikefree(tx2, ty))
{
++tx2;
}
++tx;
customentities[i].p2 = tx;
customentities[i].p3 = (tx2 - tx) * 8;
}
else
{
/* Vertical */
int tx = customentities[i].x % 40;
int ty = customentities[i].y % 30;
int ty2 = ty;
/* Unlocked */
while (!ed.spikefree(tx, ty))
{
--ty;
}
while (!ed.spikefree(tx, ty2))
{
++ty2;
}
++ty;
customentities[i].p2 = ty;
customentities[i].p3 = (ty2 - ty) * 8;
}
}
if (cl.getroomprop(ed.levx, ed.levy)->directmode == 1) if (cl.getroomprop(ed.levx, ed.levy)->directmode == 1)
{ {
if (ed.dmtileeditor > 0) if (ed.dmtileeditor > 0)
@ -2035,17 +2014,16 @@ void editorlogic(void)
graphics.titlebg.bscroll = -2; graphics.titlebg.bscroll = -2;
ed.entframedelay--; ed.entframedelay--;
if(ed.entframedelay<=0) if (ed.entframedelay <= 0)
{ {
ed.entframe=(ed.entframe+1)%4; ed.entframe = (ed.entframe + 1) % 4;
ed.entframedelay=8; ed.entframedelay = 8;
} }
ed.oldnotedelay = ed.notedelay; ed.oldnotedelay = ed.notedelay;
if(ed.notedelay>0) ed.notedelay = SDL_max(ed.notedelay - 1, 0);
{
ed.notedelay--; update_entities();
}
if (graphics.fademode == FADE_FULLY_BLACK) if (graphics.fademode == FADE_FULLY_BLACK)
{ {
@ -2214,8 +2192,10 @@ static void editormenuactionpress(void)
cl.levmusic--; cl.levmusic--;
break; break;
} }
cl.levmusic = (cl.levmusic % 16 + 16) % 16;
if(cl.levmusic>0) cl.levmusic = POS_MOD(cl.levmusic, 16);
if (cl.levmusic > 0)
{ {
music.play(cl.levmusic); music.play(cl.levmusic);
} }
@ -2223,6 +2203,7 @@ static void editormenuactionpress(void)
{ {
music.haltdasmusik(); music.haltdasmusik();
} }
music.playef(11); music.playef(11);
break; break;
case 2: case 2:
@ -2238,9 +2219,9 @@ static void editormenuactionpress(void)
{ {
case 0: case 0:
//Saving and quit //Saving and quit
ed.saveandquit=true; ed.saveandquit = true;
ed.settingsmod=false; ed.settingsmod = false;
map.nexttowercolour(); map.nexttowercolour();
ed.keydelay = 6; ed.keydelay = 6;
@ -2331,10 +2312,10 @@ void editorinput(void)
game.press_action = true; game.press_action = true;
}; };
if (key.keymap[SDLK_F9] && (ed.keydelay==0)) { if (key.keymap[SDLK_F9] && (ed.keydelay == 0)) {
ed.keydelay = 30; ed.keydelay = 30;
ed.note=loc::gettext("Reloaded resources"); ed.note = loc::gettext("Reloaded resources");
ed.notedelay=45; ed.notedelay = 45;
graphics.reloadresources(); graphics.reloadresources();
} }
@ -2445,11 +2426,6 @@ void editorinput(void)
ed.settingskey=false; ed.settingskey=false;
} }
if(key.keymap[SDLK_LCTRL] || key.keymap[SDLK_RCTRL])
{
if(key.leftbutton) key.rightbutton=true;
}
if(ed.scripteditmod) if(ed.scripteditmod)
{ {
if(ed.scripthelppage==0) if(ed.scripthelppage==0)
@ -2971,28 +2947,27 @@ void editorinput(void)
if (up_pressed || down_pressed || left_pressed || right_pressed) if (up_pressed || down_pressed || left_pressed || right_pressed)
{ {
ed.keydelay=6; ed.keydelay = 6;
if(up_pressed) if (up_pressed)
{ {
cl.mapheight--; cl.mapheight--;
} }
else if(down_pressed) else if (down_pressed)
{ {
cl.mapheight++; cl.mapheight++;
} }
else if(left_pressed) else if (left_pressed)
{ {
cl.mapwidth--; cl.mapwidth--;
} }
else if(right_pressed) else if (right_pressed)
{ {
cl.mapwidth++; cl.mapwidth++;
} }
if(cl.mapwidth<1) cl.mapwidth=1; cl.mapwidth = SDL_clamp(cl.mapwidth, 1, cl.maxwidth);
if(cl.mapheight<1) cl.mapheight=1; cl.mapheight = SDL_clamp(cl.mapheight, 1, cl.maxheight);
if(cl.mapwidth>=cl.maxwidth) cl.mapwidth=cl.maxwidth;
if(cl.mapheight>=cl.maxheight) cl.mapheight=cl.maxheight;
char buffer[3*SCREEN_WIDTH_CHARS + 1]; char buffer[3*SCREEN_WIDTH_CHARS + 1];
vformat_buf( vformat_buf(
buffer, sizeof(buffer), buffer, sizeof(buffer),
@ -3000,22 +2975,23 @@ void editorinput(void)
"width:int, height:int", "width:int, height:int",
cl.mapwidth, cl.mapheight cl.mapwidth, cl.mapheight
); );
ed.note = buffer; ed.note = buffer;
ed.notedelay=45; ed.notedelay = 45;
} }
if(!ed.shiftkey) if (!ed.shiftkey)
{ {
if(ed.shiftmenu) if (ed.shiftmenu)
{ {
ed.shiftmenu=false; ed.shiftmenu = false;
} }
else else
{ {
ed.shiftmenu=true; ed.shiftmenu = true;
} }
} }
ed.shiftkey=true; ed.shiftkey = true;
} }
else else
{ {
@ -3122,19 +3098,19 @@ void editorinput(void)
game.mapheld=true; game.mapheld=true;
//Ok! Scan the room for the closest checkpoint //Ok! Scan the room for the closest checkpoint
int testeditor=-1; int testeditor = -1;
bool startpoint = false; bool startpoint = false;
//First up; is there a start point on this screen? //First up; is there a start point on this screen?
for(size_t i=0; i<customentities.size(); i++) for (size_t i = 0; i < customentities.size(); i++)
{ {
//if() on screen //if() on screen
if(customentities[i].t==16 && testeditor==-1) if (customentities[i].t == 16 && testeditor == -1)
{ {
int tx=customentities[i].x/40; int tx = customentities[i].x / 40;
int ty=customentities[i].y/30; int ty = customentities[i].y / 30;
if(tx==ed.levx && ty==ed.levy) if (tx == ed.levx && ty == ed.levy)
{ {
testeditor=i; testeditor = i;
startpoint = true; startpoint = true;
} }
} }
@ -3142,16 +3118,16 @@ void editorinput(void)
if(testeditor==-1) if(testeditor==-1)
{ {
//Ok, settle for a check point //Ok, settle for a check point
for(size_t i=0; i<customentities.size(); i++) for (size_t i = 0; i < customentities.size(); i++)
{ {
//if() on screen //if() on screen
if(customentities[i].t==10 && testeditor==-1) if (customentities[i].t == 10 && testeditor == -1)
{ {
int tx=customentities[i].x/40; int tx = customentities[i].x / 40;
int ty=customentities[i].y/30; int ty = customentities[i].y / 30;
if(tx==ed.levx && ty==ed.levy) if (tx == ed.levx && ty == ed.levy)
{ {
testeditor=i; testeditor = i;
} }
} }
} }
@ -3189,15 +3165,15 @@ void editorinput(void)
else else
{ {
//Start point spawn //Start point spawn
int tx=customentities[testeditor].x/40; int tx = customentities[testeditor].x / 40;
int ty=customentities[testeditor].y/30; int ty = customentities[testeditor].y / 30;
game.edsavex = (customentities[testeditor].x%40)*8 - 4; game.edsavex = (customentities[testeditor].x % 40) * 8 - 4;
game.edsavey = (customentities[testeditor].y%30)*8; game.edsavey = (customentities[testeditor].y % 30) * 8;
game.edsaverx = 100+tx; game.edsaverx = 100 + tx;
game.edsavery = 100+ty; game.edsavery = 100 + ty;
game.edsavegc = 0; game.edsavegc = 0;
game.edsavey++; game.edsavey++;
game.edsavedir=1-customentities[testeditor].p1; game.edsavedir = 1 - customentities[testeditor].p1;
} }
music.haltdasmusik(); music.haltdasmusik();
@ -3218,12 +3194,12 @@ void editorinput(void)
if(key.keymap[SDLK_COMMA]) if(key.keymap[SDLK_COMMA])
{ {
ed.current_tool = (EditorTools) POS_MOD(ed.current_tool - 1, NUM_EditorTools); ed.current_tool = (EditorTools) POS_MOD(ed.current_tool - 1, NUM_EditorTools);
ed.keydelay=6; ed.keydelay = 6;
} }
else if(key.keymap[SDLK_PERIOD]) else if(key.keymap[SDLK_PERIOD])
{ {
ed.current_tool = (EditorTools) POS_MOD(ed.current_tool + 1, NUM_EditorTools); ed.current_tool = (EditorTools) POS_MOD(ed.current_tool + 1, NUM_EditorTools);
ed.keydelay=6; ed.keydelay = 6;
} }
if(up_pressed) if(up_pressed)
@ -3259,10 +3235,9 @@ void editorinput(void)
graphics.backgrounddrawn = false; graphics.backgrounddrawn = false;
} }
if (ed.levx < 0) ed.levx += cl.mapwidth; ed.levx = POS_MOD(ed.levx, cl.mapwidth);
if (ed.levx >= cl.mapwidth) ed.levx -= cl.mapwidth; ed.levy = POS_MOD(ed.levy, cl.mapheight);
if (ed.levy < 0) ed.levy += cl.mapheight;
if (ed.levy >= cl.mapheight) ed.levy -= cl.mapheight;
if (key.keymap[SDLK_SPACE]) if (key.keymap[SDLK_SPACE])
{ {
ed.spacemod = !ed.spacemod; ed.spacemod = !ed.spacemod;

View file

@ -185,9 +185,9 @@ static const inline struct ImplFunc* get_gamestate_funcs(
FUNC_LIST_BEGIN(EDITORMODE) FUNC_LIST_BEGIN(EDITORMODE)
{Func_fixed, flipmodeoff}, {Func_fixed, flipmodeoff},
{Func_input, editorinput}, {Func_input, editorinput},
{Func_fixed, editorlogic},
{Func_fixed, editorrenderfixed}, {Func_fixed, editorrenderfixed},
{Func_delta, editorrender}, {Func_delta, editorrender},
{Func_fixed, editorlogic},
FUNC_LIST_END FUNC_LIST_END
#endif #endif