#define SETUP_MODE_CHOOSE_TOUCH_CONTROL 28
#define SETUP_MODE_CHOOSE_MOVE_DISTANCE 29
#define SETUP_MODE_CHOOSE_DROP_DISTANCE 30
+#define SETUP_MODE_CHOOSE_TRANSPARENCY 31
+#define SETUP_MODE_CHOOSE_GRID_XSIZE_0 32
+#define SETUP_MODE_CHOOSE_GRID_YSIZE_0 33
+#define SETUP_MODE_CHOOSE_GRID_XSIZE_1 34
+#define SETUP_MODE_CHOOSE_GRID_YSIZE_1 35
+#define SETUP_MODE_CONFIG_VIRT_BUTTONS 36
-#define MAX_SETUP_MODES 31
+#define MAX_SETUP_MODES 37
#define MAX_MENU_MODES MAX(MAX_INFO_MODES, MAX_SETUP_MODES)
+/* setup screen titles */
+#define STR_SETUP_MAIN "Setup"
+#define STR_SETUP_GAME "Game & Menu"
+#define STR_SETUP_EDITOR "Editor"
+#define STR_SETUP_GRAPHICS "Graphics"
+#define STR_SETUP_SOUND "Sound & Music"
+#define STR_SETUP_ARTWORK "Custom Artwork"
+#define STR_SETUP_INPUT "Input Devices"
+#define STR_SETUP_TOUCH "Touch Controls"
+#define STR_SETUP_SHORTCUTS "Key Shortcuts"
+#define STR_SETUP_EXIT "Exit"
+#define STR_SETUP_SAVE_AND_EXIT "Save and Exit"
+
+#define STR_SETUP_CHOOSE_GAME_SPEED "Game Speed"
+#define STR_SETUP_CHOOSE_SCROLL_DELAY "Scroll Delay"
+#define STR_SETUP_CHOOSE_SNAPSHOT_MODE "Snapshot Mode"
+#define STR_SETUP_CHOOSE_WINDOW_SIZE "Window Scaling"
+#define STR_SETUP_CHOOSE_SCALING_TYPE "Anti-Aliasing"
+#define STR_SETUP_CHOOSE_RENDERING "Rendering Mode"
+#define STR_SETUP_CHOOSE_VOLUME_SIMPLE "Sound Volume"
+#define STR_SETUP_CHOOSE_VOLUME_LOOPS "Loops Volume"
+#define STR_SETUP_CHOOSE_VOLUME_MUSIC "Music Volume"
+#define STR_SETUP_CHOOSE_TOUCH_CONTROL "Control Type"
+#define STR_SETUP_CHOOSE_MOVE_DISTANCE "Move Distance"
+#define STR_SETUP_CHOOSE_DROP_DISTANCE "Drop Distance"
+#define STR_SETUP_CHOOSE_TRANSPARENCY "Transparency"
+#define STR_SETUP_CHOOSE_GRID_XSIZE_0 "Horiz. Buttons"
+#define STR_SETUP_CHOOSE_GRID_YSIZE_0 "Vert. Buttons"
+#define STR_SETUP_CHOOSE_GRID_XSIZE_1 "Horiz. Buttons"
+#define STR_SETUP_CHOOSE_GRID_YSIZE_1 "Vert. Buttons"
+
/* for input setup functions */
#define SETUPINPUT_SCREEN_POS_START 0
-#define SETUPINPUT_SCREEN_POS_END (SCR_FIELDY - 4)
-#define SETUPINPUT_SCREEN_POS_EMPTY1 (SETUPINPUT_SCREEN_POS_START + 3)
-#define SETUPINPUT_SCREEN_POS_EMPTY2 (SETUPINPUT_SCREEN_POS_END - 1)
+#define SETUPINPUT_SCREEN_POS_EMPTY1 3
+#define SETUPINPUT_SCREEN_POS_EMPTY2 12
+#define SETUPINPUT_SCREEN_POS_END 13
+
+#define MENU_SETUP_FONT_TITLE FONT_TEXT_1
+#define MENU_SETUP_FONT_TEXT FONT_TITLE_2
/* for various menu stuff */
#define MENU_SCREEN_START_XPOS 1
#define MENU_SCREEN_MAX_XPOS (SCR_FIELDX - 1)
#define MENU_TITLE1_YPOS 8
#define MENU_TITLE2_YPOS 46
-#define MENU_SCREEN_INFO_XSTART 16
-#define MENU_SCREEN_INFO_YSTART1 100
-#define MENU_SCREEN_INFO_YSTART2 128
+#define MENU_INFO_FONT_TITLE FONT_TEXT_1
+#define MENU_INFO_FONT_HEAD FONT_TEXT_2
+#define MENU_INFO_FONT_TEXT FONT_TEXT_3
+#define MENU_INFO_FONT_FOOT FONT_TEXT_4
+#define MENU_INFO_SPACE_HEAD (menu.headline2_spacing_info[info_mode])
+#define MENU_SCREEN_INFO_SPACE_LEFT (menu.left_spacing_info[info_mode])
+#define MENU_SCREEN_INFO_SPACE_RIGHT (menu.right_spacing_info[info_mode])
+#define MENU_SCREEN_INFO_SPACE_TOP (menu.top_spacing_info[info_mode])
+#define MENU_SCREEN_INFO_SPACE_BOTTOM (menu.bottom_spacing_info[info_mode])
+#define MENU_SCREEN_INFO_YSTART1 MENU_SCREEN_INFO_SPACE_TOP
+#define MENU_SCREEN_INFO_YSTART2 (MENU_SCREEN_INFO_YSTART1 + \
+ getMenuTextStep(MENU_INFO_SPACE_HEAD, \
+ MENU_INFO_FONT_TITLE))
#define MENU_SCREEN_INFO_YSTEP (TILEY + 4)
-#define MENU_SCREEN_INFO_YBOTTOM (SYSIZE - 20)
+#define MENU_SCREEN_INFO_YBOTTOM (SYSIZE - MENU_SCREEN_INFO_SPACE_BOTTOM)
#define MENU_SCREEN_INFO_YSIZE (MENU_SCREEN_INFO_YBOTTOM - \
MENU_SCREEN_INFO_YSTART2 - \
TILEY / 2)
static void HandleSetupScreen_Input(int, int, int, int, int);
static void CustomizeKeyboard(int);
static void ConfigureJoystick(int);
+static void ConfigureVirtualButtons();
static void execSetupGame(void);
static void execSetupGraphics(void);
static void execSetupSound(void);
static TreeInfo *drop_distances = NULL;
static TreeInfo *drop_distance_current = NULL;
+static TreeInfo *transparencies = NULL;
+static TreeInfo *transparency_current = NULL;
+
+static TreeInfo *grid_sizes[2][2] = { { NULL, NULL }, { NULL, NULL } };
+static TreeInfo *grid_size_current[2][2] = { { NULL, NULL }, { NULL, NULL } };
+
static TreeInfo *level_number = NULL;
static TreeInfo *level_number_current = NULL;
char *text;
} scaling_types_list[] =
{
- { SCALING_QUALITY_NEAREST, "None" },
+ { SCALING_QUALITY_NEAREST, "Off" },
{ SCALING_QUALITY_LINEAR, "Linear" },
{ SCALING_QUALITY_BEST, "Anisotropic" },
char *text;
} touch_controls_list[] =
{
+ { TOUCH_CONTROL_OFF, "Off" },
{ TOUCH_CONTROL_VIRTUAL_BUTTONS, "Virtual Buttons" },
{ TOUCH_CONTROL_WIPE_GESTURES, "Wipe Gestures" },
{ TOUCH_CONTROL_FOLLOW_FINGER, "Follow Finger" },
{ -1, NULL },
};
+static struct
+{
+ int value;
+ char *text;
+} transparencies_list[] =
+{
+ { 0, "0 % (Opaque)" },
+ { 10, "10 %" },
+ { 20, "20 %" },
+ { 30, "30 %" },
+ { 40, "40 %" },
+ { 50, "50 %" },
+ { 60, "60 %" },
+ { 70, "70 %" },
+ { 80, "80 %" },
+ { 90, "90 %" },
+ { 100, "100 % (Invisible)" },
+
+ { -1, NULL },
+};
+
+static struct
+{
+ int value;
+ char *text;
+} grid_sizes_list[] =
+{
+ { 3, "3" },
+ { 4, "4" },
+ { 5, "5" },
+ { 6, "6" },
+ { 7, "7" },
+ { 8, "8" },
+ { 9, "9" },
+ { 10, "10" },
+ { 11, "11" },
+ { 12, "12" },
+ { 13, "13" },
+ { 14, "14" },
+ { 15, "15" },
+ { 16, "16" },
+ { 17, "17" },
+ { 18, "18" },
+ { 19, "19" },
+ { 20, "20" },
+ { 21, "21" },
+ { 22, "22" },
+ { 23, "23" },
+ { 24, "24" },
+ { 25, "25" },
+ { 26, "26" },
+ { 27, "27" },
+ { 28, "28" },
+ { 29, "29" },
+ { 30, "30" },
+ { 31, "31" },
+ { 32, "32" },
+
+ { -1, NULL },
+};
+
#define DRAW_MODE(s) ((s) >= GAME_MODE_MAIN && \
(s) <= GAME_MODE_SETUP ? (s) : \
(s) == GAME_MODE_PSEUDO_TYPENAME ? \
GAME_MODE_MAIN : GAME_MODE_DEFAULT)
/* (there are no draw offset definitions needed for INFO_MODE_TITLE) */
-#define DRAW_MODE_INFO(i) ((i) >= INFO_MODE_ELEMENTS && \
+#define DRAW_MODE_INFO(i) ((i) >= INFO_MODE_TITLE && \
(i) <= INFO_MODE_LEVELSET ? (i) : \
INFO_MODE_MAIN)
#define DRAW_YOFFSET_INFO(i) (DRAW_MODE_INFO(i) == INFO_MODE_MAIN ? \
menu.draw_yoffset[GAME_MODE_INFO] : \
menu.draw_yoffset_info[DRAW_MODE_INFO(i)])
+#define EXTRA_SPACING_INFO(i) (DRAW_MODE_INFO(i) == INFO_MODE_MAIN ? \
+ menu.extra_spacing[GAME_MODE_INFO] : \
+ menu.extra_spacing_info[DRAW_MODE_INFO(i)])
#define DRAW_XOFFSET_SETUP(i) (DRAW_MODE_SETUP(i) == SETUP_MODE_MAIN ? \
menu.draw_xoffset[GAME_MODE_SETUP] : \
#define DRAW_YOFFSET_SETUP(i) (DRAW_MODE_SETUP(i) == SETUP_MODE_MAIN ? \
menu.draw_yoffset[GAME_MODE_SETUP] : \
menu.draw_yoffset_setup[DRAW_MODE_SETUP(i)])
+#define EXTRA_SPACING_SETUP(i) (DRAW_MODE_SETUP(i) == SETUP_MODE_MAIN ? \
+ menu.extra_spacing[GAME_MODE_SETUP] : \
+ menu.extra_spacing_setup[DRAW_MODE_SETUP(i)])
#define DRAW_XOFFSET(s) ((s) == GAME_MODE_INFO ? \
DRAW_XOFFSET_INFO(info_mode) : \
(s) == GAME_MODE_SETUP ? \
DRAW_YOFFSET_SETUP(setup_mode) : \
menu.draw_yoffset[DRAW_MODE(s)])
+#define EXTRA_SPACING(s) ((s) == GAME_MODE_INFO ? \
+ EXTRA_SPACING_INFO(info_mode) : \
+ (s) == GAME_MODE_SETUP ? \
+ EXTRA_SPACING_SETUP(setup_mode) : \
+ menu.extra_spacing[DRAW_MODE(s)])
#define mSX (SX + DRAW_XOFFSET(game_status))
#define mSY (SY + DRAW_YOFFSET(game_status))
static char *main_text_level_imported_from = NULL;
static char *main_text_level_imported_by = NULL;
static char *main_text_level_tested_by = NULL;
+static char *main_text_title_1 = NULL;
+static char *main_text_title_2 = NULL;
+static char *main_text_title_3 = NULL;
struct MainControlInfo
{
#endif
{
MAIN_CONTROL_FIRST_LEVEL,
- NULL, -1,
+ &menu.main.button.first_level, IMG_MENU_BUTTON_FIRST_LEVEL,
&menu.main.text.first_level, &main_text_first_level,
NULL, NULL,
},
{
MAIN_CONTROL_LAST_LEVEL,
- NULL, -1,
+ &menu.main.button.last_level, IMG_MENU_BUTTON_LAST_LEVEL,
&menu.main.text.last_level, &main_text_last_level,
NULL, NULL,
},
{
MAIN_CONTROL_LEVEL_NUMBER,
- NULL, -1,
+ &menu.main.button.level_number, IMG_MENU_BUTTON_LEVEL_NUMBER,
&menu.main.text.level_number, &main_text_level_number,
NULL, NULL,
},
{
MAIN_CONTROL_TITLE_1,
NULL, -1,
- &menu.main.text.title_1, &setup.internal.program_title,
+ &menu.main.text.title_1, &main_text_title_1,
NULL, NULL,
},
{
MAIN_CONTROL_TITLE_2,
NULL, -1,
- &menu.main.text.title_2, &setup.internal.program_copyright,
+ &menu.main.text.title_2, &main_text_title_2,
NULL, NULL,
},
{
MAIN_CONTROL_TITLE_3,
NULL, -1,
- &menu.main.text.title_3, &setup.internal.program_company,
+ &menu.main.text.title_3, &main_text_title_3,
NULL, NULL,
},
main_text_level_imported_by = leveldir_current->imported_by;
main_text_level_tested_by = leveldir_current->tested_by;
+ main_text_title_1 = getConfigProgramTitleString();
+ main_text_title_2 = getConfigProgramCopyrightString();
+ main_text_title_3 = getConfigProgramCompanyString();
+
/* set main control screen positions to dynamically determined values */
for (i = 0; main_controls[i].nr != -1; i++)
{
if (pos_text != NULL) /* (x/y may be -1/-1 here) */
{
- /* calculate size for non-clickable text -- needed for text alignment */
- boolean calculate_text_size = (pos_button == NULL && text != NULL);
+ /* calculate text size -- needed for text alignment */
+ boolean calculate_text_size = (text != NULL);
if (pos_text->width == -1 || calculate_text_size)
pos_text->width = text_width;
void DrawHeadline()
{
- DrawTextSCentered(MENU_TITLE1_YPOS, FONT_TITLE_1, getProgramTitleString());
- DrawTextSCentered(MENU_TITLE2_YPOS, FONT_TITLE_2,
- setup.internal.program_copyright);
+ DrawTextSCentered(MENU_TITLE1_YPOS, FONT_TITLE_1, main_text_title_1);
+ DrawTextSCentered(MENU_TITLE2_YPOS, FONT_TITLE_2, main_text_title_2);
}
void DrawTitleScreenImage(int nr, boolean initial)
if (redraw_mask & REDRAW_ALL)
fade_mask = REDRAW_ALL;
- if (CheckIfGlobalBorderHasChanged())
+ if (CheckIfGlobalBorderOrPlayfieldViewportHasChanged())
fade_mask = REDRAW_ALL;
FadeOut(fade_mask);
int ypos = MENU_SCREEN_START_YPOS + screen_pos;
int font_nr = getMenuTextFont(ti->type);
- if (token_info == setup_info_input)
+ if (setup_mode == SETUP_MODE_INPUT)
font_nr = FONT_MENU_1;
if (active)
if (redraw_mask & REDRAW_ALL)
fade_mask = REDRAW_ALL;
- if (CheckIfGlobalBorderHasChanged())
+ if (CheckIfGlobalBorderOrPlayfieldViewportHasChanged())
fade_mask = REDRAW_ALL;
UnmapAllGadgets();
info_mode, num_info_info, max_info_info);
}
+static int getMenuFontSpacing(int spacing_height, int font_nr)
+{
+ int font_spacing = getFontHeight(font_nr) + EXTRA_SPACING(game_status);
+
+ return (spacing_height < 0 ? ABS(spacing_height) * font_spacing :
+ spacing_height);
+}
+
+static int getMenuTextSpacing(int spacing_height, int font_nr)
+{
+ return (getMenuFontSpacing(spacing_height, font_nr) +
+ EXTRA_SPACING(game_status));
+}
+
+static int getMenuTextStep(int spacing_height, int font_nr)
+{
+ return getFontHeight(font_nr) + getMenuTextSpacing(spacing_height, font_nr);
+}
+
void DrawInfoScreen_NotAvailable(char *text_title, char *text_error)
{
- int ystart1 = mSY - SY + 100;
- int ystart2 = mSY - SY + 150;
- int ybottom = mSY - SY + SYSIZE - 20;
+ int font_title = MENU_INFO_FONT_TITLE;
+ int font_error = FONT_TEXT_2;
+ int font_foot = MENU_INFO_FONT_FOOT;
+ int spacing_title = menu.headline1_spacing_info[info_mode];
+ int ystep_title = getMenuTextStep(spacing_title, font_title);
+ int ystart1 = mSY - SY + MENU_SCREEN_INFO_YSTART1;
+ int ystart2 = ystart1 + ystep_title;
+ int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
SetMainBackgroundImageIfDefined(IMG_BACKGROUND_INFO);
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1, text_title);
- DrawTextSCentered(ystart2, FONT_TEXT_2, text_error);
+ DrawTextSCentered(ystart1, font_title, text_title);
+ DrawTextSCentered(ystart2, font_error, text_error);
- DrawTextSCentered(ybottom, FONT_TEXT_4,
+ DrawTextSCentered(ybottom, font_foot,
"Press any key or button for info menu");
FadeIn(REDRAW_FIELD);
{
static int infoscreen_step[MAX_INFO_ELEMENTS_ON_SCREEN];
static int infoscreen_frame[MAX_INFO_ELEMENTS_ON_SCREEN];
- int xstart = mSX + MENU_SCREEN_INFO_XSTART;
+ int font_title = MENU_INFO_FONT_TITLE;
+ int font_foot = MENU_INFO_FONT_FOOT;
+ int xstart = mSX + MENU_SCREEN_INFO_SPACE_LEFT;
int ystart1 = mSY - SY + MENU_SCREEN_INFO_YSTART1;
int ystart2 = mSY + MENU_SCREEN_INFO_YSTART2;
int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1, "The Game Elements:");
+ DrawTextSCentered(ystart1, font_title, "The Game Elements:");
- DrawTextSCentered(ybottom, FONT_TEXT_4,
+ DrawTextSCentered(ybottom, font_foot,
"Press any key or button for next page");
FrameCounter = 0;
{
int font_nr = FONT_INFO_ELEMENTS;
int font_width = getFontWidth(font_nr);
- int sx = mSX + MINI_TILEX + TILEX + MINI_TILEX;
- int sy = mSY + 65 + 2 * 32 + 1;
+ int font_height = getFontHeight(font_nr);
+ int yoffset = (TILEX - 2 * font_height) / 2;
+ int xstart = mSX + MENU_SCREEN_INFO_SPACE_LEFT + TILEX + MINI_TILEX;
+ int ystart = mSY + MENU_SCREEN_INFO_YSTART2 + yoffset;
int ystep = TILEY + 4;
- int pad_x = sx - SX;
- int max_chars_per_line = (SXSIZE - pad_x - MINI_TILEX) / font_width;
+ int pad_left = xstart - SX;
+ int pad_right = MENU_SCREEN_INFO_SPACE_RIGHT;
+ int max_chars_per_line = (SXSIZE - pad_left - pad_right) / font_width;
int max_lines_per_text = 2;
char *text = NULL;
text = "No description available";
if (strlen(text) <= max_chars_per_line) /* only one line of text */
- sy += getFontHeight(font_nr) / 2;
+ ystart += getFontHeight(font_nr) / 2;
- DrawTextBuffer(sx, sy + ypos * ystep, text, font_nr,
+ DrawTextBuffer(xstart, ystart + ypos * ystep, text, font_nr,
max_chars_per_line, -1, max_lines_per_text, 0, -1,
TRUE, FALSE, FALSE);
}
void HandleInfoScreen_Music(int button)
{
static struct MusicFileInfo *list = NULL;
- int ystart1 = mSY - SY + 100;
- int ystart2 = mSY - SY + 150;
- int ybottom = mSY - SY + SYSIZE - 20;
- int dy = 30;
+ int font_title = MENU_INFO_FONT_TITLE;
+ int font_head = MENU_INFO_FONT_HEAD;
+ int font_text = MENU_INFO_FONT_TEXT;
+ int font_foot = MENU_INFO_FONT_FOOT;
+ int spacing_title = menu.headline1_spacing_info[info_mode];
+ int spacing_head = menu.headline2_spacing_info[info_mode];
+ int ystep_title = getMenuTextStep(spacing_title, font_title);
+ int ystep_head = getMenuTextStep(spacing_head, font_head);
+ int ystart = mSY - SY + MENU_SCREEN_INFO_YSTART1;
+ int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
if (button == MB_MENU_INITIALIZE)
{
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1,
+ DrawTextSCentered(ystart, font_title,
"No music info for this level set.");
- DrawTextSCentered(ybottom, FONT_TEXT_4,
+ DrawTextSCentered(ybottom, font_foot,
"Press any key or button for info menu");
return;
}
else if (button == MB_MENU_CHOICE || button == MB_MENU_INITIALIZE)
{
- int y = 0;
-
if (button != MB_MENU_INITIALIZE)
{
PlaySound(SND_MENU_ITEM_SELECTING);
else
PlaySound(sound);
- DrawTextSCentered(ystart1, FONT_TEXT_1, "The Game Background Sounds:");
+ DrawTextSCentered(ystart, font_title, "The Game Background Sounds:");
}
else
{
PlayMusic(list->music);
- DrawTextSCentered(ystart1, FONT_TEXT_1, "The Game Background Music:");
+ DrawTextSCentered(ystart, font_title, "The Game Background Music:");
}
+ ystart += ystep_title;
+
if (!strEqual(list->title, UNKNOWN_NAME))
{
if (!strEqual(list->title_header, UNKNOWN_NAME))
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, list->title_header);
+ {
+ DrawTextSCentered(ystart, font_head, list->title_header);
+ ystart += ystep_head;
+ }
- DrawTextFCentered(ystart2 + y++ * dy, FONT_TEXT_3, "\"%s\"", list->title);
+ DrawTextFCentered(ystart, font_text, "\"%s\"", list->title);
+ ystart += ystep_head;
}
if (!strEqual(list->artist, UNKNOWN_NAME))
{
if (!strEqual(list->artist_header, UNKNOWN_NAME))
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, list->artist_header);
+ DrawTextSCentered(ystart, font_head, list->artist_header);
else
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, "by");
+ DrawTextSCentered(ystart, font_head, "by");
- DrawTextFCentered(ystart2 + y++ * dy, FONT_TEXT_3, "%s", list->artist);
+ ystart += ystep_head;
+
+ DrawTextFCentered(ystart, font_text, "%s", list->artist);
+ ystart += ystep_head;
}
if (!strEqual(list->album, UNKNOWN_NAME))
{
if (!strEqual(list->album_header, UNKNOWN_NAME))
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, list->album_header);
+ DrawTextSCentered(ystart, font_head, list->album_header);
else
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, "from the album");
+ DrawTextSCentered(ystart, font_head, "from the album");
+
+ ystart += ystep_head;
- DrawTextFCentered(ystart2 + y++ * dy, FONT_TEXT_3, "\"%s\"", list->album);
+ DrawTextFCentered(ystart, font_text, "\"%s\"", list->album);
+ ystart += ystep_head;
}
if (!strEqual(list->year, UNKNOWN_NAME))
{
if (!strEqual(list->year_header, UNKNOWN_NAME))
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, list->year_header);
+ DrawTextSCentered(ystart, font_head, list->year_header);
else
- DrawTextSCentered(ystart2 + y++ * dy, FONT_TEXT_2, "from the year");
+ DrawTextSCentered(ystart, font_head, "from the year");
- DrawTextFCentered(ystart2 + y++ * dy, FONT_TEXT_3, "%s", list->year);
+ ystart += ystep_head;
+
+ DrawTextFCentered(ystart, font_text, "%s", list->year);
+ ystart += ystep_head;
}
DrawTextSCentered(ybottom, FONT_TEXT_4,
static void DrawInfoScreen_CreditsScreen(int screen_nr)
{
- int ystart1 = mSY - SY + 100;
- int ystart2 = mSY - SY + 150;
- int ybottom = mSY - SY + SYSIZE - 20;
- int ystep = 30;
+ int font_title = MENU_INFO_FONT_TITLE;
+ int font_head = MENU_INFO_FONT_HEAD;
+ int font_text = MENU_INFO_FONT_TEXT;
+ int font_foot = MENU_INFO_FONT_FOOT;
+ int spacing_title = menu.headline1_spacing_info[info_mode];
+ int spacing_head = menu.headline2_spacing_info[info_mode];
+ int spacing_para = menu.paragraph_spacing_info[info_mode];
+ int spacing_line = menu.line_spacing_info[info_mode];
+ int ystep_title = getMenuTextStep(spacing_title, font_title);
+ int ystep_head = getMenuTextStep(spacing_head, font_head);
+ int ystep_para = getMenuTextStep(spacing_para, font_text);
+ int ystep_line = getMenuTextStep(spacing_line, font_text);
+ int ystart = mSY - SY + MENU_SCREEN_INFO_YSTART1;
+ int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1, "Credits:");
+ DrawTextSCentered(ystart, font_title, "Credits:");
+ ystart += ystep_title;
if (screen_nr == 0)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Special thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Peter Liepa");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for creating");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"\"Boulder Dash\"");
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"in the year");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"1984");
- DrawTextSCentered(ystart2 + 6 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"published by");
- DrawTextSCentered(ystart2 + 7 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"First Star Software");
}
else if (screen_nr == 1)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Special thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Klaus Heinz & Volker Wertich");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for creating");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"\"Emerald Mine\"");
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"in the year");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"1987");
- DrawTextSCentered(ystart2 + 6 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"published by");
- DrawTextSCentered(ystart2 + 7 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Kingsoft");
}
else if (screen_nr == 2)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Special thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Michael Stopp & Philip Jespersen");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for creating");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"\"Supaplex\"");
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"in the year");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"1991");
- DrawTextSCentered(ystart2 + 6 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"published by");
- DrawTextSCentered(ystart2 + 7 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Digital Integration");
}
else if (screen_nr == 3)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Special thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Hiroyuki Imabayashi");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for creating");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"\"Sokoban\"");
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"in the year");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"1982");
- DrawTextSCentered(ystart2 + 6 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"published by");
- DrawTextSCentered(ystart2 + 7 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Thinking Rabbit");
}
else if (screen_nr == 4)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Special thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Alan Bond");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"and");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"J\xfcrgen Bonhagen");
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for the continuous creation");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_2,
+ ystart += ystep_line;
+ DrawTextSCentered(ystart, font_head,
"of outstanding level sets");
}
else if (screen_nr == 5)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Peter Elzner");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for ideas and inspiration by");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Diamond Caves");
+ ystart += ystep_para;
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Thanks to");
- DrawTextSCentered(ystart2 + 6 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Steffest");
- DrawTextSCentered(ystart2 + 7 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for ideas and inspiration by");
- DrawTextSCentered(ystart2 + 8 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"DX-Boulderdash");
}
else if (screen_nr == 6)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"David Tritscher");
-#if 1
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for the code base used for the");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_2,
+ ystart += ystep_line;
+ DrawTextSCentered(ystart, font_head,
"native Emerald Mine engine");
-#else
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
- "for the new Emerald Mine engine");
-#endif
}
else if (screen_nr == 7)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Thanks to");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Guido Schulz");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for the initial DOS port");
+ ystart += ystep_para;
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"Thanks to");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"Karl H\xf6rnell");
- DrawTextSCentered(ystart2 + 6 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"for some additional toons");
}
else if (screen_nr == 8)
{
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"And not to forget:");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"Many thanks to");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
"All those who contributed");
- DrawTextSCentered(ystart2 + 3 * ystep, FONT_TEXT_3,
+ ystart += ystep_line;
+ DrawTextSCentered(ystart, font_text,
"levels to this game");
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_3,
+ ystart += ystep_line;
+ DrawTextSCentered(ystart, font_text,
"since 1995");
}
- DrawTextSCentered(ybottom, FONT_TEXT_4,
+ DrawTextSCentered(ybottom, font_foot,
"Press any key or button for next page");
}
void DrawInfoScreen_Program()
{
- int ystart1 = mSY - SY + 100;
- int ystart2 = mSY - SY + 150;
- int ybottom = mSY - SY + SYSIZE - 20;
- int ystep = 30;
+ int font_title = MENU_INFO_FONT_TITLE;
+ int font_head = MENU_INFO_FONT_HEAD;
+ int font_text = MENU_INFO_FONT_TEXT;
+ int font_foot = MENU_INFO_FONT_FOOT;
+ int spacing_title = menu.headline1_spacing_info[info_mode];
+ int spacing_head = menu.headline2_spacing_info[info_mode];
+ int spacing_para = menu.paragraph_spacing_info[info_mode];
+ int spacing_line = menu.line_spacing_info[info_mode];
+ int ystep_title = getMenuTextStep(spacing_title, font_title);
+ int ystep_head = getMenuTextStep(spacing_head, font_head);
+ int ystep_para = getMenuTextStep(spacing_para, font_text);
+ int ystep_line = getMenuTextStep(spacing_line, font_text);
+ int ystart = mSY - SY + MENU_SCREEN_INFO_YSTART1;
+ int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
SetMainBackgroundImageIfDefined(IMG_BACKGROUND_INFO_PROGRAM);
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1, "Program Information:");
+ DrawTextSCentered(ystart, font_title, "Program Information:");
+ ystart += ystep_title;
- DrawTextSCentered(ystart2 + 0 * ystep, FONT_TEXT_2,
+ DrawTextSCentered(ystart, font_head,
"This game is Freeware!");
- DrawTextSCentered(ystart2 + 1 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
"If you like it, send e-mail to:");
- DrawTextSCentered(ystart2 + 2 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
setup.internal.program_email);
- DrawTextSCentered(ystart2 + 4 * ystep, FONT_TEXT_2,
+ ystart += ystep_para;
+
+ DrawTextSCentered(ystart, font_head,
"More information and levels:");
- DrawTextSCentered(ystart2 + 5 * ystep, FONT_TEXT_3,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_text,
setup.internal.program_website);
- DrawTextSCentered(ystart2 + 7 * ystep, FONT_TEXT_2,
+ ystart += ystep_para;
+
+ DrawTextSCentered(ystart, font_head,
"If you have created new levels,");
- DrawTextSCentered(ystart2 + 8 * ystep, FONT_TEXT_2,
+ ystart += ystep_line;
+ DrawTextSCentered(ystart, font_head,
"send them to me to include them!");
- DrawTextSCentered(ystart2 + 9 * ystep, FONT_TEXT_2,
+ ystart += ystep_head;
+ DrawTextSCentered(ystart, font_head,
":-)");
- DrawTextSCentered(ybottom, FONT_TEXT_4,
+ DrawTextSCentered(ybottom, font_foot,
"Press any key or button for info menu");
FadeIn(REDRAW_FIELD);
void DrawInfoScreen_Version()
{
- int font_header = FONT_TEXT_3;
- int font_text = FONT_TEXT_2;
+ int font_title = MENU_INFO_FONT_TITLE;
+ int font_head = MENU_INFO_FONT_HEAD;
+ int font_text = MENU_INFO_FONT_TEXT;
+ int font_foot = MENU_INFO_FONT_FOOT;
+ int spacing_title = menu.headline1_spacing_info[info_mode];
+ int spacing_head = menu.headline2_spacing_info[info_mode];
+ int spacing_para = menu.paragraph_spacing_info[info_mode];
+ int spacing_line = menu.line_spacing_info[info_mode];
int xstep = getFontWidth(font_text);
- int ystep = getFontHeight(font_text);
- int ystart1 = mSY - SY + 100;
- int ystart2 = mSY - SY + 150;
- int ybottom = mSY - SY + SYSIZE - 20;
+ int ystep_title = getMenuTextStep(spacing_title, font_title);
+ int ystep_head = getMenuTextStep(spacing_head, font_head);
+ int ystep_para = getMenuTextStep(spacing_para, font_text);
+ int ystep_line = getMenuTextStep(spacing_line, font_text);
+ int ystart = mSY - SY + MENU_SCREEN_INFO_YSTART1;
+ int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
int xstart1 = mSX - SX + 2 * xstep;
int xstart2 = mSX - SX + 18 * xstep;
int xstart3 = mSX - SX + 28 * xstep;
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1, "Version Information:");
-
- DrawTextF(xstart1, ystart2, font_header, "Name");
- DrawTextF(xstart2, ystart2, font_text, getProgramTitleString());
+ DrawTextSCentered(ystart, font_title, "Version Information:");
+ ystart += ystep_title;
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_header, "Version");
- DrawTextF(xstart2, ystart2, font_text, getProgramVersionString());
+ DrawTextF(xstart1, ystart, font_head, "Name");
+ DrawTextF(xstart2, ystart, font_text, getProgramTitleString());
+ ystart += ystep_line;
if (!strEqual(getProgramVersionString(), getProgramRealVersionString()))
{
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_header, "Version (real)");
- DrawTextF(xstart2, ystart2, font_text, getProgramRealVersionString());
+ DrawTextF(xstart1, ystart, font_head, "Version (fake)");
+ DrawTextF(xstart2, ystart, font_text, getProgramVersionString());
+ ystart += ystep_line;
+
+ DrawTextF(xstart1, ystart, font_head, "Version (real)");
+ DrawTextF(xstart2, ystart, font_text, getProgramRealVersionString());
+ ystart += ystep_line;
+ }
+ else
+ {
+ DrawTextF(xstart1, ystart, font_head, "Version");
+ DrawTextF(xstart2, ystart, font_text, getProgramVersionString());
+ ystart += ystep_line;
}
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_header, "Platform");
- DrawTextF(xstart2, ystart2, font_text, PLATFORM_STRING);
+ DrawTextF(xstart1, ystart, font_head, "Platform");
+ DrawTextF(xstart2, ystart, font_text, PLATFORM_STRING);
+ ystart += ystep_line;
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_header, "Target");
- DrawTextF(xstart2, ystart2, font_text, TARGET_STRING);
+ DrawTextF(xstart1, ystart, font_head, "Target");
+ DrawTextF(xstart2, ystart, font_text, TARGET_STRING);
+ ystart += ystep_line;
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_header, "Source date");
- DrawTextF(xstart2, ystart2, font_text, getSourceDateString());
+ DrawTextF(xstart1, ystart, font_head, "Source date");
+ DrawTextF(xstart2, ystart, font_text, getSourceDateString());
+ ystart += ystep_para;
- ystart2 += 3 * ystep;
- DrawTextF(xstart1, ystart2, font_header, "Library");
- DrawTextF(xstart2, ystart2, font_header, "compiled");
- DrawTextF(xstart3, ystart2, font_header, "linked");
+ DrawTextF(xstart1, ystart, font_head, "Library");
+ DrawTextF(xstart2, ystart, font_head, "compiled");
+ DrawTextF(xstart3, ystart, font_head, "linked");
+ ystart += ystep_head;
SDL_VERSION(&sdl_version_compiled);
#if defined(TARGET_SDL2)
sdl_version_linked = SDL_Linked_Version();
#endif
- ystart2 += 2 * ystep;
- DrawTextF(xstart1, ystart2, font_text, "SDL");
- DrawTextF(xstart2, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart1, ystart, font_text, "SDL");
+ DrawTextF(xstart2, ystart, font_text, "%d.%d.%d",
sdl_version_compiled.major,
sdl_version_compiled.minor,
sdl_version_compiled.patch);
- DrawTextF(xstart3, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart3, ystart, font_text, "%d.%d.%d",
sdl_version_linked->major,
sdl_version_linked->minor,
sdl_version_linked->patch);
+ ystart += ystep_line;
SDL_IMAGE_VERSION(&sdl_version_compiled);
sdl_version_linked = IMG_Linked_Version();
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_text, "SDL_image");
- DrawTextF(xstart2, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart1, ystart, font_text, "SDL_image");
+ DrawTextF(xstart2, ystart, font_text, "%d.%d.%d",
sdl_version_compiled.major,
sdl_version_compiled.minor,
sdl_version_compiled.patch);
- DrawTextF(xstart3, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart3, ystart, font_text, "%d.%d.%d",
sdl_version_linked->major,
sdl_version_linked->minor,
sdl_version_linked->patch);
+ ystart += ystep_line;
SDL_MIXER_VERSION(&sdl_version_compiled);
sdl_version_linked = Mix_Linked_Version();
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_text, "SDL_mixer");
- DrawTextF(xstart2, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart1, ystart, font_text, "SDL_mixer");
+ DrawTextF(xstart2, ystart, font_text, "%d.%d.%d",
sdl_version_compiled.major,
sdl_version_compiled.minor,
sdl_version_compiled.patch);
- DrawTextF(xstart3, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart3, ystart, font_text, "%d.%d.%d",
sdl_version_linked->major,
sdl_version_linked->minor,
sdl_version_linked->patch);
+ ystart += ystep_line;
SDL_NET_VERSION(&sdl_version_compiled);
sdl_version_linked = SDLNet_Linked_Version();
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_text, "SDL_net");
- DrawTextF(xstart2, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart1, ystart, font_text, "SDL_net");
+ DrawTextF(xstart2, ystart, font_text, "%d.%d.%d",
sdl_version_compiled.major,
sdl_version_compiled.minor,
sdl_version_compiled.patch);
- DrawTextF(xstart3, ystart2, font_text, "%d.%d.%d",
+ DrawTextF(xstart3, ystart, font_text, "%d.%d.%d",
sdl_version_linked->major,
sdl_version_linked->minor,
sdl_version_linked->patch);
+ ystart += ystep_para;
- ystart2 += 3 * ystep;
- DrawTextF(xstart1, ystart2, font_header, "Driver");
- DrawTextF(xstart2, ystart2, font_header, "Requested");
- DrawTextF(xstart3, ystart2, font_header, "Used");
+ DrawTextF(xstart1, ystart, font_head, "Driver");
+ DrawTextF(xstart2, ystart, font_head, "Requested");
+ DrawTextF(xstart3, ystart, font_head, "Used");
+ ystart += ystep_head;
#if defined(TARGET_SDL2)
driver_name = getStringCopyNStatic(SDL_GetVideoDriver(0), driver_name_len);
SDL_VideoDriverName(driver_name, driver_name_len);
#endif
- ystart2 += 2 * ystep;
- DrawTextF(xstart1, ystart2, font_text, "SDL_VideoDriver");
- DrawTextF(xstart2, ystart2, font_text, "%s", setup.system.sdl_videodriver);
- DrawTextF(xstart3, ystart2, font_text, "%s", driver_name);
+ DrawTextF(xstart1, ystart, font_text, "SDL_VideoDriver");
+ DrawTextF(xstart2, ystart, font_text, "%s", setup.system.sdl_videodriver);
+ DrawTextF(xstart3, ystart, font_text, "%s", driver_name);
+ ystart += ystep_line;
#if defined(TARGET_SDL2)
driver_name = getStringCopyNStatic(SDL_GetAudioDriver(0), driver_name_len);
SDL_AudioDriverName(driver_name, driver_name_len);
#endif
- ystart2 += ystep;
- DrawTextF(xstart1, ystart2, font_text, "SDL_AudioDriver");
- DrawTextF(xstart2, ystart2, font_text, "%s", setup.system.sdl_audiodriver);
- DrawTextF(xstart3, ystart2, font_text, "%s", driver_name);
+ DrawTextF(xstart1, ystart, font_text, "SDL_AudioDriver");
+ DrawTextF(xstart2, ystart, font_text, "%s", setup.system.sdl_audiodriver);
+ DrawTextF(xstart3, ystart, font_text, "%s", driver_name);
- DrawTextSCentered(ybottom, FONT_TEXT_4,
+ DrawTextSCentered(ybottom, font_foot,
"Press any key or button for info menu");
FadeIn(REDRAW_FIELD);
struct TitleMessageInfo *tmi = &readme;
char *filename = getLevelSetInfoFilename();
char *title = "Level Set Information:";
- int ystart1 = mSY - SY + 100;
- int ybottom = mSY - SY + SYSIZE - 20;
+ int ystart = mSY - SY + MENU_SCREEN_INFO_YSTART1;
+ int ybottom = mSY - SY + MENU_SCREEN_INFO_YBOTTOM;
if (filename == NULL)
{
ClearField();
DrawHeadline();
- DrawTextSCentered(ystart1, FONT_TEXT_1, title);
+ DrawTextSCentered(ystart, FONT_TEXT_1, title);
/* if x position set to "-1", automatically determine by playfield width */
if (tmi->x == -1)
/* if height set to "-1", automatically determine by playfield height */
if (tmi->height == -1)
- tmi->height = SYSIZE - 20 - tmi->y - 10;
+ tmi->height = MENU_SCREEN_INFO_YBOTTOM - tmi->y - 10;
/* if chars set to "-1", automatically determine by text and font width */
if (tmi->chars == -1)
{
int fade_mask = REDRAW_FIELD;
- if (CheckIfGlobalBorderHasChanged())
+ if (CheckIfGlobalBorderOrPlayfieldViewportHasChanged())
fade_mask = REDRAW_ALL;
if (strEqual((*ti_ptr)->subdir, STRING_TOP_DIRECTORY))
execSetupSound();
else if (setup_mode == SETUP_MODE_CHOOSE_TOUCH_CONTROL ||
setup_mode == SETUP_MODE_CHOOSE_MOVE_DISTANCE ||
- setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE)
+ setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE ||
+ setup_mode == SETUP_MODE_CHOOSE_TRANSPARENCY ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_0 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_0 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_1 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_1)
execSetupTouch();
else
execSetupArtwork();
execSetupSound();
else if (setup_mode == SETUP_MODE_CHOOSE_TOUCH_CONTROL ||
setup_mode == SETUP_MODE_CHOOSE_MOVE_DISTANCE ||
- setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE)
+ setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE ||
+ setup_mode == SETUP_MODE_CHOOSE_TRANSPARENCY ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_0 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_0 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_1 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_1)
execSetupTouch();
else
execSetupArtwork();
execSetupSound();
else if (setup_mode == SETUP_MODE_CHOOSE_TOUCH_CONTROL ||
setup_mode == SETUP_MODE_CHOOSE_MOVE_DISTANCE ||
- setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE)
+ setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE ||
+ setup_mode == SETUP_MODE_CHOOSE_TRANSPARENCY ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_0 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_0 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_1 ||
+ setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_1)
execSetupTouch();
else
execSetupArtwork();
{
int fade_mask = REDRAW_FIELD;
- if (CheckIfGlobalBorderHasChanged())
+ if (CheckIfGlobalBorderOrPlayfieldViewportHasChanged())
fade_mask = REDRAW_ALL;
UnmapAllGadgets();
static char *touch_controls_text;
static char *move_distance_text;
static char *drop_distance_text;
+static char *transparency_text;
+static char *grid_size_text[2][2];
static void execSetupMain()
{
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Game Speed");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_GAME_SPEED);
pushTreeInfo(&game_speeds, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Scroll Delay");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_SCROLL_DELAY);
pushTreeInfo(&scroll_delays, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Snapshot Mode");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_SNAPSHOT_MODE);
pushTreeInfo(&snapshot_modes, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Window Scaling");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_WINDOW_SIZE);
pushTreeInfo(&window_sizes, ti);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Window Scaling");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_WINDOW_SIZE);
pushTreeInfo(&window_sizes, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Anti-Aliasing");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_SCALING_TYPE);
pushTreeInfo(&scaling_types, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Special Rendering");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_RENDERING);
pushTreeInfo(&rendering_modes, ti);
}
#endif
}
-#if defined(TARGET_SDL2) && !defined(PLATFORM_ANDROID)
static void execSetupChooseWindowSize()
{
setup_mode = SETUP_MODE_CHOOSE_WINDOW_SIZE;
DrawSetupScreen();
}
-#endif
static void execSetupChooseVolumeSimple()
{
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Sound Volume");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_VOLUME_SIMPLE);
pushTreeInfo(&volumes_simple, ti);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Sound Volume");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_VOLUME_SIMPLE);
pushTreeInfo(&volumes_simple, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Loops Volume");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_VOLUME_LOOPS);
pushTreeInfo(&volumes_loops, ti);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Loops Volume");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_VOLUME_LOOPS);
pushTreeInfo(&volumes_loops, ti);
}
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Music Volume");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_VOLUME_MUSIC);
pushTreeInfo(&volumes_music, ti);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Music Volume");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_VOLUME_MUSIC);
pushTreeInfo(&volumes_music, ti);
}
DrawSetupScreen();
}
+static void execSetupChooseTransparency()
+{
+ setup_mode = SETUP_MODE_CHOOSE_TRANSPARENCY;
+
+ DrawSetupScreen();
+}
+
+static void execSetupChooseGridXSize_0()
+{
+ setup_mode = SETUP_MODE_CHOOSE_GRID_XSIZE_0;
+
+ DrawSetupScreen();
+}
+
+static void execSetupChooseGridYSize_0()
+{
+ setup_mode = SETUP_MODE_CHOOSE_GRID_YSIZE_0;
+
+ DrawSetupScreen();
+}
+
+static void execSetupChooseGridXSize_1()
+{
+ setup_mode = SETUP_MODE_CHOOSE_GRID_XSIZE_1;
+
+ DrawSetupScreen();
+}
+
+static void execSetupChooseGridYSize_1()
+{
+ setup_mode = SETUP_MODE_CHOOSE_GRID_YSIZE_1;
+
+ DrawSetupScreen();
+}
+
+static void execSetupConfigureVirtualButtons()
+{
+ setup_mode = SETUP_MODE_CONFIG_VIRT_BUTTONS;
+
+ ConfigureVirtualButtons();
+
+ setup_mode = SETUP_MODE_TOUCH;
+
+ DrawSetupScreen();
+}
+
static void execSetupTouch()
{
+ int i, j, k;
+
if (touch_controls == NULL)
{
- int i;
-
for (i = 0; touch_controls_list[i].value != NULL; i++)
{
TreeInfo *ti = newTreeInfo_setDefaults(TREE_TYPE_UNDEFINED);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Control Type");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_TOUCH_CONTROL);
pushTreeInfo(&touch_controls, ti);
}
if (move_distances == NULL)
{
- int i;
-
for (i = 0; distances_list[i].value != -1; i++)
{
TreeInfo *ti = newTreeInfo_setDefaults(TREE_TYPE_UNDEFINED);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Move Distance");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_MOVE_DISTANCE);
pushTreeInfo(&move_distances, ti);
}
/* if that fails, set current distance to reliable default value */
if (move_distance_current == NULL)
move_distance_current =
- getTreeInfoFromIdentifier(move_distances, i_to_a(1));
+ getTreeInfoFromIdentifier(move_distances,
+ i_to_a(TOUCH_MOVE_DISTANCE_DEFAULT));
/* if that also fails, set current distance to first available value */
if (move_distance_current == NULL)
if (drop_distances == NULL)
{
- int i;
-
for (i = 0; distances_list[i].value != -1; i++)
{
TreeInfo *ti = newTreeInfo_setDefaults(TREE_TYPE_UNDEFINED);
setString(&ti->identifier, identifier);
setString(&ti->name, name);
setString(&ti->name_sorting, name);
- setString(&ti->infotext, "Drop Distance");
+ setString(&ti->infotext, STR_SETUP_CHOOSE_DROP_DISTANCE);
pushTreeInfo(&drop_distances, ti);
}
/* if that fails, set current distance to reliable default value */
if (drop_distance_current == NULL)
drop_distance_current =
- getTreeInfoFromIdentifier(drop_distances, i_to_a(1));
+ getTreeInfoFromIdentifier(drop_distances,
+ i_to_a(TOUCH_DROP_DISTANCE_DEFAULT));
/* if that also fails, set current distance to first available value */
if (drop_distance_current == NULL)
drop_distance_current = drop_distances;
}
+ if (transparencies == NULL)
+ {
+ for (i = 0; transparencies_list[i].value != -1; i++)
+ {
+ TreeInfo *ti = newTreeInfo_setDefaults(TREE_TYPE_UNDEFINED);
+ char identifier[32], name[32];
+ int value = transparencies_list[i].value;
+ char *text = transparencies_list[i].text;
+
+ ti->node_top = &transparencies;
+ ti->sort_priority = value;
+
+ sprintf(identifier, "%d", value);
+ sprintf(name, "%s", text);
+
+ setString(&ti->identifier, identifier);
+ setString(&ti->name, name);
+ setString(&ti->name_sorting, name);
+ setString(&ti->infotext, STR_SETUP_CHOOSE_TRANSPARENCY);
+
+ pushTreeInfo(&transparencies, ti);
+ }
+
+ /* sort transparency values to start with lowest transparency value */
+ sortTreeInfo(&transparencies);
+
+ /* set current transparency value to configured transparency value */
+ transparency_current =
+ getTreeInfoFromIdentifier(transparencies,
+ i_to_a(setup.touch.transparency));
+
+ /* if that fails, set current transparency to reliable default value */
+ if (transparency_current == NULL)
+ transparency_current =
+ getTreeInfoFromIdentifier(transparencies,
+ i_to_a(TOUCH_TRANSPARENCY_DEFAULT));
+
+ /* if that also fails, set current transparency to first available value */
+ if (transparency_current == NULL)
+ transparency_current = transparencies;
+ }
+
+ for (i = 0; i < 2; i++)
+ {
+ for (j = 0; j < 2; j++)
+ {
+ if (grid_sizes[i][j] == NULL)
+ {
+ for (k = 0; grid_sizes_list[k].value != -1; k++)
+ {
+ TreeInfo *ti = newTreeInfo_setDefaults(TREE_TYPE_UNDEFINED);
+ char identifier[32], name[32];
+ int value = grid_sizes_list[k].value;
+ char *text = grid_sizes_list[k].text;
+
+ ti->node_top = &grid_sizes[i][j];
+ ti->sort_priority = value;
+
+ sprintf(identifier, "%d", value);
+ sprintf(name, "%s", text);
+
+ setString(&ti->identifier, identifier);
+ setString(&ti->name, name);
+ setString(&ti->name_sorting, name);
+ setString(&ti->infotext,
+ (i == 0 ?
+ (j == 0 ?
+ STR_SETUP_CHOOSE_GRID_XSIZE_0 :
+ STR_SETUP_CHOOSE_GRID_YSIZE_0) :
+ (j == 0 ?
+ STR_SETUP_CHOOSE_GRID_XSIZE_1 :
+ STR_SETUP_CHOOSE_GRID_YSIZE_1)));
+
+ pushTreeInfo(&grid_sizes[i][j], ti);
+ }
+
+ /* sort grid size values to start with lowest grid size value */
+ sortTreeInfo(&grid_sizes[i][j]);
+
+ /* set current grid size value to configured grid size value */
+ grid_size_current[i][j] =
+ getTreeInfoFromIdentifier(grid_sizes[i][j],
+ i_to_a(j == 0 ?
+ setup.touch.grid_xsize[i] :
+ setup.touch.grid_ysize[i]));
+
+ /* if that fails, set current grid size to reliable default value */
+ if (grid_size_current[i][j] == NULL)
+ grid_size_current[i][j] =
+ getTreeInfoFromIdentifier(grid_sizes[i][j],
+ i_to_a(j == 0 ?
+ DEFAULT_GRID_XSIZE(i) :
+ DEFAULT_GRID_YSIZE(i)));
+
+ /* if that also fails, set current grid size to first available value */
+ if (grid_size_current[i][j] == NULL)
+ grid_size_current[i][j] = grid_sizes[i][j];
+ }
+ }
+ }
+
setup.touch.control_type = touch_control_current->identifier;
setup.touch.move_distance = atoi(move_distance_current->identifier);
setup.touch.drop_distance = atoi(drop_distance_current->identifier);
+ setup.touch.transparency = atoi(transparency_current->identifier);
- /* needed for displaying volume text instead of identifier */
+ for (i = 0; i < 2; i++)
+ {
+ setup.touch.grid_xsize[i] = atoi(grid_size_current[i][0]->identifier);
+ setup.touch.grid_ysize[i] = atoi(grid_size_current[i][1]->identifier);
+
+ if (i == GRID_ACTIVE_NR())
+ {
+ overlay.grid_xsize = setup.touch.grid_xsize[i];
+ overlay.grid_ysize = setup.touch.grid_ysize[i];
+ }
+ }
+
+ /* needed for displaying value text instead of identifier */
touch_controls_text = touch_control_current->name;
move_distance_text = move_distance_current->name;
drop_distance_text = drop_distance_current->name;
+ transparency_text = transparency_current->name;
+
+ for (i = 0; i < 2; i++)
+ for (j = 0; j < 2; j++)
+ grid_size_text[i][j] = grid_size_current[i][j]->name;
setup_mode = SETUP_MODE_TOUCH;
execExitSetup();
}
+static struct
+{
+ void *value;
+ void *related_value;
+} hide_related_entry_list[] =
+{
+ { &setup.game_frame_delay, execSetupChooseGameSpeed },
+ { &setup.game_frame_delay, &game_speed_text },
+
+ { &setup.scroll_delay_value, execSetupChooseScrollDelay },
+ { &setup.scroll_delay_value, &scroll_delay_text },
+
+ { &setup.engine_snapshot_mode, execSetupChooseSnapshotMode },
+ { &setup.engine_snapshot_mode, &snapshot_mode_text },
+
+ { &setup.window_scaling_percent, execSetupChooseWindowSize },
+ { &setup.window_scaling_percent, &window_size_text },
+
+ { &setup.window_scaling_quality, execSetupChooseScalingType },
+ { &setup.window_scaling_quality, &scaling_type_text },
+
+ { &setup.screen_rendering_mode, execSetupChooseRenderingMode },
+ { &setup.screen_rendering_mode, &rendering_mode_text },
+
+ { &setup.graphics_set, execSetupChooseGraphics },
+ { &setup.graphics_set, &graphics_set_name },
+
+ { &setup.sounds_set, execSetupChooseSounds },
+ { &setup.sounds_set, &sounds_set_name },
+
+ { &setup.music_set, execSetupChooseMusic },
+ { &setup.music_set, &music_set_name },
+
+ { &setup.volume_simple, execSetupChooseVolumeSimple },
+ { &setup.volume_simple, &volume_simple_text },
+
+ { &setup.volume_loops, execSetupChooseVolumeLoops },
+ { &setup.volume_loops, &volume_loops_text },
+
+ { &setup.volume_music, execSetupChooseVolumeMusic },
+ { &setup.volume_music, &volume_music_text },
+
+ { &setup.touch.control_type, execSetupChooseTouchControls },
+ { &setup.touch.control_type, &touch_controls_text },
+
+ { &setup.touch.move_distance, execSetupChooseMoveDistance },
+ { &setup.touch.move_distance, &move_distance_text },
+
+ { &setup.touch.drop_distance, execSetupChooseDropDistance },
+ { &setup.touch.drop_distance, &drop_distance_text },
+
+ { &setup.touch.transparency, execSetupChooseTransparency },
+ { &setup.touch.transparency, &transparency_text },
+
+ { &setup.touch.grid_xsize[0], execSetupChooseGridXSize_0 },
+ { &setup.touch.grid_xsize[0], &grid_size_text[0][0] },
+
+ { &setup.touch.grid_ysize[0], execSetupChooseGridYSize_0 },
+ { &setup.touch.grid_ysize[0], &grid_size_text[0][1] },
+
+ { &setup.touch.grid_xsize[1], execSetupChooseGridXSize_1 },
+ { &setup.touch.grid_xsize[1], &grid_size_text[1][0] },
+
+ { &setup.touch.grid_ysize[1], execSetupChooseGridYSize_1 },
+ { &setup.touch.grid_ysize[1], &grid_size_text[1][1] },
+
+ { NULL, NULL }
+};
+
+void setHideRelatedSetupEntries()
+{
+ int i;
+
+ for (i = 0; hide_related_entry_list[i].value != NULL; i++)
+ if (hideSetupEntry(hide_related_entry_list[i].value))
+ setHideSetupEntry(hide_related_entry_list[i].related_value);
+}
+
static struct TokenInfo setup_info_main[] =
{
- { TYPE_ENTER_MENU, execSetupGame, "Game & Menu" },
- { TYPE_ENTER_MENU, execSetupEditor, "Editor" },
- { TYPE_ENTER_MENU, execSetupGraphics, "Graphics" },
- { TYPE_ENTER_MENU, execSetupSound, "Sound & Music" },
- { TYPE_ENTER_MENU, execSetupArtwork, "Custom Artwork" },
- { TYPE_ENTER_MENU, execSetupInput, "Input Devices" },
- { TYPE_ENTER_MENU, execSetupTouch, "Touch Controls" },
- { TYPE_ENTER_MENU, execSetupShortcuts, "Key Shortcuts" },
+ { TYPE_ENTER_MENU, execSetupGame, STR_SETUP_GAME },
+ { TYPE_ENTER_MENU, execSetupEditor, STR_SETUP_EDITOR },
+ { TYPE_ENTER_MENU, execSetupGraphics, STR_SETUP_GRAPHICS },
+ { TYPE_ENTER_MENU, execSetupSound, STR_SETUP_SOUND },
+ { TYPE_ENTER_MENU, execSetupArtwork, STR_SETUP_ARTWORK },
+ { TYPE_ENTER_MENU, execSetupInput, STR_SETUP_INPUT },
+ { TYPE_ENTER_MENU, execSetupTouch, STR_SETUP_TOUCH },
+ { TYPE_ENTER_MENU, execSetupShortcuts, STR_SETUP_SHORTCUTS },
{ TYPE_EMPTY, NULL, "" },
- { TYPE_LEAVE_MENU, execExitSetup, "Exit" },
- { TYPE_LEAVE_MENU, execSaveAndExitSetup, "Save and Exit" },
+ { TYPE_LEAVE_MENU, execExitSetup, STR_SETUP_EXIT },
+ { TYPE_LEAVE_MENU, execSaveAndExitSetup, STR_SETUP_SAVE_AND_EXIT },
{ 0, NULL, NULL }
};
{ TYPE_SWITCH, NULL, "Player:" },
{ TYPE_SWITCH, NULL, "Device:" },
{ TYPE_SWITCH, NULL, "" },
+ { TYPE_SKIPPABLE, NULL, "" },
+ { TYPE_EMPTY, NULL, "" },
{ TYPE_EMPTY, NULL, "" },
{ TYPE_EMPTY, NULL, "" },
{ TYPE_EMPTY, NULL, "" },
{ TYPE_EMPTY, NULL, "" },
{ TYPE_EMPTY, NULL, "" },
{ TYPE_EMPTY, NULL, "" },
+ { TYPE_SKIPPABLE, NULL, "" },
+ { TYPE_LEAVE_MENU, execSetupMain, "Back" },
+
+ { 0, NULL, NULL }
+};
+
+static struct TokenInfo setup_info_touch[] =
+{
+ { TYPE_ENTER_LIST, execSetupChooseTouchControls, "Touch Control Type:" },
+ { TYPE_STRING, &touch_controls_text, "" },
+ { TYPE_EMPTY, NULL, "" },
+ { TYPE_LEAVE_MENU, execSetupMain, "Back" },
+
+ { 0, NULL, NULL }
+};
+
+static struct TokenInfo setup_info_touch_virtual_buttons_0[] =
+{
+ { TYPE_ENTER_LIST, execSetupChooseTouchControls, "Touch Control Type:" },
+ { TYPE_STRING, &touch_controls_text, "" },
{ TYPE_EMPTY, NULL, "" },
+ { TYPE_ENTER_LIST, execSetupChooseGridXSize_0, "Horizontal Buttons (Landscape):" },
+ { TYPE_STRING, &grid_size_text[0][0], "" },
+ { TYPE_ENTER_LIST, execSetupChooseGridYSize_0, "Vertical Buttons (Landscape):" },
+ { TYPE_STRING, &grid_size_text[0][1], "" },
+ { TYPE_ENTER_LIST, execSetupChooseTransparency, "Button Transparency:" },
+ { TYPE_STRING, &transparency_text, "" },
+ { TYPE_SWITCH, &setup.touch.draw_outlined, "Draw Buttons Outlined:" },
+ { TYPE_SWITCH, &setup.touch.draw_pressed, "Highlight Pressed Buttons:" },
{ TYPE_EMPTY, NULL, "" },
+ { TYPE_ENTER_LIST, execSetupConfigureVirtualButtons, "Configure Virtual Buttons" },
{ TYPE_EMPTY, NULL, "" },
{ TYPE_LEAVE_MENU, execSetupMain, "Back" },
{ 0, NULL, NULL }
};
-static struct TokenInfo setup_info_touch[] =
+static struct TokenInfo setup_info_touch_virtual_buttons_1[] =
{
{ TYPE_ENTER_LIST, execSetupChooseTouchControls, "Touch Control Type:" },
{ TYPE_STRING, &touch_controls_text, "" },
{ TYPE_EMPTY, NULL, "" },
+ { TYPE_ENTER_LIST, execSetupChooseGridXSize_1, "Horizontal Buttons (Portrait):" },
+ { TYPE_STRING, &grid_size_text[1][0], "" },
+ { TYPE_ENTER_LIST, execSetupChooseGridYSize_1, "Vertical Buttons (Portrait):" },
+ { TYPE_STRING, &grid_size_text[1][1], "" },
+ { TYPE_ENTER_LIST, execSetupChooseTransparency, "Button Transparency:" },
+ { TYPE_STRING, &transparency_text, "" },
+ { TYPE_SWITCH, &setup.touch.draw_outlined, "Draw Buttons Outlined:" },
+ { TYPE_SWITCH, &setup.touch.draw_pressed, "Highlight Pressed Buttons:" },
+ { TYPE_EMPTY, NULL, "" },
+ { TYPE_ENTER_LIST, execSetupConfigureVirtualButtons, "Configure Virtual Buttons" },
+ { TYPE_EMPTY, NULL, "" },
{ TYPE_LEAVE_MENU, execSetupMain, "Back" },
{ 0, NULL, NULL }
};
+static struct TokenInfo *setup_info_touch_virtual_buttons[] =
+{
+ setup_info_touch_virtual_buttons_0,
+ setup_info_touch_virtual_buttons_1
+};
+
static struct TokenInfo setup_info_touch_wipe_gestures[] =
{
{ TYPE_ENTER_LIST, execSetupChooseTouchControls, "Touch Control Type:" },
static struct TokenInfo *getSetupInfoFinal(struct TokenInfo *setup_info_orig)
{
- static struct TokenInfo *setup_info_hide = NULL;
+ static struct TokenInfo *setup_info_final = NULL;
int list_size = 0;
int list_pos = 0;
int i;
while (setup_info_orig[list_size++].type != 0);
/* free, allocate and clear memory for target list */
- checked_free(setup_info_hide);
- setup_info_hide = checked_calloc(list_size * sizeof(struct TokenInfo));
+ checked_free(setup_info_final);
+ setup_info_final = checked_calloc(list_size * sizeof(struct TokenInfo));
/* copy setup info list without setup entries marked as hidden */
for (i = 0; setup_info_orig[i].type != 0; i++)
- if (!hideSetupEntry(setup_info_orig[i].value))
- setup_info_hide[list_pos++] = setup_info_orig[i];
+ {
+ /* skip setup entries configured to be hidden */
+ if (hideSetupEntry(setup_info_orig[i].value))
+ continue;
+
+ /* skip skippable setup entries if screen is lower than usual */
+ if (SCR_FIELDY < SCR_FIELDY_DEFAULT &&
+ setup_info_orig[i].type == TYPE_SKIPPABLE)
+ continue;
- return setup_info_hide;
+ setup_info_final[list_pos++] = setup_info_orig[i];
+ }
+
+ return setup_info_final;
}
static void DrawSetupScreen_Generic()
char *title_string = NULL;
int i;
- if (CheckIfGlobalBorderHasChanged())
+ if (CheckIfGlobalBorderOrPlayfieldViewportHasChanged())
fade_mask = REDRAW_ALL;
UnmapAllGadgets();
if (setup_mode == SETUP_MODE_MAIN)
{
setup_info = setup_info_main;
- title_string = "Setup";
+ title_string = STR_SETUP_MAIN;
}
else if (setup_mode == SETUP_MODE_GAME)
{
setup_info = setup_info_game;
- title_string = "Setup Game";
+ title_string = STR_SETUP_GAME;
}
else if (setup_mode == SETUP_MODE_EDITOR)
{
setup_info = setup_info_editor;
- title_string = "Setup Editor";
+ title_string = STR_SETUP_EDITOR;
}
else if (setup_mode == SETUP_MODE_GRAPHICS)
{
setup_info = setup_info_graphics;
- title_string = "Setup Graphics";
+ title_string = STR_SETUP_GRAPHICS;
}
else if (setup_mode == SETUP_MODE_SOUND)
{
setup_info = setup_info_sound;
- title_string = "Setup Sound";
+ title_string = STR_SETUP_SOUND;
}
else if (setup_mode == SETUP_MODE_ARTWORK)
{
setup_info = setup_info_artwork;
- title_string = "Custom Artwork";
+ title_string = STR_SETUP_ARTWORK;
}
else if (setup_mode == SETUP_MODE_TOUCH)
{
setup_info = setup_info_touch;
- title_string = "Setup Touch Ctrls";
+ title_string = STR_SETUP_TOUCH;
- if (strEqual(setup.touch.control_type, TOUCH_CONTROL_WIPE_GESTURES))
+ if (strEqual(setup.touch.control_type, TOUCH_CONTROL_VIRTUAL_BUTTONS))
+ setup_info = setup_info_touch_virtual_buttons[GRID_ACTIVE_NR()];
+ else if (strEqual(setup.touch.control_type, TOUCH_CONTROL_WIPE_GESTURES))
setup_info = setup_info_touch_wipe_gestures;
}
else if (setup_mode == SETUP_MODE_SHORTCUTS)
{
setup_info = setup_info_shortcuts;
- title_string = "Setup Shortcuts";
+ title_string = STR_SETUP_SHORTCUTS;
}
else if (setup_mode == SETUP_MODE_SHORTCUTS_1)
{
setup_info = setup_info_shortcuts_1;
- title_string = "Setup Shortcuts";
+ title_string = STR_SETUP_SHORTCUTS;
}
else if (setup_mode == SETUP_MODE_SHORTCUTS_2)
{
setup_info = setup_info_shortcuts_2;
- title_string = "Setup Shortcuts";
+ title_string = STR_SETUP_SHORTCUTS;
}
else if (setup_mode == SETUP_MODE_SHORTCUTS_3)
{
setup_info = setup_info_shortcuts_3;
- title_string = "Setup Shortcuts";
+ title_string = STR_SETUP_SHORTCUTS;
}
else if (setup_mode == SETUP_MODE_SHORTCUTS_4)
{
setup_info = setup_info_shortcuts_4;
- title_string = "Setup Shortcuts";
+ title_string = STR_SETUP_SHORTCUTS;
}
else if (setup_mode == SETUP_MODE_SHORTCUTS_5)
{
setup_info = setup_info_shortcuts_5;
- title_string = "Setup Shortcuts";
+ title_string = STR_SETUP_SHORTCUTS;
}
/* use modified setup info without setup entries marked as hidden */
ClearField();
- setup_info = setup_info_input;
+ setup_info = getSetupInfoFinal(setup_info_input);
- DrawTextSCentered(mSY - SY + 16, FONT_TITLE_1, "Setup Input");
+ DrawTextSCentered(mSY - SY + 16, FONT_TITLE_1, STR_SETUP_INPUT);
- for (i = 0; setup_info[i].type != 0 && i < MAX_MENU_ENTRIES_ON_SCREEN; i++)
+ for (i = 0; setup_info[i].type != 0; i++)
{
if (setup_info[i].type & (TYPE_ENTER_MENU|TYPE_ENTER_LIST))
initCursor(i, IMG_MENU_BUTTON_ENTER_MENU);
"Joystick3",
"Joystick4"
};
- int text_font_nr = (active ? FONT_MENU_1_ACTIVE : FONT_MENU_1);
+ int font_nr_menu = (active ? FONT_MENU_1_ACTIVE : FONT_MENU_1);
+ int font_nr_info = FONT_MENU_1;
+ int font_nr_name = FONT_VALUE_OLD;
+ int font_nr_on = FONT_VALUE_1;
+ int font_nr_off = FONT_VALUE_OLD;
+ int pos = 4;
+
+ if (SCR_FIELDX < SCR_FIELDX_DEFAULT)
+ {
+ font_nr_info = FONT_MENU_2;
+ font_nr_on = FONT_VALUE_NARROW;
+ font_nr_off = FONT_VALUE_OLD_NARROW;
+ }
custom_key = setup.input[player_nr].key;
int joystick_nr = getJoystickNrFromDeviceName(device_name);
boolean joystick_active = CheckJoystickOpened(joystick_nr);
char *text = joystick_name[joystick_nr];
- int font_nr = (joystick_active ? FONT_VALUE_1 : FONT_VALUE_OLD);
+ int font_nr = (joystick_active ? font_nr_on : font_nr_off);
DrawText(mSX + 8 * 32, mSY + 3 * 32, text, font_nr);
- DrawText(mSX + 32, mSY + 4 * 32, "Configure", text_font_nr);
+ DrawText(mSX + 32, mSY + 4 * 32, "Configure", font_nr_menu);
}
else
{
- DrawText(mSX + 8 * 32, mSY + 3 * 32, "Keyboard ", FONT_VALUE_1);
- DrawText(mSX + 1 * 32, mSY + 4 * 32, "Customize", text_font_nr);
+ DrawText(mSX + 8 * 32, mSY + 3 * 32, "Keyboard ", font_nr_on);
+ DrawText(mSX + 1 * 32, mSY + 4 * 32, "Customize", font_nr_menu);
}
- DrawText(mSX + 32, mSY + 5 * 32, "Actual Settings:", FONT_MENU_1);
+ if (SCR_FIELDY >= SCR_FIELDY_DEFAULT)
+ DrawText(mSX + 32, mSY + 5 * 32, "Actual Settings:", font_nr_info);
+ else
+ pos = 3;
- drawCursorXY(1, 4, IMG_MENU_BUTTON_LEFT);
- drawCursorXY(1, 5, IMG_MENU_BUTTON_RIGHT);
- drawCursorXY(1, 6, IMG_MENU_BUTTON_UP);
- drawCursorXY(1, 7, IMG_MENU_BUTTON_DOWN);
+ drawCursorXY(1, pos + 0, IMG_MENU_BUTTON_LEFT);
+ drawCursorXY(1, pos + 1, IMG_MENU_BUTTON_RIGHT);
+ drawCursorXY(1, pos + 2, IMG_MENU_BUTTON_UP);
+ drawCursorXY(1, pos + 3, IMG_MENU_BUTTON_DOWN);
- DrawText(mSX + 2 * 32, mSY + 6 * 32, ":", FONT_VALUE_OLD);
- DrawText(mSX + 2 * 32, mSY + 7 * 32, ":", FONT_VALUE_OLD);
- DrawText(mSX + 2 * 32, mSY + 8 * 32, ":", FONT_VALUE_OLD);
- DrawText(mSX + 2 * 32, mSY + 9 * 32, ":", FONT_VALUE_OLD);
- DrawText(mSX + 1 * 32, mSY + 10 * 32, "Snap Field:", FONT_VALUE_OLD);
- DrawText(mSX + 1 * 32, mSY + 12 * 32, "Drop Element:", FONT_VALUE_OLD);
+ DrawText(mSX + 2 * 32, mSY + (pos + 2) * 32, ":", font_nr_name);
+ DrawText(mSX + 2 * 32, mSY + (pos + 3) * 32, ":", font_nr_name);
+ DrawText(mSX + 2 * 32, mSY + (pos + 4) * 32, ":", font_nr_name);
+ DrawText(mSX + 2 * 32, mSY + (pos + 5) * 32, ":", font_nr_name);
+ DrawText(mSX + 1 * 32, mSY + (pos + 6) * 32, "Snap Field:", font_nr_name);
+ DrawText(mSX + 1 * 32, mSY + (pos + 8) * 32, "Drop Element:", font_nr_name);
for (i = 0; i < 6; i++)
{
- int ypos = 6 + i + (i > 3 ? i-3 : 0);
+ int ypos = (pos + 2) + i + (i > 3 ? i - 3 : 0);
DrawText(mSX + 3 * 32, mSY + ypos * 32,
- " ", FONT_VALUE_1);
+ " ", font_nr_on);
DrawText(mSX + 3 * 32, mSY + ypos * 32,
(setup.input[player_nr].use_joystick ?
custom[i].text :
- getKeyNameFromKey(*custom[i].key)), FONT_VALUE_1);
+ getKeyNameFromKey(*custom[i].key)), font_nr_on);
}
}
int pos_empty2 = SETUPINPUT_SCREEN_POS_EMPTY2;
int pos_end = SETUPINPUT_SCREEN_POS_END;
+ if (SCR_FIELDY < SCR_FIELDY_DEFAULT)
+ {
+ int i;
+
+ for (i = 0; setup_info_input[i].type != 0; i++)
+ {
+ /* adjust menu structure according to skipped setup entries */
+ if (setup_info_input[i].type == TYPE_SKIPPABLE)
+ {
+ pos_empty2--;
+ pos_end--;
+ }
+ }
+ }
+
if (button == MB_MENU_INITIALIZE)
{
+ /* input setup menu may have changed size due to graphics configuration */
+ if (choice >= pos_empty1)
+ choice = pos_end;
+
drawPlayerSetupInputInfo(input_player_nr, (choice == 2));
DrawCursorAndText_Setup(choice, -1, TRUE);
}
}
-void CustomizeKeyboard(int player_nr)
+static boolean CustomizeKeyboardMain(int player_nr)
{
int i;
int step_nr;
{ &custom_key.snap, "Snap Field" },
{ &custom_key.drop, "Drop Element" }
};
+ int font_nr_old = FONT_VALUE_OLD;
+ int font_nr_new = FONT_VALUE_1;
+ boolean success = FALSE;
+
+ if (SCR_FIELDX < SCR_FIELDX_DEFAULT)
+ {
+ font_nr_old = FONT_VALUE_OLD_NARROW;
+ font_nr_new = FONT_VALUE_NARROW;
+ }
/* read existing key bindings from player setup */
custom_key = setup.input[player_nr].key;
DrawText(mSX, mSY + (2 + 2 * step_nr + 1) * 32,
"Key:", FONT_INPUT_1_ACTIVE);
DrawText(mSX + 4 * 32, mSY + (2 + 2 * step_nr + 1) * 32,
- getKeyNameFromKey(*customize_step[step_nr].key), FONT_VALUE_OLD);
+ getKeyNameFromKey(*customize_step[step_nr].key), font_nr_old);
FadeIn(REDRAW_FIELD);
{
Key key = GetEventKey((KeyEvent *)&event, FALSE);
- if (key == KSYM_Escape || (key == KSYM_Return && step_nr == 6))
+ /* press 'Escape' to abort and keep the old key bindings */
+ if (key == KSYM_Escape)
{
- if (key == KSYM_Escape)
- FadeSkipNextFadeIn();
+ FadeSkipNextFadeIn();
finished = TRUE;
- break;
- }
- /* all keys configured -- wait for "Escape" or "Return" key */
- if (step_nr == 6)
break;
+ }
/* press 'Enter' to keep the existing key binding */
if (key == KSYM_Return)
/* got new key binding */
*customize_step[step_nr].key = key;
DrawText(mSX + 4 * 32, mSY + (2 + 2 * step_nr + 1) * 32,
- " ", FONT_VALUE_1);
+ " ", font_nr_new);
DrawText(mSX + 4 * 32, mSY + (2 + 2 * step_nr + 1) * 32,
- getKeyNameFromKey(key), FONT_VALUE_1);
+ getKeyNameFromKey(key), font_nr_new);
step_nr++;
/* un-highlight last query */
DrawText(mSX, mSY + (2 + 2 * (step_nr - 1) + 1) * 32,
"Key:", FONT_MENU_1);
- /* press 'Enter' to leave */
+ /* all keys configured */
if (step_nr == 6)
{
- DrawText(mSX + 16, mSY + 15 * 32 + 16,
- "Press Enter", FONT_TITLE_1);
+ finished = TRUE;
+ success = TRUE;
+
break;
}
"Key:", FONT_INPUT_1_ACTIVE);
DrawText(mSX + 4 * 32, mSY + (2 + 2 * step_nr + 1) * 32,
getKeyNameFromKey(*customize_step[step_nr].key),
- FONT_VALUE_OLD);
+ font_nr_old);
}
break;
BackToFront();
}
- /* write new key bindings back to player setup */
- setup.input[player_nr].key = custom_key;
+ /* write new key bindings back to player setup, if successfully finished */
+ if (success)
+ setup.input[player_nr].key = custom_key;
+
+ return success;
+}
+
+void CustomizeKeyboard(int player_nr)
+{
+ boolean success = CustomizeKeyboardMain(player_nr);
+
+ if (success)
+ {
+ int font_nr = FONT_TITLE_1;
+ int font_height = getFontHeight(font_nr);
+ int ypos1 = SYSIZE / 2 - font_height * 2;
+ int ypos2 = SYSIZE / 2 - font_height * 1;
+ unsigned int wait_frame_delay = 0;
+ unsigned int wait_frame_delay_value = 2000;
+
+ ResetDelayCounter(&wait_frame_delay);
+
+ ClearField();
+
+ DrawTextSCentered(ypos1, font_nr, "Keyboard");
+ DrawTextSCentered(ypos2, font_nr, "configured!");
+
+ while (!DelayReached(&wait_frame_delay, wait_frame_delay_value))
+ BackToFront();
+
+ ClearEventQueue();
+ }
DrawSetupScreen_Input();
}
int alpha = 200, alpha_step = -1;
int alpha_ticks = 0;
char mapping[4096], temp[4096];
- int font_name = FONT_TEXT_1;
- int font_info = FONT_REQUEST;
- int ystep1 = getFontHeight(font_name) + 2;
- int ystep2 = getFontHeight(font_info) + 2;
+ int font_name = MENU_SETUP_FONT_TITLE;
+ int font_info = MENU_SETUP_FONT_TEXT;
+ int spacing_name = menu.line_spacing_setup[SETUP_MODE_INPUT];
+ int spacing_line = menu.line_spacing_setup[SETUP_MODE_INPUT];
+ int spacing_para = menu.paragraph_spacing_setup[SETUP_MODE_INPUT];
+ int ystep_name = getMenuTextStep(spacing_name, font_name);
+ int ystep_line = getMenuTextStep(spacing_line, font_info);
+ int ystep_para = getMenuTextStep(spacing_para, font_info);
int i, j;
struct
}
int controller_x = SX + (SXSIZE - controller->width) / 2;
- int controller_y = SY + ystep2;
+ int controller_y = SY + ystep_line;
int marker_x = controller_x + step->x;
int marker_y = controller_y + step->y;
int ystart1 = mSY - 2 * SY + controller_y + controller->height;
- int ystart2 = ystart1 + ystep1 + ystep2;
+ int ystart2 = ystart1 + ystep_name + ystep_line;
ClearField();
DrawTextSCentered(ystart1, font_name, name);
- DrawTextSCentered(ystart2 + 0 * ystep2, font_info,
+ DrawTextSCentered(ystart2, font_info,
"Press buttons and move axes on");
- DrawTextSCentered(ystart2 + 1 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"your controller when indicated.");
- DrawTextSCentered(ystart2 + 2 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"(Your controller may look different.)");
+ ystart2 += ystep_para;
#if defined(PLATFORM_ANDROID)
- DrawTextSCentered(ystart2 + 4 * ystep2, font_info,
+ DrawTextSCentered(ystart2, font_info,
"To correct a mistake,");
- DrawTextSCentered(ystart2 + 5 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"press the 'back' button.");
- DrawTextSCentered(ystart2 + 6 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"To skip a button or axis,");
- DrawTextSCentered(ystart2 + 7 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"press the 'menu' button.");
#else
- DrawTextSCentered(ystart2 + 4 * ystep2, font_info,
+ DrawTextSCentered(ystart2, font_info,
"To correct a mistake,");
- DrawTextSCentered(ystart2 + 5 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"press the 'backspace' key.");
- DrawTextSCentered(ystart2 + 6 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"To skip a button or axis,");
- DrawTextSCentered(ystart2 + 7 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"press the 'return' key.");
-
- DrawTextSCentered(ystart2 + 8 * ystep2, font_info,
+ ystart2 += ystep_line;
+ DrawTextSCentered(ystart2, font_info,
"To exit, press the 'escape' key.");
#endif
controller->width, controller->height,
controller_x, controller_y);
+ SDL_SetSurfaceBlendMode(marker->surface_masked, SDL_BLENDMODE_BLEND);
SDL_SetSurfaceAlphaMod(marker->surface_masked, alpha);
BlitBitmapMasked(marker, drawto, 0, 0,
/* leave screen */
success = FALSE;
done = TRUE;
+
+ break;
}
/* undo this step */
if (state != JOYSTICK_NOT_CONFIGURED)
{
boolean success = (state == JOYSTICK_CONFIGURED);
- char *message = (success ? " IS CONFIGURED! " : " NOT AVAILABLE! ");
+ char message1[MAX_OUTPUT_LINESIZE + 1];
+ char *message2 = (success ? "configured!" : "not available!");
char *device_name = setup.input[player_nr].joy.device_name;
int nr = getJoystickNrFromDeviceName(device_name) + 1;
- int xpos = mSX - SX;
- int ypos = mSY - SY;
+ int font_nr = FONT_TITLE_1;
+ int font_height = getFontHeight(font_nr);
+ int ypos1 = SYSIZE / 2 - font_height * 2;
+ int ypos2 = SYSIZE / 2 - font_height * 1;
unsigned int wait_frame_delay = 0;
unsigned int wait_frame_delay_value = 2000;
ClearField();
- DrawTextF(xpos + 16, ypos + 6 * 32, FONT_TITLE_1, " JOYSTICK %d ", nr);
- DrawTextF(xpos + 16, ypos + 7 * 32, FONT_TITLE_1, message);
+ sprintf(message1, "Joystick %d", nr);
+
+ DrawTextSCentered(ypos1, font_nr, message1);
+ DrawTextSCentered(ypos2, font_nr, message2);
while (!DelayReached(&wait_frame_delay, wait_frame_delay_value))
BackToFront();
DrawSetupScreen_Input();
}
+boolean ConfigureVirtualButtonsMain()
+{
+ static char *customize_step_text[] =
+ {
+ "Move Left",
+ "Move Right",
+ "Move Up",
+ "Move Down",
+ "Snap Field",
+ "Drop Element"
+ };
+ char grid_button[] =
+ {
+ CHAR_GRID_BUTTON_LEFT,
+ CHAR_GRID_BUTTON_RIGHT,
+ CHAR_GRID_BUTTON_UP,
+ CHAR_GRID_BUTTON_DOWN,
+ CHAR_GRID_BUTTON_SNAP,
+ CHAR_GRID_BUTTON_DROP
+ };
+ int font_nr = FONT_INPUT_1_ACTIVE;
+ int font_height = getFontHeight(font_nr);
+ int ypos1 = SYSIZE / 2 - font_height * 2;
+ int ypos2 = SYSIZE / 2 - font_height * 1;
+ boolean success = FALSE;
+ boolean finished = FALSE;
+ int step_nr = 0;
+ char grid_button_draw = CHAR_GRID_BUTTON_NONE;
+ char grid_button_old[MAX_GRID_XSIZE][MAX_GRID_YSIZE];
+ char grid_button_tmp[MAX_GRID_XSIZE][MAX_GRID_YSIZE];
+ boolean set_grid_button = FALSE;
+ int nr = GRID_ACTIVE_NR();
+ int x, y;
+
+ for (x = 0; x < MAX_GRID_XSIZE; x++)
+ for (y = 0; y < MAX_GRID_YSIZE; y++)
+ grid_button_old[x][y] = grid_button_tmp[x][y] = overlay.grid_button[x][y];
+
+ overlay.grid_button_highlight = grid_button[step_nr];
+
+ FadeSetEnterMenu();
+ FadeOut(REDRAW_FIELD);
+
+ ClearField();
+
+ DrawTextSCentered(mSY - SY + 16, FONT_TITLE_1, "Virtual Buttons");
+ DrawTextSCentered(ypos1, font_nr, "Select tiles to");
+ DrawTextSCentered(ypos2, font_nr, customize_step_text[step_nr]);
+
+ FadeIn(REDRAW_FIELD);
+
+ SetOverlayShowGrid(TRUE);
+
+ while (!finished)
+ {
+ Event event;
+
+ while (NextValidEvent(&event))
+ {
+ switch (event.type)
+ {
+ case EVENT_KEYPRESS:
+ {
+ Key key = GetEventKey((KeyEvent *)&event, FALSE);
+
+ /* press 'Escape' to abort and keep the old key bindings */
+ if (key == KSYM_Escape)
+ {
+ for (x = 0; x < MAX_GRID_XSIZE; x++)
+ for (y = 0; y < MAX_GRID_YSIZE; y++)
+ overlay.grid_button[x][y] = grid_button_old[x][y];
+
+ FadeSkipNextFadeIn();
+
+ finished = TRUE;
+
+ break;
+ }
+
+ /* press 'Enter' to keep the existing key binding */
+ if (key == KSYM_Return ||
+ key == KSYM_Menu ||
+ key == KSYM_space)
+ {
+ step_nr++;
+ }
+ else if (key == KSYM_BackSpace ||
+ key == KSYM_Back)
+ {
+ if (step_nr == 0)
+ {
+ FadeSkipNextFadeIn();
+
+ finished = TRUE;
+
+ break;
+ }
+
+ step_nr--;
+ }
+ else
+ {
+ break;
+ }
+
+ /* all virtual buttons configured */
+ if (step_nr == 6)
+ {
+ finished = TRUE;
+ success = TRUE;
+
+ break;
+ }
+
+ for (x = 0; x < MAX_GRID_XSIZE; x++)
+ for (y = 0; y < MAX_GRID_YSIZE; y++)
+ grid_button_tmp[x][y] = overlay.grid_button[x][y];
+
+ overlay.grid_button_highlight = grid_button[step_nr];
+
+ /* query next virtual button */
+
+ ClearField();
+
+ DrawTextSCentered(mSY - SY + 16, FONT_TITLE_1, "Virtual Buttons");
+ DrawTextSCentered(ypos1, font_nr, "Select tiles to");
+ DrawTextSCentered(ypos2, font_nr, customize_step_text[step_nr]);
+ }
+ break;
+
+ case EVENT_KEYRELEASE:
+ key_joystick_mapping = 0;
+ break;
+
+ case EVENT_BUTTONPRESS:
+ case EVENT_BUTTONRELEASE:
+ {
+ ButtonEvent *button = (ButtonEvent *)&event;
+
+ button->x += video.screen_xoffset;
+ button->y += video.screen_yoffset;
+
+ x = button->x * overlay.grid_xsize / video.screen_width;
+ y = button->y * overlay.grid_ysize / video.screen_height;
+
+ if (button->type == EVENT_BUTTONPRESS)
+ {
+ button_status = button->button;
+
+ grid_button_draw =
+ (overlay.grid_button[x][y] != grid_button[step_nr] ?
+ grid_button[step_nr] : CHAR_GRID_BUTTON_NONE);
+
+ set_grid_button = TRUE;
+ }
+ else
+ {
+ button_status = MB_RELEASED;
+ }
+ }
+ break;
+
+ case EVENT_MOTIONNOTIFY:
+ {
+ MotionEvent *motion = (MotionEvent *)&event;
+
+ motion->x += video.screen_xoffset;
+ motion->y += video.screen_yoffset;
+
+ x = motion->x * overlay.grid_xsize / video.screen_width;
+ y = motion->y * overlay.grid_ysize / video.screen_height;
+
+ set_grid_button = TRUE;
+ }
+ break;
+
+#if defined(TARGET_SDL2)
+ case SDL_WINDOWEVENT:
+ HandleWindowEvent((WindowEvent *) &event);
+
+ // check if device has been rotated
+ if (nr != GRID_ACTIVE_NR())
+ {
+ nr = GRID_ACTIVE_NR();
+
+ for (x = 0; x < MAX_GRID_XSIZE; x++)
+ for (y = 0; y < MAX_GRID_YSIZE; y++)
+ grid_button_old[x][y] = grid_button_tmp[x][y] =
+ overlay.grid_button[x][y];
+ }
+
+ break;
+
+ case SDL_APP_WILLENTERBACKGROUND:
+ case SDL_APP_DIDENTERBACKGROUND:
+ case SDL_APP_WILLENTERFOREGROUND:
+ case SDL_APP_DIDENTERFOREGROUND:
+ HandlePauseResumeEvent((PauseResumeEvent *) &event);
+ break;
+#endif
+
+ default:
+ HandleOtherEvents(&event);
+ break;
+ }
+
+ if (set_grid_button)
+ {
+ overlay.grid_button[x][y] =
+ (grid_button_draw != CHAR_GRID_BUTTON_NONE ? grid_button_draw :
+ grid_button_tmp[x][y] == grid_button[step_nr] ? CHAR_GRID_BUTTON_NONE :
+ grid_button_tmp[x][y]);
+
+ set_grid_button = FALSE;
+ }
+ }
+
+ BackToFront();
+ }
+
+ for (x = 0; x < MAX_GRID_XSIZE; x++)
+ for (y = 0; y < MAX_GRID_YSIZE; y++)
+ setup.touch.grid_button[nr][x][y] = overlay.grid_button[x][y];
+
+ overlay.grid_button_highlight = CHAR_GRID_BUTTON_NONE;
+
+ SetOverlayShowGrid(FALSE);
+
+ return success;
+}
+
+void ConfigureVirtualButtons()
+{
+ boolean success = ConfigureVirtualButtonsMain();
+
+ if (success)
+ {
+ int font_nr = FONT_TITLE_1;
+ int font_height = getFontHeight(font_nr);
+ int ypos1 = SYSIZE / 2 - font_height * 2;
+ int ypos2 = SYSIZE / 2 - font_height * 1;
+ unsigned int wait_frame_delay = 0;
+ unsigned int wait_frame_delay_value = 2000;
+
+ ResetDelayCounter(&wait_frame_delay);
+
+ ClearField();
+
+ DrawTextSCentered(ypos1, font_nr, "Virtual buttons");
+ DrawTextSCentered(ypos2, font_nr, "configured!");
+
+ while (!DelayReached(&wait_frame_delay, wait_frame_delay_value))
+ BackToFront();
+
+ ClearEventQueue();
+ }
+}
+
void DrawSetupScreen()
{
if (setup_mode == SETUP_MODE_INPUT)
DrawChooseTree(&move_distance_current);
else if (setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE)
DrawChooseTree(&drop_distance_current);
+ else if (setup_mode == SETUP_MODE_CHOOSE_TRANSPARENCY)
+ DrawChooseTree(&transparency_current);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_0)
+ DrawChooseTree(&grid_size_current[0][0]);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_0)
+ DrawChooseTree(&grid_size_current[0][1]);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_1)
+ DrawChooseTree(&grid_size_current[1][0]);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_1)
+ DrawChooseTree(&grid_size_current[1][1]);
else
DrawSetupScreen_Generic();
}
}
+void RedrawSetupScreenAfterScreenRotation(int nr)
+{
+ int x, y;
+
+ if (setup_mode == SETUP_MODE_TOUCH)
+ {
+ // update virtual button settings (depending on screen orientation)
+ DrawSetupScreen();
+ }
+ else if (setup_mode == SETUP_MODE_CONFIG_VIRT_BUTTONS)
+ {
+ // save already configured virtual buttons
+ for (x = 0; x < MAX_GRID_XSIZE; x++)
+ for (y = 0; y < MAX_GRID_YSIZE; y++)
+ setup.touch.grid_button[nr][x][y] = overlay.grid_button[x][y];
+ }
+}
+
void HandleSetupScreen(int mx, int my, int dx, int dy, int button)
{
if (setup_mode == SETUP_MODE_INPUT)
HandleChooseTree(mx, my, dx, dy, button, &move_distance_current);
else if (setup_mode == SETUP_MODE_CHOOSE_DROP_DISTANCE)
HandleChooseTree(mx, my, dx, dy, button, &drop_distance_current);
+ else if (setup_mode == SETUP_MODE_CHOOSE_TRANSPARENCY)
+ HandleChooseTree(mx, my, dx, dy, button, &transparency_current);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_0)
+ HandleChooseTree(mx, my, dx, dy, button, &grid_size_current[0][0]);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_0)
+ HandleChooseTree(mx, my, dx, dy, button, &grid_size_current[0][1]);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_XSIZE_1)
+ HandleChooseTree(mx, my, dx, dy, button, &grid_size_current[1][0]);
+ else if (setup_mode == SETUP_MODE_CHOOSE_GRID_YSIZE_1)
+ HandleChooseTree(mx, my, dx, dy, button, &grid_size_current[1][1]);
else
HandleSetupScreen_Generic(mx, my, dx, dy, button);
}
void HandleGameActions()
{
+ if (game.restart_game_message != NULL)
+ RequestRestartGame(game.restart_game_message);
+
if (game_status != GAME_MODE_PLAYING)
return;