mirror of
https://github.com/TerryCavanagh/VVVVVV.git
synced 2025-01-08 18:09:45 +01:00
Add suggestions from style pass
Co-authored-by: Misa Elizabeth Kai <infoteddy@infoteddy.info>
This commit is contained in:
parent
234776bbec
commit
0edbf6398a
2 changed files with 194 additions and 216 deletions
|
@ -807,10 +807,8 @@ static void draw_entities(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
// Need to also check warp point destinations
|
// Need to also check warp point destinations
|
||||||
if (entity->t == 13 && ed.warp_token_entity != i)
|
if (entity->t == 13 && ed.warp_token_entity != i &&
|
||||||
{
|
entity->p1 / 40 == ed.levx && entity->p2 / 30 == ed.levy)
|
||||||
// Is the destination in this room?
|
|
||||||
if (entity->p1 / 40 == ed.levx && entity->p2 / 30 == ed.levy)
|
|
||||||
{
|
{
|
||||||
const int x = entity->p1 % 40 * 8;
|
const int x = entity->p1 % 40 * 8;
|
||||||
const int y = entity->p2 % 30 * 8;
|
const int y = entity->p2 % 30 * 8;
|
||||||
|
@ -832,7 +830,6 @@ static void draw_entities(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
static void draw_ghosts(void)
|
static void draw_ghosts(void)
|
||||||
{
|
{
|
||||||
|
@ -1024,24 +1021,24 @@ static void draw_tile_drawer(int tileset)
|
||||||
|
|
||||||
const int numtiles = (int)(texturewidth / 8) * (textureheight / 8);
|
const int numtiles = (int)(texturewidth / 8) * (textureheight / 8);
|
||||||
|
|
||||||
for (int x = 0; x < 40; x++)
|
for (int x = 0; x < SCREEN_WIDTH_TILES; x++)
|
||||||
{
|
{
|
||||||
for (int y = 0; y < 5; y++)
|
for (int y = 0; y < 5; y++)
|
||||||
{
|
{
|
||||||
if (tileset == 0)
|
if (tileset == 0)
|
||||||
{
|
{
|
||||||
graphics.drawtile(x * 8, (y * 8) - t2, (temp + numtiles + (y * 40) + x) % numtiles);
|
graphics.drawtile(x * 8, (y * 8) - t2, (temp + numtiles + (y * SCREEN_WIDTH_TILES) + x) % numtiles);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
graphics.drawtile2(x * 8, (y * 8) - t2, (temp + numtiles + (y * 40) + x) % numtiles);
|
graphics.drawtile2(x * 8, (y * 8) - t2, (temp + numtiles + (y * SCREEN_WIDTH_TILES) + x) % numtiles);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Highlight our little block
|
// Highlight our little block
|
||||||
graphics.draw_rect(((ed.direct_mode_tile % 40) * 8) - 2, 16 - t2 - 2, 12, 12, graphics.getRGB(255 - help.glow, 196, 196));
|
graphics.draw_rect(((ed.direct_mode_tile % SCREEN_WIDTH_TILES) * 8) - 2, 16 - t2 - 2, 12, 12, graphics.getRGB(255 - help.glow, 196, 196));
|
||||||
graphics.draw_rect(((ed.direct_mode_tile % 40) * 8) - 1, 16 - t2 - 1, 10, 10, graphics.getRGB(0, 0, 0));
|
graphics.draw_rect(((ed.direct_mode_tile % SCREEN_WIDTH_TILES) * 8) - 1, 16 - t2 - 1, 10, 10, graphics.getRGB(0, 0, 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ed.direct_mode_drawer > 0 && t2 <= 30)
|
if (ed.direct_mode_drawer > 0 && t2 <= 30)
|
||||||
|
@ -1302,8 +1299,6 @@ static void draw_main_ui(void)
|
||||||
|
|
||||||
void editorclass::draw_tool(EditorTools tool, int x, int y)
|
void editorclass::draw_tool(EditorTools tool, int x, int y)
|
||||||
{
|
{
|
||||||
extern editorclass ed;
|
|
||||||
|
|
||||||
switch (tool)
|
switch (tool)
|
||||||
{
|
{
|
||||||
case EditorTool_WALLS:
|
case EditorTool_WALLS:
|
||||||
|
@ -1340,7 +1335,7 @@ void editorclass::draw_tool(EditorTools tool, int x, int y)
|
||||||
graphics.drawtile(x + 8, y + 4, 1);
|
graphics.drawtile(x + 8, y + 4, 1);
|
||||||
break;
|
break;
|
||||||
case EditorTool_ENEMIES:
|
case EditorTool_ENEMIES:
|
||||||
graphics.draw_sprite(x, y, 78 + ed.entframe, 196, 196, 196);
|
graphics.draw_sprite(x, y, 78 + entframe, 196, 196, 196);
|
||||||
break;
|
break;
|
||||||
case EditorTool_GRAVITY_LINES:
|
case EditorTool_GRAVITY_LINES:
|
||||||
graphics.fill_rect(x + 2, y + 8, 12, 1, graphics.getRGB(255, 255, 255));
|
graphics.fill_rect(x + 2, y + 8, 12, 1, graphics.getRGB(255, 255, 255));
|
||||||
|
@ -1356,7 +1351,7 @@ void editorclass::draw_tool(EditorTools tool, int x, int y)
|
||||||
graphics.draw_rect(x + 4, y + 4, 8, 8, graphics.getRGB(96, 96, 96));
|
graphics.draw_rect(x + 4, y + 4, 8, 8, graphics.getRGB(96, 96, 96));
|
||||||
break;
|
break;
|
||||||
case EditorTool_WARP_TOKENS:
|
case EditorTool_WARP_TOKENS:
|
||||||
graphics.draw_sprite(x, y, 18 + (ed.entframe % 2), 196, 196, 196);
|
graphics.draw_sprite(x, y, 18 + (entframe % 2), 196, 196, 196);
|
||||||
break;
|
break;
|
||||||
case EditorTool_WARP_LINES:
|
case EditorTool_WARP_LINES:
|
||||||
graphics.fill_rect(x + 6, y + 2, 4, 12, graphics.getRGB(255, 255, 255));
|
graphics.fill_rect(x + 6, y + 2, 4, 12, graphics.getRGB(255, 255, 255));
|
||||||
|
@ -1383,7 +1378,6 @@ void editorrender(void)
|
||||||
switch (ed.state)
|
switch (ed.state)
|
||||||
{
|
{
|
||||||
case EditorState_DRAW:
|
case EditorState_DRAW:
|
||||||
{
|
|
||||||
// Draw the editor guidelines
|
// Draw the editor guidelines
|
||||||
draw_background_grid();
|
draw_background_grid();
|
||||||
|
|
||||||
|
@ -1461,47 +1455,46 @@ void editorrender(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
case EditorState_SCRIPTS:
|
case EditorState_SCRIPTS:
|
||||||
// Intended to look like Commodore 64's UI
|
// Intended to look like Commodore 64's UI
|
||||||
|
|
||||||
graphics.fill_rect(0, 0, 320, 240, graphics.getRGB(123, 111, 218));
|
graphics.fill_rect(0, 0, 320, 240, graphics.getRGB(123, 111, 218));
|
||||||
graphics.fill_rect(14, 16, 292, 208, graphics.getRGB(61, 48, 162));
|
graphics.fill_rect(14, 16, 292, 208, graphics.getRGB(61, 48, 162));
|
||||||
|
|
||||||
if (ed.substate == EditorSubState_MAIN)
|
switch (ed.substate)
|
||||||
{
|
{
|
||||||
|
case EditorSubState_MAIN:
|
||||||
font::print(PR_CEN, -1, 28, loc::gettext("**** VVVVVV SCRIPT EDITOR ****"), 123, 111, 218);
|
font::print(PR_CEN, -1, 28, loc::gettext("**** VVVVVV SCRIPT EDITOR ****"), 123, 111, 218);
|
||||||
font::print(PR_CEN, -1, 44, loc::gettext("PRESS ESC TO RETURN TO MENU"), 123, 111, 218);
|
font::print(PR_CEN, -1, 44, loc::gettext("PRESS ESC TO RETURN TO MENU"), 123, 111, 218);
|
||||||
|
|
||||||
if (!script.customscripts.empty())
|
if (script.customscripts.empty())
|
||||||
{
|
{
|
||||||
|
font::print(PR_CEN, -1, 110, loc::gettext("NO SCRIPT IDS FOUND"), 123, 111, 218);
|
||||||
|
font::print_wrap(PR_CEN, -1, 130, loc::gettext("CREATE A SCRIPT WITH EITHER THE TERMINAL OR SCRIPT BOX TOOLS"), 123, 111, 218, 10, 288);
|
||||||
|
break;
|
||||||
|
}
|
||||||
for (int i = 0; i < 9; i++)
|
for (int i = 0; i < 9; i++)
|
||||||
{
|
{
|
||||||
if (ed.script_list_offset + i < (int)script.customscripts.size())
|
const int offset = ed.script_list_offset + i;
|
||||||
|
const bool draw = offset < (int) script.customscripts.size();
|
||||||
|
if (!draw)
|
||||||
{
|
{
|
||||||
if (ed.script_list_offset + i == ed.selected_script)
|
continue;
|
||||||
|
}
|
||||||
|
if (offset == ed.selected_script)
|
||||||
{
|
{
|
||||||
std::string text_upper(loc::toupper(script.customscripts[(script.customscripts.size() - 1) - (ed.script_list_offset + i)].name));
|
std::string text_upper(loc::toupper(script.customscripts[script.customscripts.size() - 1 - offset].name));
|
||||||
|
|
||||||
char buffer[SCREEN_WIDTH_CHARS + 1];
|
char buffer[SCREEN_WIDTH_CHARS + 1];
|
||||||
vformat_buf(buffer, sizeof(buffer), loc::get_langmeta()->menu_select.c_str(), "label:str", text_upper.c_str());
|
vformat_buf(buffer, sizeof(buffer), loc::get_langmeta()->menu_select.c_str(), "label:str", text_upper.c_str());
|
||||||
font::print(PR_CEN, -1, 68 + (i * 16), buffer, 123, 111, 218);
|
font::print(PR_CEN, -1, 68 + (i * 16), buffer, 123, 111, 218);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
font::print(PR_CEN, -1, 68 + (i * 16), script.customscripts[(script.customscripts.size() - 1) - (ed.script_list_offset + i)].name, 123, 111, 218);
|
font::print(PR_CEN, -1, 68 + (i * 16), script.customscripts[script.customscripts.size() - 1 - offset].name, 123, 111, 218);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
break;
|
||||||
}
|
case EditorSubState_SCRIPTS_EDIT:
|
||||||
else
|
|
||||||
{
|
|
||||||
font::print(PR_CEN, -1, 110, loc::gettext("NO SCRIPT IDS FOUND"), 123, 111, 218);
|
|
||||||
font::print_wrap(PR_CEN, -1, 130, loc::gettext("CREATE A SCRIPT WITH EITHER THE TERMINAL OR SCRIPT BOX TOOLS"), 123, 111, 218, 10, 288);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (ed.substate == EditorSubState_SCRIPTS_EDIT)
|
|
||||||
{
|
{
|
||||||
// Draw the current script's name
|
// Draw the current script's name
|
||||||
graphics.fill_rect(14, 226, 292, 12, graphics.getRGB(61, 48, 162));
|
graphics.fill_rect(14, 226, 292, 12, graphics.getRGB(61, 48, 162));
|
||||||
|
@ -1529,6 +1522,10 @@ void editorrender(void)
|
||||||
{
|
{
|
||||||
font::print(PR_FONT_LEVEL | PR_CJK_LOW, 16 + font::len(PR_FONT_LEVEL, ed.script_buffer[ed.script_cursor_y].c_str()), 20 + ((ed.script_cursor_y - ed.script_offset) * font_height), "_", 123, 111, 218);
|
font::print(PR_FONT_LEVEL | PR_CJK_LOW, 16 + font::len(PR_FONT_LEVEL, ed.script_buffer[ed.script_cursor_y].c_str()), 20 + ((ed.script_cursor_y - ed.script_offset) * font_height), "_", 123, 111, 218);
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case EditorState_MENU:
|
case EditorState_MENU:
|
||||||
|
@ -1780,7 +1777,6 @@ static void input_submitted(void)
|
||||||
break;
|
break;
|
||||||
case TEXT_WEBSITE:
|
case TEXT_WEBSITE:
|
||||||
cl.website = key.keybuffer;
|
cl.website = key.keybuffer;
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case TEXT_DESC1:
|
case TEXT_DESC1:
|
||||||
cl.Desc1 = key.keybuffer;
|
cl.Desc1 = key.keybuffer;
|
||||||
|
@ -1892,7 +1888,7 @@ static void set_tile_interpolated(const int x1, const int x2, const int y1, cons
|
||||||
const int dx = x2 - x1;
|
const int dx = x2 - x1;
|
||||||
const int dy = y2 - y1;
|
const int dy = y2 - y1;
|
||||||
|
|
||||||
const int steps = SDL_max(abs(dx), abs(dy));
|
const int steps = SDL_max(SDL_abs(dx), SDL_abs(dy));
|
||||||
|
|
||||||
if (steps == 0)
|
if (steps == 0)
|
||||||
{
|
{
|
||||||
|
@ -1916,7 +1912,7 @@ void editorclass::handle_tile_placement(const int tile)
|
||||||
if (b_modifier)
|
if (b_modifier)
|
||||||
{
|
{
|
||||||
// Vertical line
|
// Vertical line
|
||||||
for (int i = 0; i < 30; i++)
|
for (int i = 0; i < SCREEN_HEIGHT_TILES; i++)
|
||||||
{
|
{
|
||||||
set_tile_interpolated(old_tilex, tilex, i, i, tile);
|
set_tile_interpolated(old_tilex, tilex, i, i, tile);
|
||||||
}
|
}
|
||||||
|
@ -1925,7 +1921,7 @@ void editorclass::handle_tile_placement(const int tile)
|
||||||
else if (h_modifier)
|
else if (h_modifier)
|
||||||
{
|
{
|
||||||
// Horizontal line
|
// Horizontal line
|
||||||
for (int i = 0; i < 40; i++)
|
for (int i = 0; i < SCREEN_WIDTH_TILES; i++)
|
||||||
{
|
{
|
||||||
set_tile_interpolated(i, i, old_tiley, tiley, tile);
|
set_tile_interpolated(i, i, old_tiley, tiley, tile);
|
||||||
}
|
}
|
||||||
|
@ -1979,7 +1975,7 @@ void editorclass::tool_remove()
|
||||||
|
|
||||||
for (size_t i = 0; i < customentities.size(); i++)
|
for (size_t i = 0; i < customentities.size(); i++)
|
||||||
{
|
{
|
||||||
if (customentities[i].x == tilex + (levx * 40) && customentities[i].y == tiley + (levy * 30))
|
if (customentities[i].x == tilex + (levx * SCREEN_WIDTH_TILES) && customentities[i].y == tiley + (levy * SCREEN_HEIGHT_TILES))
|
||||||
{
|
{
|
||||||
remove_entity(i);
|
remove_entity(i);
|
||||||
}
|
}
|
||||||
|
@ -2053,8 +2049,7 @@ void editorclass::entity_clicked(const int index)
|
||||||
|
|
||||||
void editorclass::tool_place()
|
void editorclass::tool_place()
|
||||||
{
|
{
|
||||||
|
const int entity = get_entity_at(tilex + (levx * SCREEN_WIDTH_TILES), tiley + (levy * SCREEN_HEIGHT_TILES));
|
||||||
const int entity = get_entity_at(tilex + (levx * 40), tiley + (levy * 30));
|
|
||||||
if (entity != -1)
|
if (entity != -1)
|
||||||
{
|
{
|
||||||
entity_clicked(entity);
|
entity_clicked(entity);
|
||||||
|
@ -2454,14 +2449,23 @@ static void start_at_checkpoint(void)
|
||||||
bool startpoint = false;
|
bool startpoint = false;
|
||||||
|
|
||||||
for (size_t i = 0; i < customentities.size(); i++)
|
for (size_t i = 0; i < customentities.size(); i++)
|
||||||
{
|
|
||||||
if (customentities[i].t == 16 || customentities[i].t == 10)
|
|
||||||
{
|
|
||||||
int tx = customentities[i].x / 40;
|
|
||||||
int ty = customentities[i].y / 30;
|
|
||||||
if (tx == ed.levx && ty == ed.levy)
|
|
||||||
{
|
{
|
||||||
startpoint = customentities[i].t == 16;
|
startpoint = customentities[i].t == 16;
|
||||||
|
const bool is_startpoint_or_checkpoint = startpoint ||
|
||||||
|
customentities[i].t == 10;
|
||||||
|
if (!is_startpoint_or_checkpoint)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
const int tx = customentities[i].x / 40;
|
||||||
|
const int ty = customentities[i].y / 30;
|
||||||
|
const bool in_room = tx == ed.levx && ty == ed.levy;
|
||||||
|
if (!in_room)
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
if (startpoint)
|
if (startpoint)
|
||||||
{
|
{
|
||||||
// Oh, there's a start point! Let's use this.
|
// Oh, there's a start point! Let's use this.
|
||||||
|
@ -2474,8 +2478,6 @@ static void start_at_checkpoint(void)
|
||||||
testeditor = i;
|
testeditor = i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (testeditor == -1)
|
if (testeditor == -1)
|
||||||
{
|
{
|
||||||
|
@ -2599,14 +2601,13 @@ static void handle_draw_input()
|
||||||
|
|
||||||
for (int i = 0; i < NUM_EditorTools; i++)
|
for (int i = 0; i < NUM_EditorTools; i++)
|
||||||
{
|
{
|
||||||
if (key.keymap[ed.tool_keys[i]])
|
if (key.keymap[ed.tool_keys[i]] &&
|
||||||
{
|
((shift_down && ed.tool_requires_shift[i]) ||
|
||||||
if ((shift_down && ed.tool_requires_shift[i]) || (!shift_down && !ed.tool_requires_shift[i]))
|
(!shift_down && !ed.tool_requires_shift[i])))
|
||||||
{
|
{
|
||||||
ed.current_tool = (EditorTools) i;
|
ed.current_tool = (EditorTools) i;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (key.keymap[SDLK_w])
|
if (key.keymap[SDLK_w])
|
||||||
{
|
{
|
||||||
|
@ -2899,9 +2900,7 @@ void editorinput(void)
|
||||||
ed.substate = EditorSubState_MAIN;
|
ed.substate = EditorSubState_MAIN;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (key.leftbutton)
|
if (key.leftbutton && ed.lclickdelay == 0)
|
||||||
{
|
|
||||||
if (ed.lclickdelay == 0)
|
|
||||||
{
|
{
|
||||||
if (ed.box_corner == BoxCorner_FIRST)
|
if (ed.box_corner == BoxCorner_FIRST)
|
||||||
{
|
{
|
||||||
|
@ -2949,7 +2948,6 @@ void editorinput(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ed.lclickdelay = 0;
|
ed.lclickdelay = 0;
|
||||||
|
@ -3575,7 +3573,7 @@ int editorclass::get_enemy_tile(int t)
|
||||||
|
|
||||||
void editorclass::set_tile(int x, int y, int t)
|
void editorclass::set_tile(int x, int y, int t)
|
||||||
{
|
{
|
||||||
if (x >= 0 && y >= 0 && x < 40 && y < 30)
|
if (x >= 0 && y >= 0 && x < SCREEN_WIDTH_TILES && y < SCREEN_HEIGHT_TILES)
|
||||||
{
|
{
|
||||||
cl.settile(levx, levy, x, y, t);
|
cl.settile(levx, levy, x, y, t);
|
||||||
}
|
}
|
||||||
|
@ -3774,86 +3772,66 @@ bool editorclass::is_background(int x, int y)
|
||||||
x = SDL_clamp(x, 0, 39);
|
x = SDL_clamp(x, 0, 39);
|
||||||
y = SDL_clamp(y, 0, 29);
|
y = SDL_clamp(y, 0, 29);
|
||||||
|
|
||||||
return (cl.gettile(levx, levy, x, y) >= 680);
|
const int tile = cl.gettile(levx, levy, x, y);
|
||||||
|
|
||||||
|
return tile >= 680 && tile <= 739;
|
||||||
}
|
}
|
||||||
|
|
||||||
int editorclass::backfree( int x, int y )
|
bool editorclass::backfree(int x, int y)
|
||||||
{
|
{
|
||||||
// Returns 0 if tile is not a block or background tile, 1 otherwise
|
|
||||||
x = SDL_clamp(x, 0, 39);
|
x = SDL_clamp(x, 0, 39);
|
||||||
y = SDL_clamp(y, 0, 29);
|
y = SDL_clamp(y, 0, 29);
|
||||||
|
|
||||||
if (x >= 0 && y >= 0 && x < 40 && y < 30)
|
const int tile = cl.gettile(levx, levy, x, y);
|
||||||
{
|
|
||||||
if (cl.gettile(levx, levy, x, y) == 0)
|
return tile == 0;
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool editorclass::lines_can_pass(int x, int y)
|
bool editorclass::lines_can_pass(int x, int y)
|
||||||
{
|
{
|
||||||
// Returns 0 if tile is not a block or spike, 1 otherwise
|
const int tile = cl.gettile(levx, levy, x, y);
|
||||||
|
if (x >= 0 && y >= 0 && x < SCREEN_WIDTH_TILES && y < SCREEN_HEIGHT_TILES)
|
||||||
if (x >= 0 && y >= 0 && x < 40 && y < 30)
|
|
||||||
{
|
{
|
||||||
return (cl.gettile(levx, levy, x, y) == 0) || (cl.gettile(levx, levy, x, y) >= 680);
|
return tile == 0 || tile >= 680;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int editorclass::free( int x, int y )
|
bool editorclass::free(int x, int y)
|
||||||
{
|
{
|
||||||
// Returns 0 if tile is not a block, 1 otherwise
|
|
||||||
|
|
||||||
x = SDL_clamp(x, 0, 39);
|
x = SDL_clamp(x, 0, 39);
|
||||||
y = SDL_clamp(y, 0, 29);
|
y = SDL_clamp(y, 0, 29);
|
||||||
|
|
||||||
if (cl.gettile(levx, levy, x, y) == 0)
|
const int tile = cl.gettile(levx, levy, x, y);
|
||||||
{
|
|
||||||
return 0;
|
return tile == 0 || (tile >= 2 && tile < 80) || tile >= 680;
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
if (cl.gettile(levx, levy, x, y) >= 2 && cl.gettile(levx, levy, x, y) < 80)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (cl.gettile(levx, levy, x, y) >= 680)
|
|
||||||
{
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int editorclass::match(int x, int y)
|
int editorclass::match(int x, int y)
|
||||||
{
|
{
|
||||||
if (free(x - 1, y) == 0 && free(x, y - 1) == 0 && free(x + 1, y) == 0 && free(x, y + 1) == 0) return 0;
|
if (free(x - 1, y) && free(x, y - 1) && free(x + 1, y) && free(x, y + 1)) return 0;
|
||||||
|
|
||||||
if (free(x - 1, y) == 0 && free(x, y - 1) == 0) return 10;
|
if (free(x - 1, y) && free(x, y - 1)) return 10;
|
||||||
if (free(x + 1, y) == 0 && free(x, y - 1) == 0) return 11;
|
if (free(x + 1, y) && free(x, y - 1)) return 11;
|
||||||
if (free(x - 1, y) == 0 && free(x, y + 1) == 0) return 12;
|
if (free(x - 1, y) && free(x, y + 1)) return 12;
|
||||||
if (free(x + 1, y) == 0 && free(x, y + 1) == 0) return 13;
|
if (free(x + 1, y) && free(x, y + 1)) return 13;
|
||||||
|
|
||||||
if (free(x, y - 1) == 0) return 1;
|
if (free(x, y - 1)) return 1;
|
||||||
if (free(x - 1, y) == 0) return 2;
|
if (free(x - 1, y)) return 2;
|
||||||
if (free(x, y + 1) == 0) return 3;
|
if (free(x, y + 1)) return 3;
|
||||||
if (free(x + 1, y) == 0) return 4;
|
if (free(x + 1, y)) return 4;
|
||||||
if (free(x - 1, y - 1) == 0) return 5;
|
if (free(x - 1, y - 1)) return 5;
|
||||||
if (free(x + 1, y - 1) == 0) return 6;
|
if (free(x + 1, y - 1)) return 6;
|
||||||
if (free(x - 1, y + 1) == 0) return 7;
|
if (free(x - 1, y + 1)) return 7;
|
||||||
if (free(x + 1, y + 1) == 0) return 8;
|
if (free(x + 1, y + 1)) return 8;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int editorclass::outsidematch(int x, int y)
|
int editorclass::outsidematch(int x, int y)
|
||||||
{
|
{
|
||||||
if (is_background(x - 1, y) == 0 && is_background(x + 1, y) == 0) return 2;
|
if (!is_background(x - 1, y) && !is_background(x + 1, y)) return 2;
|
||||||
if (is_background(x, y - 1) == 0 && is_background(x, y + 1) == 0) return 1;
|
if (!is_background(x, y - 1) && !is_background(x, y + 1)) return 1;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -3864,21 +3842,21 @@ int editorclass::backmatch( int x, int y )
|
||||||
// 5 1 6
|
// 5 1 6
|
||||||
// 2 X 4
|
// 2 X 4
|
||||||
// 7 3 8
|
// 7 3 8
|
||||||
if (backfree(x - 1, y) == 0 && backfree(x, y - 1) == 0 && backfree(x + 1, y) == 0 && backfree(x, y + 1) == 0) return 0;
|
if (backfree(x - 1, y) && backfree(x, y - 1) && backfree(x + 1, y) && backfree(x, y + 1)) return 0;
|
||||||
|
|
||||||
if (backfree(x - 1, y) == 0 && backfree(x, y - 1) == 0) return 10;
|
if (backfree(x - 1, y) && backfree(x, y - 1)) return 10;
|
||||||
if (backfree(x + 1, y) == 0 && backfree(x, y - 1) == 0) return 11;
|
if (backfree(x + 1, y) && backfree(x, y - 1)) return 11;
|
||||||
if (backfree(x - 1, y) == 0 && backfree(x, y + 1) == 0) return 12;
|
if (backfree(x - 1, y) && backfree(x, y + 1)) return 12;
|
||||||
if (backfree(x + 1, y) == 0 && backfree(x, y + 1) == 0) return 13;
|
if (backfree(x + 1, y) && backfree(x, y + 1)) return 13;
|
||||||
|
|
||||||
if (backfree(x, y - 1) == 0) return 1;
|
if (backfree(x, y - 1)) return 1;
|
||||||
if (backfree(x - 1, y) == 0) return 2;
|
if (backfree(x - 1, y)) return 2;
|
||||||
if (backfree(x, y + 1) == 0) return 3;
|
if (backfree(x, y + 1)) return 3;
|
||||||
if (backfree(x + 1, y) == 0) return 4;
|
if (backfree(x + 1, y)) return 4;
|
||||||
if (backfree(x - 1, y - 1) == 0) return 5;
|
if (backfree(x - 1, y - 1)) return 5;
|
||||||
if (backfree(x + 1, y - 1) == 0) return 6;
|
if (backfree(x + 1, y - 1)) return 6;
|
||||||
if (backfree(x - 1, y + 1) == 0) return 7;
|
if (backfree(x - 1, y + 1)) return 7;
|
||||||
if (backfree(x + 1, y + 1) == 0) return 8;
|
if (backfree(x + 1, y + 1)) return 8;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -4004,19 +3982,19 @@ int editorclass::backedgetile( int x, int y )
|
||||||
int editorclass::labspikedir(int x, int y, int t)
|
int editorclass::labspikedir(int x, int y, int t)
|
||||||
{
|
{
|
||||||
// a slightly more tricky case
|
// a slightly more tricky case
|
||||||
if (free(x, y + 1) == 1) return 63 + (t * 2);
|
if (!free(x, y + 1)) return 63 + (t * 2);
|
||||||
if (free(x, y - 1) == 1) return 64 + (t * 2);
|
if (!free(x, y - 1)) return 64 + (t * 2);
|
||||||
if (free(x - 1, y) == 1) return 51 + (t * 2);
|
if (!free(x - 1, y)) return 51 + (t * 2);
|
||||||
if (free(x + 1, y) == 1) return 52 + (t * 2);
|
if (!free(x + 1, y)) return 52 + (t * 2);
|
||||||
return 63 + (t * 2);
|
return 63 + (t * 2);
|
||||||
}
|
}
|
||||||
|
|
||||||
int editorclass::spikedir(int x, int y)
|
int editorclass::spikedir(int x, int y)
|
||||||
{
|
{
|
||||||
if (free(x, y + 1) == 1) return 8;
|
if (!free(x, y + 1)) return 8;
|
||||||
if (free(x, y - 1) == 1) return 9;
|
if (!free(x, y - 1)) return 9;
|
||||||
if (free(x - 1, y) == 1) return 49;
|
if (!free(x - 1, y)) return 49;
|
||||||
if (free(x + 1, y) == 1) return 50;
|
if (!free(x + 1, y)) return 50;
|
||||||
return 8;
|
return 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -129,7 +129,7 @@ public:
|
||||||
void entity_clicked(int index);
|
void entity_clicked(int index);
|
||||||
void tool_place();
|
void tool_place();
|
||||||
|
|
||||||
void get_input_line(const enum TextMode mode, const std::string& prompt, std::string* ptr);
|
void get_input_line(enum TextMode mode, const std::string& prompt, std::string* ptr);
|
||||||
|
|
||||||
void show_note(const char* text);
|
void show_note(const char* text);
|
||||||
|
|
||||||
|
@ -148,9 +148,9 @@ public:
|
||||||
TileTypes get_tile_type(int x, int y, bool wrap);
|
TileTypes get_tile_type(int x, int y, bool wrap);
|
||||||
|
|
||||||
bool is_background(int x, int y);
|
bool is_background(int x, int y);
|
||||||
int backfree(int x, int y);
|
bool backfree(int x, int y);
|
||||||
bool lines_can_pass(int x, int y);
|
bool lines_can_pass(int x, int y);
|
||||||
int free(int x, int y);
|
bool free(int x, int y);
|
||||||
int match(int x, int y);
|
int match(int x, int y);
|
||||||
int outsidematch(int x, int y);
|
int outsidematch(int x, int y);
|
||||||
int backmatch(int x, int y);
|
int backmatch(int x, int y);
|
||||||
|
|
Loading…
Reference in a new issue