X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=common%2Fmenu.h;h=74bf8e688be6a7d63b356d9978364085b5472c5b;hb=0c9ae59222a6fa9af18dcc072fdfb06cfca124d6;hp=0b5aac30cc2c5d4226aecc1199760fd730544bba;hpb=0ae25549b5066ea8b42216ec875f5c3c5d5bd8d6;p=libpicofe.git diff --git a/common/menu.h b/common/menu.h index 0b5aac3..74bf8e6 100644 --- a/common/menu.h +++ b/common/menu.h @@ -1,20 +1,14 @@ -// (c) Copyright 2006,2007 notaz, All rights reserved. - - -void menu_init(void); -void text_out16(int x, int y, const char *texto, ...); -void smalltext_out16(int x, int y, const char *texto, int color); -void smalltext_out16_lim(int x, int y, const char *texto, int color, int max); -void menu_draw_selection(int x, int y, int w); - -extern char menuErrorMsg[64]; - +// (c) Copyright 2006-2009 notaz, All rights reserved. typedef enum { MB_NONE = 1, /* no auto processing */ - MB_ONOFF, /* ON/OFF setting */ - MB_RANGE, /* [min-max] setting */ + MB_OPT_ONOFF, /* ON/OFF setting */ + MB_OPT_RANGE, /* [min-max] setting */ + MB_OPT_CUSTOM, /* custom value */ + MB_OPT_CUSTONOFF, + MB_OPT_CUSTRANGE, + MB_OPT_ENUM, } menu_behavior; typedef enum @@ -25,14 +19,12 @@ typedef enum MA_MAIN_LOAD_STATE, MA_MAIN_RESET_GAME, MA_MAIN_LOAD_ROM, - MA_MAIN_OPTIONS, MA_MAIN_CONTROLS, MA_MAIN_CREDITS, MA_MAIN_PATCHES, MA_MAIN_EXIT, MA_OPT_RENDERER, MA_OPT_SCALING, - MA_OPT_ACC_TIMING, MA_OPT_ACC_SPRITES, MA_OPT_SHOW_FPS, MA_OPT_FRAMESKIP, @@ -52,6 +44,8 @@ typedef enum MA_OPT_SAVECFG_GAME, MA_OPT_LOADCFG, MA_OPT_INTERLACED, /* giz */ + MA_OPT_ROTATION, /* uiq */ + MA_OPT_TEARING_FIX, /* wiz */ MA_OPT2_GAMMA, MA_OPT2_A_SN_GAMMA, MA_OPT2_DBLBUFF, /* giz */ @@ -65,6 +59,9 @@ typedef enum MA_OPT2_SQUIDGEHACK, /* gp2x */ MA_OPT2_STATUS_LINE, /* psp */ MA_OPT2_NO_FRAME_LIMIT, /* psp */ + MA_OPT2_SVP_DYNAREC, + MA_OPT2_NO_SPRITE_LIM, + MA_OPT2_NO_IDLE_LOOPS, MA_OPT2_DONE, MA_OPT3_SCALE, /* psp (all OPT3) */ MA_OPT3_HSCALE32, @@ -75,6 +72,7 @@ typedef enum MA_OPT3_FILTERING, MA_OPT3_VSYNC, MA_OPT3_GAMMAA, + MA_OPT3_BLACKLVL, MA_OPT3_DONE, MA_CDOPT_TESTBIOS_USA, MA_CDOPT_TESTBIOS_EUR, @@ -87,30 +85,108 @@ typedef enum MA_CDOPT_SCALEROT_CHIP, MA_CDOPT_BETTER_SYNC, MA_CDOPT_DONE, + MA_32XOPT_ENABLE_32X, + MA_32XOPT_RENDERER, + MA_32XOPT_PWM, + MA_32XOPT_MSH2_CYCLES, + MA_32XOPT_SSH2_CYCLES, + MA_CTRL_PLAYER1, + MA_CTRL_PLAYER2, + MA_CTRL_EMU, + MA_CTRL_TURBO_RATE, + MA_CTRL_DEV_FIRST, + MA_CTRL_DEV_NEXT, + MA_CTRL_DONE, } menu_id; typedef struct { - char *name; + const char *name; menu_behavior beh; menu_id id; - void *var; /* for on-off settings */ - int mask; - signed char min; /* for ranged integer settings, to be sign-extended */ - signed char max; - char enabled; - char need_to_save; + void *var; /* for on-off/range settings */ + int mask; /* bit to toggle for on/off */ + signed short min; /* for ranged integer settings, to be sign-extended */ + signed short max; + int enabled:1; + int need_to_save:1; + int selectable:1; + int (*handler)(menu_id id, int keys); + const char * (*generate_name)(menu_id id, int *offs); + const void *data; + const char *help; } menu_entry; +#define mee_handler_id(name, id, handler) \ + { name, MB_NONE, id, NULL, 0, 0, 0, 1, 0, 1, handler, NULL, NULL, NULL } + +#define mee_handler(name, handler) \ + mee_handler_id(name, MA_NONE, handler) + +#define mee_label(name) \ + { name, MB_NONE, MA_NONE, NULL, 0, 0, 0, 1, 0, 0, NULL, NULL, NULL, NULL } + +#define mee_label_mk(id, name_func) \ + { "", MB_NONE, id, NULL, 0, 0, 0, 1, 0, 0, NULL, name_func, NULL, NULL } + +#define mee_onoff_h(name, id, var, mask, help) \ + { name, MB_OPT_ONOFF, id, &(var), mask, 0, 0, 1, 1, 1, NULL, NULL, NULL, help } + +#define mee_onoff(name, id, var, mask) \ + mee_onoff_h(name, id, var, mask, NULL) + +#define mee_range(name, id, var, min, max) \ + { name, MB_OPT_RANGE, id, &(var), 0, min, max, 1, 1, 1, NULL, NULL, NULL, NULL } + +#define mee_cust_s_h(name, id, need_save, handler, name_func, help) \ + { name, MB_OPT_CUSTOM, id, NULL, 0, 0, 0, 1, need_save, 1, handler, name_func, NULL, help } + +#define mee_cust_h(name, id, handler, name_func, help) \ + mee_cust_s_h(name, id, 1, handler, name_func, help) + +#define mee_cust(name, id, handler, name_func) \ + mee_cust_h(name, id, handler, name_func, NULL) + +#define mee_cust_nosave(name, id, handler, name_func) \ + mee_cust_s_h(name, id, 0, handler, name_func, NULL) + +#define mee_onoff_cust(name, id, var, mask, name_func) \ + { name, MB_OPT_CUSTONOFF, id, &(var), mask, 0, 0, 1, 1, 1, NULL, name_func, NULL, NULL } + +#define mee_range_cust(name, id, var, min, max, name_func) \ + { name, MB_OPT_CUSTRANGE, id, &(var), 0, min, max, 1, 1, 1, NULL, name_func, NULL, NULL } + +#define mee_enum_h(name, id, var, names_list, help) \ + { name, MB_OPT_ENUM, id, &(var), 0, 0, 0, 1, 1, 1, NULL, NULL, names_list, help } + +#define mee_enum(name, id, var, names_list) \ + mee_enum_h(name, id, var, names_list, NULL) + +#define mee_end \ + { NULL, 0, 0, NULL, 0, 0, 0, 0, 0, 0, NULL, NULL, NULL, NULL } + +typedef struct +{ + char *name; + int mask; +} me_bind_action; + +extern me_bind_action me_ctrl_actions[15]; +extern me_bind_action emuctrl_actions[]; // platform code + +extern void *g_menubg_ptr; + +void menu_init(void); +void menu_plat_setup(int is_wiz); +void text_out16(int x, int y, const char *texto, ...); +void me_update_msg(const char *msg); -typedef void (me_draw_custom_f)(const menu_entry *entry, int x, int y, void *param); +void menu_romload_prepare(const char *rom_name); +void menu_romload_end(void); -int me_id2offset(const menu_entry *entries, int count, menu_id id); -void me_enable(menu_entry *entries, int count, menu_id id, int enable); -int me_count_enabled(const menu_entry *entries, int count); -menu_id me_index2id(const menu_entry *entries, int count, int index); -void me_draw(const menu_entry *entries, int count, int x, int y, me_draw_custom_f *cust_draw, void *param); -int me_process(menu_entry *entries, int count, menu_id id, int is_next); +void menu_loop(void); +int menu_loop_tray(void); -const char *me_region_name(unsigned int code, int auto_order); +menu_entry *me_list_get_first(void); +menu_entry *me_list_get_next(void);