X-Git-Url: https://git.artsoft.org/?a=blobdiff_plain;f=src%2Flibgame%2Fsystem.c;h=33246588592ebf6dab8b5da904fb314f9bd97492;hb=969000b44b047ef2d77619bd3882a3f09eb1787d;hp=a35f91d6827b3ffd7d6a772614519c31c350c8d4;hpb=de9f167f6960194e913af2a768456d502d4fdf1a;p=rocksndiamonds.git diff --git a/src/libgame/system.c b/src/libgame/system.c index a35f91d6..33246588 100644 --- a/src/libgame/system.c +++ b/src/libgame/system.c @@ -87,10 +87,10 @@ void InitProgramInfo(char *argv0, char *config_filename, char *userdata_subdir, program.cookie_prefix = cookie_prefix; + program.version_super = VERSION_SUPER(program_version); program.version_major = VERSION_MAJOR(program_version); program.version_minor = VERSION_MINOR(program_version); program.version_patch = VERSION_PATCH(program_version); - program.version_build = VERSION_BUILD(program_version); program.version_ident = program_version; program.version_string = program_version_string; @@ -318,13 +318,57 @@ void InitTileCursorInfo() tile_cursor.y = 0; tile_cursor.target_x = 0; tile_cursor.target_y = 0; + + tile_cursor.sx = 0; + tile_cursor.sy = 0; } void InitOverlayInfo() { + static char *default_grid_button[6][2] = + { + { " ", " ^^ " }, + { " ", " ^^ " }, + { " ", "<< >>" }, + { " ", "<< >>" }, + { "111222", " vv " }, + { "111222", " vv " } + }; + int min_xsize, min_ysize; + int startx, starty; + int x, y; + + min_xsize = MIN(6, DEFAULT_GRID_XSIZE); + min_ysize = MIN(6, DEFAULT_GRID_YSIZE); + + startx = DEFAULT_GRID_XSIZE - min_xsize; + starty = DEFAULT_GRID_YSIZE - min_ysize; + overlay.enabled = FALSE; overlay.active = FALSE; + overlay.show_grid = FALSE; + overlay.show_grid_buttons = FALSE; + + overlay.grid_xsize = DEFAULT_GRID_XSIZE; + overlay.grid_ysize = DEFAULT_GRID_YSIZE; + + for (x = 0; x < MAX_GRID_XSIZE; x++) + for (y = 0; y < MAX_GRID_YSIZE; y++) + overlay.grid_button[x][y] = CHAR_GRID_BUTTON_NONE; + + for (x = 0; x < min_xsize; x++) + for (y = 0; y < min_ysize; y++) + overlay.grid_button[x][starty + y] = + default_grid_button[y][0][x]; + + for (x = 0; x < min_xsize; x++) + for (y = 0; y < min_ysize; y++) + overlay.grid_button[startx + x][starty + y] = + default_grid_button[y][1][x]; + + overlay.grid_button_highlight = CHAR_GRID_BUTTON_NONE; + #if defined(PLATFORM_ANDROID) if (strEqual(setup.touch.control_type, TOUCH_CONTROL_VIRTUAL_BUTTONS)) overlay.enabled = TRUE; @@ -348,8 +392,8 @@ void SetTileCursorTargetXY(int x, int y) tile_cursor.xpos = x; tile_cursor.ypos = y; - tile_cursor.target_x = gfx.sx + x * gfx.game_tile_size; - tile_cursor.target_y = gfx.sy + y * gfx.game_tile_size; + tile_cursor.target_x = tile_cursor.sx + x * gfx.game_tile_size; + tile_cursor.target_y = tile_cursor.sy + y * gfx.game_tile_size; tile_cursor.moving = TRUE; } @@ -366,6 +410,12 @@ void SetTileCursorXY(int x, int y) tile_cursor.moving = FALSE; } +void SetTileCursorSXSY(int sx, int sy) +{ + tile_cursor.sx = sx; + tile_cursor.sy = sy; +} + void SetOverlayEnabled(boolean enabled) { overlay.enabled = enabled; @@ -376,6 +426,17 @@ void SetOverlayActive(boolean active) overlay.active = active; } +void SetOverlayShowGrid(boolean show_grid) +{ + overlay.show_grid = show_grid; + overlay.show_grid_buttons = show_grid; + + SetOverlayActive(show_grid); + + if (show_grid) + SetOverlayEnabled(TRUE); +} + boolean GetOverlayActive() { return overlay.active;