mirror of
				https://github.com/RaySollium99/libpicofe.git
				synced 2025-10-26 17:19:40 -04:00 
			
		
		
		
	fix gp2x build and some obvious menu glitches
git-svn-id: file:///home/notaz/opt/svn/PicoDrive/platform@665 be3aeb3a-fb24-0410-a615-afba39da0efa
This commit is contained in:
		
							parent
							
								
									7fd581f40b
								
							
						
					
					
						commit
						5a31ef0777
					
				
					 5 changed files with 27 additions and 15 deletions
				
			
		|  | @ -176,7 +176,7 @@ static void menu_draw_selection(int x, int y, int w) | ||||||
| 	for (h = me_mfont_h + 1; h > 0; h--) | 	for (h = me_mfont_h + 1; h > 0; h--) | ||||||
| 	{ | 	{ | ||||||
| 		dst = dest; | 		dst = dest; | ||||||
| 		for (i = w; i > 0; i--) | 		for (i = w - 14; i > 0; i--) | ||||||
| 			*dst++ = menu_sel_color; | 			*dst++ = menu_sel_color; | ||||||
| 		dest += g_screen_width; | 		dest += g_screen_width; | ||||||
| 	} | 	} | ||||||
|  | @ -472,7 +472,7 @@ static void me_loop(menu_entry *menu, int *menu_sel) | ||||||
| 		return; | 		return; | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	while (!menu[sel].enabled && sel < menu_sel_max) | 	while ((!menu[sel].enabled || !menu[sel].selectable) && sel < menu_sel_max) | ||||||
| 		sel++; | 		sel++; | ||||||
| 
 | 
 | ||||||
| 	/* make sure action buttons are not pressed on entering menu */ | 	/* make sure action buttons are not pressed on entering menu */ | ||||||
|  | @ -604,16 +604,16 @@ void menu_romload_prepare(const char *rom_name) | ||||||
| { | { | ||||||
| 	const char *p = rom_name + strlen(rom_name); | 	const char *p = rom_name + strlen(rom_name); | ||||||
| 
 | 
 | ||||||
| 	plat_video_menu_begin(); |  | ||||||
| 
 |  | ||||||
| 	while (p > rom_name && *p != '/') | 	while (p > rom_name && *p != '/') | ||||||
| 		p--; | 		p--; | ||||||
| 
 | 
 | ||||||
| 	/* fill both buffers, callbacks won't update in full */ | 	/* fill both buffers, callbacks won't update in full */ | ||||||
|  | 	plat_video_menu_begin(); | ||||||
| 	smalltext_out16(1, 1, "Loading", 0xffff); | 	smalltext_out16(1, 1, "Loading", 0xffff); | ||||||
| 	smalltext_out16(1, 10, p, 0xffff); | 	smalltext_out16(1, 10, p, 0xffff); | ||||||
| 	plat_video_menu_end(); | 	plat_video_menu_end(); | ||||||
| 
 | 
 | ||||||
|  | 	plat_video_menu_begin(); | ||||||
| 	smalltext_out16(1, 1, "Loading", 0xffff); | 	smalltext_out16(1, 1, "Loading", 0xffff); | ||||||
| 	smalltext_out16(1, 10, p, 0xffff); | 	smalltext_out16(1, 10, p, 0xffff); | ||||||
| 	plat_video_menu_end(); | 	plat_video_menu_end(); | ||||||
|  | @ -977,7 +977,7 @@ static void draw_savestate_menu(int menu_sel, int is_loading) | ||||||
| 	text_out16(x, y, is_loading ? "Load state" : "Save state"); | 	text_out16(x, y, is_loading ? "Load state" : "Save state"); | ||||||
| 	y += 3 * me_mfont_h; | 	y += 3 * me_mfont_h; | ||||||
| 
 | 
 | ||||||
| 	menu_draw_selection(x - me_mfont_w * 2, y + menu_sel * me_mfont_h, 13 * me_mfont_w + 4); | 	menu_draw_selection(x - me_mfont_w * 2, y + menu_sel * me_mfont_h, (13 + 2) * me_mfont_w + 4); | ||||||
| 
 | 
 | ||||||
| 	/* draw all 10 slots */ | 	/* draw all 10 slots */ | ||||||
| 	for (i = 0; i < 10; i++, y += me_mfont_h) | 	for (i = 0; i < 10; i++, y += me_mfont_h) | ||||||
|  | @ -1091,10 +1091,11 @@ static int count_bound_keys(int dev_id, int action_mask, int player_idx) | ||||||
| static void draw_key_config(const me_bind_action *opts, int opt_cnt, int player_idx, | static void draw_key_config(const me_bind_action *opts, int opt_cnt, int player_idx, | ||||||
| 		int sel, int dev_id, int dev_count, int is_bind) | 		int sel, int dev_id, int dev_count, int is_bind) | ||||||
| { | { | ||||||
| 	int x, y, w, i; |  | ||||||
| 	const char *dev_name; | 	const char *dev_name; | ||||||
|  | 	int x, y, w, i; | ||||||
| 
 | 
 | ||||||
| 	x = g_screen_width / 2 - 20 * me_mfont_w / 2; | 	w = ((player_idx >= 0) ? 20 : 30) * me_mfont_w; | ||||||
|  | 	x = g_screen_width / 2 - w / 2; | ||||||
| 	y = (g_screen_height - 4 * me_mfont_h) / 2 - (2 + opt_cnt) * me_mfont_h / 2; | 	y = (g_screen_height - 4 * me_mfont_h) / 2 - (2 + opt_cnt) * me_mfont_h / 2; | ||||||
| 	if (x < me_mfont_w * 2) | 	if (x < me_mfont_w * 2) | ||||||
| 		x = me_mfont_w * 2; | 		x = me_mfont_w * 2; | ||||||
|  | @ -1106,7 +1107,7 @@ static void draw_key_config(const me_bind_action *opts, int opt_cnt, int player_ | ||||||
| 		text_out16(x, y, "Emulator controls"); | 		text_out16(x, y, "Emulator controls"); | ||||||
| 
 | 
 | ||||||
| 	y += 2 * me_mfont_h; | 	y += 2 * me_mfont_h; | ||||||
| 	menu_draw_selection(x - me_mfont_w * 2, y + sel * me_mfont_h, me_mfont_w); // FIXME last arg
 | 	menu_draw_selection(x - me_mfont_w * 2, y + sel * me_mfont_h, w + 2 * me_mfont_w); | ||||||
| 
 | 
 | ||||||
| 	for (i = 0; i < opt_cnt; i++, y += me_mfont_h) | 	for (i = 0; i < opt_cnt; i++, y += me_mfont_h) | ||||||
| 		text_out16(x, y, "%s : %s", opts[i].name, | 		text_out16(x, y, "%s : %s", opts[i].name, | ||||||
|  | @ -1885,6 +1886,10 @@ static int main_menu_handler(menu_id id, int keys) | ||||||
| 
 | 
 | ||||||
| static menu_entry e_menu_main[] = | static menu_entry e_menu_main[] = | ||||||
| { | { | ||||||
|  | 	mee_label     ("PicoDrive " VERSION), | ||||||
|  | 	mee_label     (""), | ||||||
|  | 	mee_label     (""), | ||||||
|  | 	mee_label     (""), | ||||||
| 	mee_handler_id("Resume game",        MA_MAIN_RESUME_GAME, main_menu_handler), | 	mee_handler_id("Resume game",        MA_MAIN_RESUME_GAME, main_menu_handler), | ||||||
| 	mee_handler_id("Save State",         MA_MAIN_SAVE_STATE,  main_menu_handler), | 	mee_handler_id("Save State",         MA_MAIN_SAVE_STATE,  main_menu_handler), | ||||||
| 	mee_handler_id("Load State",         MA_MAIN_LOAD_STATE,  main_menu_handler), | 	mee_handler_id("Load State",         MA_MAIN_LOAD_STATE,  main_menu_handler), | ||||||
|  | @ -1911,13 +1916,15 @@ void menu_loop(void) | ||||||
| 	plat_video_menu_enter(rom_loaded); | 	plat_video_menu_enter(rom_loaded); | ||||||
| 	in_set_blocking(1); | 	in_set_blocking(1); | ||||||
| 	me_loop(e_menu_main, &sel); | 	me_loop(e_menu_main, &sel); | ||||||
| 	in_set_blocking(0); |  | ||||||
| 
 | 
 | ||||||
| 	if (rom_loaded && engineState == PGS_Menu) { | 	if (rom_loaded) { | ||||||
|  | 		if (engineState == PGS_Menu) | ||||||
|  | 			engineState = PGS_Running; | ||||||
| 		/* wait until menu, ok, back is released */ | 		/* wait until menu, ok, back is released */ | ||||||
| 		while (in_menu_wait_any(50) & (PBTN_MENU|PBTN_MOK|PBTN_MBACK)); | 		while (in_menu_wait_any(50) & (PBTN_MENU|PBTN_MOK|PBTN_MBACK)); | ||||||
| 		engineState = PGS_Running; |  | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	in_set_blocking(0); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // --------- CD tray close menu ----------
 | // --------- CD tray close menu ----------
 | ||||||
|  | @ -1967,7 +1974,6 @@ int menu_loop_tray(void) | ||||||
| 
 | 
 | ||||||
| 	in_set_blocking(1); | 	in_set_blocking(1); | ||||||
| 	me_loop(e_menu_tray, &sel); | 	me_loop(e_menu_tray, &sel); | ||||||
| 	in_set_blocking(0); |  | ||||||
| 
 | 
 | ||||||
| 	if (engineState != PGS_RestartRun) { | 	if (engineState != PGS_RestartRun) { | ||||||
| 		engineState = PGS_RestartRun; | 		engineState = PGS_RestartRun; | ||||||
|  | @ -1975,6 +1981,7 @@ int menu_loop_tray(void) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	while (in_menu_wait_any(50) & (PBTN_MENU|PBTN_MOK|PBTN_MBACK)); | 	while (in_menu_wait_any(50) & (PBTN_MENU|PBTN_MOK|PBTN_MBACK)); | ||||||
|  | 	in_set_blocking(0); | ||||||
| 
 | 
 | ||||||
| 	return ret; | 	return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -54,14 +54,15 @@ LD = $(CROSS)ld | ||||||
| OBJCOPY = $(CROSS)objcopy | OBJCOPY = $(CROSS)objcopy | ||||||
| 
 | 
 | ||||||
| # frontend
 | # frontend
 | ||||||
| OBJS += main.o gp2x.o emu.o in_gp2x.o squidgehack.o cpuctrl.o | # TODO: clean cpuctrl
 | ||||||
|  | OBJS += main.o gp2x.o emu.o in_gp2x.o plat.o squidgehack.o cpuctrl.o | ||||||
| # 940 core control
 | # 940 core control
 | ||||||
| OBJS += 940ctl.o | OBJS += 940ctl.o | ||||||
| 
 | 
 | ||||||
| # common
 | # common
 | ||||||
| OBJS += platform/common/emu.o platform/common/menu.o platform/common/fonts.o platform/common/config.o \
 | OBJS += platform/common/emu.o platform/common/menu.o platform/common/fonts.o platform/common/config.o \
 | ||||||
| 	platform/common/arm_utils.o platform/common/arm_linux.o platform/common/readpng.o \
 | 	platform/common/arm_utils.o platform/common/arm_linux.o platform/common/readpng.o \
 | ||||||
| 	platform/common/mp3_helix.o platform/common/input.o platform/linux/usbjoy.o \
 | 	platform/common/mp3_helix.o platform/common/input.o \
 | ||||||
| 	platform/linux/sndout_oss.o platform/linux/plat.o | 	platform/linux/sndout_oss.o platform/linux/plat.o | ||||||
| 
 | 
 | ||||||
| # Pico
 | # Pico
 | ||||||
|  |  | ||||||
|  | @ -35,6 +35,7 @@ | ||||||
| #include "../linux/sndout_oss.h" | #include "../linux/sndout_oss.h" | ||||||
| #include "../common/arm_utils.h" | #include "../common/arm_utils.h" | ||||||
| #include "../common/arm_linux.h" | #include "../common/arm_linux.h" | ||||||
|  | #include "../common/emu.h" | ||||||
| 
 | 
 | ||||||
| volatile unsigned short *gp2x_memregs; | volatile unsigned short *gp2x_memregs; | ||||||
| //static
 | //static
 | ||||||
|  | @ -196,7 +197,6 @@ void gp2x_pd_clone_buffer2(void) | ||||||
| 
 | 
 | ||||||
| unsigned long gp2x_joystick_read(int unused) | unsigned long gp2x_joystick_read(int unused) | ||||||
| { | { | ||||||
| 	int i; |  | ||||||
|   	unsigned long value=(gp2x_memregs[0x1198>>1] & 0x00FF); // GPIO M
 |   	unsigned long value=(gp2x_memregs[0x1198>>1] & 0x00FF); // GPIO M
 | ||||||
|   	if(value==0xFD) value=0xFA; |   	if(value==0xFD) value=0xFA; | ||||||
|   	if(value==0xF7) value=0xEB; |   	if(value==0xF7) value=0xEB; | ||||||
|  |  | ||||||
|  | @ -3,6 +3,8 @@ | ||||||
| #ifndef PORT_CONFIG_H | #ifndef PORT_CONFIG_H | ||||||
| #define PORT_CONFIG_H | #define PORT_CONFIG_H | ||||||
| 
 | 
 | ||||||
|  | #include "version.h" | ||||||
|  | 
 | ||||||
| #define CASE_SENSITIVE_FS 1 // CS filesystem
 | #define CASE_SENSITIVE_FS 1 // CS filesystem
 | ||||||
| #define DONT_OPEN_MANY_FILES 0 | #define DONT_OPEN_MANY_FILES 0 | ||||||
| #define REDUCE_IO_CALLS 0 | #define REDUCE_IO_CALLS 0 | ||||||
|  |  | ||||||
|  | @ -3,6 +3,8 @@ | ||||||
| #ifndef PORT_CONFIG_H | #ifndef PORT_CONFIG_H | ||||||
| #define PORT_CONFIG_H | #define PORT_CONFIG_H | ||||||
| 
 | 
 | ||||||
|  | #include "../gp2x/version.h" /* FIXME */ | ||||||
|  | 
 | ||||||
| #define CASE_SENSITIVE_FS 1 // CS filesystem
 | #define CASE_SENSITIVE_FS 1 // CS filesystem
 | ||||||
| #define DONT_OPEN_MANY_FILES 0 | #define DONT_OPEN_MANY_FILES 0 | ||||||
| #define REDUCE_IO_CALLS 0 | #define REDUCE_IO_CALLS 0 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 notaz
						notaz