mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-11 18:59:07 +01:00
+ improved controller setting menu
+ improved GUI generic code
This commit is contained in:
parent
a9de2b70d1
commit
67517fa794
@ -68,8 +68,8 @@ static butn_data arrow_down_data =
|
||||
/* GUI Arrows button */
|
||||
/*****************************************************************************/
|
||||
|
||||
static gui_butn arrow_up = {&arrow_up_data,BUTTON_VISIBLE|BUTTON_OVER_SFX,{0,0},14,76,360,32};
|
||||
static gui_butn arrow_down = {&arrow_down_data,BUTTON_VISIBLE|BUTTON_OVER_SFX,{0,0},14,368,360,32};
|
||||
static gui_butn arrow_up = {&arrow_up_data,BUTTON_VISIBLE|BUTTON_OVER_SFX,{0,0,0,0},14,76,360,32};
|
||||
static gui_butn arrow_down = {&arrow_down_data,BUTTON_VISIBLE|BUTTON_OVER_SFX,{0,0,0,0},14,368,360,32};
|
||||
|
||||
/*****************************************************************************/
|
||||
/* GUI helpers */
|
||||
@ -97,16 +97,16 @@ static gui_item action_select =
|
||||
/*****************************************************************************/
|
||||
static gui_image bg_filesel[10] =
|
||||
{
|
||||
{NULL,Bg_main_png,IMAGE_VISIBLE,356,144,348,288,255,{0,0},{0,0}},
|
||||
{NULL,Bg_overlay_png,IMAGE_VISIBLE|IMAGE_REPEAT,0,0,640,480,255,{0,0},{0,0}},
|
||||
{NULL,Banner_top_png,IMAGE_VISIBLE,0,0,640,108,255,{0,0},{0,0}},
|
||||
{NULL,Banner_bottom_png,IMAGE_VISIBLE,0,380,640,100,255,{0,0},{0,0}},
|
||||
{NULL,Main_logo_png,IMAGE_VISIBLE,466,40,152,44,255,{0,0},{0,0}},
|
||||
{NULL,Frame_s1_png,IMAGE_VISIBLE,8,70,372,336,200,{0,0},{0,0}},
|
||||
{NULL,Frame_s2_png,0,384,264,248,140,200,{0,0},{0,0}},
|
||||
{NULL,Snap_empty_png,IMAGE_VISIBLE,422,114,164,116,255,{0,0},{0,0}},
|
||||
{NULL,NULL,0,424,116,160,112,255,{0,0},{0,0}},
|
||||
{NULL,Snap_frame_png,IMAGE_VISIBLE,388,112,236,148,255,{0,0},{0,0}}
|
||||
{NULL,Bg_main_png,IMAGE_VISIBLE,356,144,348,288,255},
|
||||
{NULL,Bg_overlay_png,IMAGE_VISIBLE|IMAGE_REPEAT,0,0,640,480,255},
|
||||
{NULL,Banner_top_png,IMAGE_VISIBLE,0,0,640,108,255},
|
||||
{NULL,Banner_bottom_png,IMAGE_VISIBLE,0,380,640,100,255},
|
||||
{NULL,Main_logo_png,IMAGE_VISIBLE,466,40,152,44,255},
|
||||
{NULL,Frame_s1_png,IMAGE_VISIBLE,8,70,372,336,200},
|
||||
{NULL,Frame_s2_png,0,384,264,248,140,200},
|
||||
{NULL,Snap_empty_png,IMAGE_VISIBLE,422,114,164,116,255},
|
||||
{NULL,NULL,0,424,116,160,112,255},
|
||||
{NULL,Snap_frame_png,IMAGE_VISIBLE,388,112,236,148,255}
|
||||
};
|
||||
|
||||
/*****************************************************************************/
|
||||
@ -197,10 +197,6 @@ int FileSelector(unsigned char *buffer)
|
||||
bar_over.x = 22;
|
||||
bar_over.y = -(bar_over.h - dir_icon.h)/2;
|
||||
|
||||
/* Initialize star icons */
|
||||
//gx_texture *star_full = gxTextureOpenPNG(Star_full_png);
|
||||
//gx_texture *star_empty = gxTextureOpenPNG(Star_empty_png);
|
||||
|
||||
while (!quit)
|
||||
{
|
||||
/* get ROM filename without extension */
|
||||
@ -300,6 +296,7 @@ int FileSelector(unsigned char *buffer)
|
||||
{
|
||||
gxTextureClose(&w_pointer);
|
||||
GUI_DeleteMenu(m);
|
||||
GUI_FadeOut();
|
||||
shutdown();
|
||||
SYS_ResetSystem(SYS_POWEROFF, 0, 0);
|
||||
}
|
||||
@ -486,8 +483,6 @@ int FileSelector(unsigned char *buffer)
|
||||
GUI_DeleteMenu(m);
|
||||
gxTextureClose(&bar_over.texture);
|
||||
gxTextureClose(&dir_icon.texture);
|
||||
//gxTextureClose(&star_full);
|
||||
//gxTextureClose(&star_empty);
|
||||
|
||||
if (quit == 2) return 0;
|
||||
else if (useFAT) return FAT_LoadFile(buffer);
|
||||
|
@ -186,19 +186,35 @@ int FONT_write(char *string, int size, int x, int y, int max_width, GXColor colo
|
||||
|
||||
void FONT_writeCenter(char *string, int size, int x1, int x2, int y, GXColor color)
|
||||
{
|
||||
int i;
|
||||
int i=0;
|
||||
u16 width = 0;
|
||||
|
||||
for (i=0; i<strlen(string); i++)
|
||||
width += (font_size[(u8)string[i]] * size) / fheight;
|
||||
while (string[i] && (string[i] != '\n'))
|
||||
width += (font_size[(u8)string[i++]] * size) / fheight;
|
||||
|
||||
x1 += (x2 - x1 - width - vmode->fbWidth) / 2;
|
||||
int x = x1 + (x2 - x1 - width - vmode->fbWidth) / 2;
|
||||
y -= (vmode->efbHeight / 2);
|
||||
|
||||
while (*string)
|
||||
while (*string && (*string != '\n'))
|
||||
{
|
||||
DrawChar(*string, x1, y, size,color);
|
||||
x1 += (font_size[(u8)*string++] * size) / fheight;
|
||||
DrawChar(*string, x, y, size,color);
|
||||
x += (font_size[(u8)*string++] * size) / fheight;
|
||||
}
|
||||
|
||||
if (*string == '\n')
|
||||
{
|
||||
string++;
|
||||
i = 0;
|
||||
width = 0;
|
||||
while (string[i])
|
||||
width += (font_size[(u8)string[i++]] * size) / fheight;
|
||||
x = x1 + (x2 - x1 - width - vmode->fbWidth) / 2;
|
||||
y += size;
|
||||
while (*string)
|
||||
{
|
||||
DrawChar(*string, x, y, size,color);
|
||||
x += (font_size[(u8)*string++] * size) / fheight;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
1611
source/gx/gui/menu.c
1611
source/gx/gui/menu.c
File diff suppressed because it is too large
Load Diff
@ -32,20 +32,27 @@
|
||||
/*****************************************************************************/
|
||||
/* GUI Buttons state */
|
||||
/*****************************************************************************/
|
||||
#define BUTTON_VISIBLE 0x01
|
||||
#define BUTTON_SHIFT 0x02
|
||||
#define BUTTON_ACTIVE 0x04
|
||||
#define BUTTON_OVER_SFX 0x10
|
||||
#define BUTTON_SELECT_SFX 0x20
|
||||
#define BUTTON_VISIBLE 0x01
|
||||
#define BUTTON_SHIFT 0x02
|
||||
#define BUTTON_ACTIVE 0x04
|
||||
#define BUTTON_OVER_SFX 0x08
|
||||
#define BUTTON_SELECT_SFX 0x10
|
||||
#define BUTTON_FADE 0x20
|
||||
#define BUTTON_SLIDE_LEFT 0x40
|
||||
#define BUTTON_SLIDE_RIGHT 0x80
|
||||
#define BUTTON_SLIDE_TOP 0x100
|
||||
#define BUTTON_SLIDE_BOTTOM 0x200
|
||||
|
||||
/*****************************************************************************/
|
||||
/* GUI Image state */
|
||||
/*****************************************************************************/
|
||||
#define IMAGE_VISIBLE 0x01
|
||||
#define IMAGE_REPEAT 0x02
|
||||
#define IMAGE_FADE 0x10
|
||||
#define IMAGE_SLIDE_X 0x20
|
||||
#define IMAGE_SLIDE_Y 0x40
|
||||
#define IMAGE_VISIBLE 0x01
|
||||
#define IMAGE_REPEAT 0x02
|
||||
#define IMAGE_FADE 0x04
|
||||
#define IMAGE_SLIDE_LEFT 0x08
|
||||
#define IMAGE_SLIDE_RIGHT 0x10
|
||||
#define IMAGE_SLIDE_TOP 0x20
|
||||
#define IMAGE_SLIDE_BOTTOM 0x40
|
||||
|
||||
/*****************************************************************************/
|
||||
/* GUI png data */
|
||||
@ -186,7 +193,7 @@ typedef struct
|
||||
u16 h; /* item image or text height */
|
||||
} gui_item;
|
||||
|
||||
/* Button descriptor */
|
||||
/* Button Data descriptor */
|
||||
typedef struct
|
||||
{
|
||||
gx_texture *texture[2]; /* temporary texture datas */
|
||||
@ -197,7 +204,7 @@ typedef struct
|
||||
typedef struct
|
||||
{
|
||||
butn_data *data; /* pointer to button image/texture data */
|
||||
u8 state; /* button state (ACTIVE,VISIBLE,SELECTED...) */
|
||||
u16 state; /* button state (ACTIVE,VISIBLE,SELECTED...) */
|
||||
u8 shift[4]; /* direction offsets */
|
||||
u16 x; /* button image X position (upper left corner) */
|
||||
u16 y; /* button image Y position (upper left corner) */
|
||||
@ -216,8 +223,6 @@ typedef struct
|
||||
u16 w; /* image width */
|
||||
u16 h; /* image height */
|
||||
u8 alpha; /* alpha transparency */
|
||||
u16 xrange[2]; /* image X range (slide effect) */
|
||||
u16 yrange[2]; /* image Y range (slide effect) */
|
||||
} gui_image;
|
||||
|
||||
/* Menu descriptor */
|
||||
@ -248,11 +253,12 @@ extern gx_texture *w_pointer;
|
||||
|
||||
|
||||
extern void MainMenu(void);
|
||||
extern void GUI_FadeOut();
|
||||
extern void GUI_InitMenu(gui_menu *menu);
|
||||
extern void GUI_DeleteMenu(gui_menu *menu);
|
||||
extern void GUI_DrawMenu(gui_menu *menu);
|
||||
extern void GUI_DrawMenuFX(gui_menu *menu, u8 speed, u8 out);
|
||||
extern void GUI_FadeMenu(gui_menu *menu, u8 speed, u8 out);
|
||||
extern int GUI_UpdateMenu(gui_menu *menu);
|
||||
extern int GUI_RunMenu(gui_menu *menu);
|
||||
extern int GUI_WindowPrompt(gui_menu *parent, char *title, char *items[], u8 nb_items);
|
||||
#endif
|
||||
|
@ -73,8 +73,8 @@ static int held_cnt = 0;
|
||||
/* default directions mapping */
|
||||
static u32 wpad_dirmap[3][4] =
|
||||
{
|
||||
{WPAD_BUTTON_RIGHT, WPAD_BUTTON_LEFT, WPAD_BUTTON_UP, WPAD_BUTTON_DOWN}, /* WIIMOTE */
|
||||
{WPAD_BUTTON_UP, WPAD_BUTTON_DOWN, WPAD_BUTTON_LEFT, WPAD_BUTTON_RIGHT}, /* WIIMOTE + NUNCHUK */
|
||||
{WPAD_BUTTON_RIGHT, WPAD_BUTTON_LEFT, WPAD_BUTTON_UP, WPAD_BUTTON_DOWN}, /* WIIMOTE */
|
||||
{WPAD_BUTTON_UP, WPAD_BUTTON_DOWN, WPAD_BUTTON_LEFT, WPAD_BUTTON_RIGHT}, /* WIIMOTE + NUNCHUK */
|
||||
{WPAD_CLASSIC_BUTTON_UP, WPAD_CLASSIC_BUTTON_DOWN, WPAD_CLASSIC_BUTTON_LEFT, WPAD_CLASSIC_BUTTON_RIGHT} /* CLASSIC */
|
||||
};
|
||||
#endif
|
||||
@ -96,11 +96,7 @@ static void pad_config(int chan, int max_keys)
|
||||
WaitPrompt(msg);
|
||||
|
||||
/* remove any pending keys */
|
||||
while (PAD_ButtonsHeld(chan))
|
||||
{
|
||||
VIDEO_WaitVSync();
|
||||
PAD_ScanPads();
|
||||
}
|
||||
while (m_input.keys) VIDEO_WaitVSync();
|
||||
return;
|
||||
}
|
||||
|
||||
@ -337,12 +333,7 @@ static void wpad_config(u8 chan, u8 exp, u8 max_keys)
|
||||
WaitPrompt(msg);
|
||||
|
||||
/* remove any pending buttons */
|
||||
while (WPAD_ButtonsHeld(chan))
|
||||
{
|
||||
WPAD_ScanPads();
|
||||
VIDEO_WaitVSync();
|
||||
}
|
||||
|
||||
while (m_input.keys) VIDEO_WaitVSync();
|
||||
return;
|
||||
}
|
||||
|
||||
|
@ -217,7 +217,7 @@ int main (int argc, char *argv[])
|
||||
gx_audio_Init();
|
||||
|
||||
/* initialize core engine */
|
||||
legal();
|
||||
// legal();
|
||||
config_default();
|
||||
history_default();
|
||||
init_machine();
|
||||
|
Loading…
x
Reference in New Issue
Block a user