mirror of
https://github.com/ekeeke/Genesis-Plus-GX.git
synced 2025-01-27 18:35:29 +01:00
1217 lines
32 KiB
C
1217 lines
32 KiB
C
/****************************************************************************
|
|
* menu.c
|
|
*
|
|
* Genesis Plus GX menu
|
|
*
|
|
* code by Softdev (March 2006), Eke-Eke (2007,2008)
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*
|
|
***************************************************************************/
|
|
|
|
#include "shared.h"
|
|
#include "dvd.h"
|
|
#include "font.h"
|
|
#include "file_dvd.h"
|
|
#include "file_fat.h"
|
|
#include "filesel.h"
|
|
|
|
#ifdef HW_RVL
|
|
#include <wiiuse/wpad.h>
|
|
#include <di/di.h>
|
|
#endif
|
|
|
|
/***************************************************************************
|
|
* drawmenu
|
|
*
|
|
* As it says, simply draws the menu with a highlight on the currently
|
|
* selected item :)
|
|
***************************************************************************/
|
|
char menutitle[60] = { "" };
|
|
int menu = 0;
|
|
|
|
void drawmenu (char items[][25], int maxitems, int selected)
|
|
{
|
|
int i;
|
|
int ypos;
|
|
|
|
ypos = (310 - (fheight * maxitems)) >> 1;
|
|
ypos += 130;
|
|
|
|
ClearScreen ();
|
|
WriteCentre (134, menutitle);
|
|
|
|
for (i = 0; i < maxitems; i++)
|
|
{
|
|
if (i == selected) WriteCentre_HL (i * fheight + ypos, (char *) items[i]);
|
|
else WriteCentre (i * fheight + ypos, (char *) items[i]);
|
|
}
|
|
|
|
SetScreen ();
|
|
}
|
|
|
|
/****************************************************************************
|
|
* domenu
|
|
*
|
|
* Returns index into menu array when A is pressed, -1 for B
|
|
****************************************************************************/
|
|
int domenu (char items[][25], int maxitems, u8 fastmove)
|
|
{
|
|
int redraw = 1;
|
|
int quit = 0;
|
|
short p;
|
|
int ret = 0;
|
|
|
|
while (quit == 0)
|
|
{
|
|
if (redraw)
|
|
{
|
|
drawmenu (&items[0], maxitems, menu);
|
|
redraw = 0;
|
|
}
|
|
|
|
p = ogc_input__getMenuButtons();
|
|
|
|
if (p & PAD_BUTTON_UP)
|
|
{
|
|
redraw = 1;
|
|
menu--;
|
|
if (menu < 0) menu = maxitems - 1;
|
|
}
|
|
else if (p & PAD_BUTTON_DOWN)
|
|
{
|
|
redraw = 1;
|
|
menu++;
|
|
if (menu == maxitems) menu = 0;
|
|
}
|
|
|
|
if (p & PAD_BUTTON_A)
|
|
{
|
|
quit = 1;
|
|
ret = menu;
|
|
}
|
|
else if (p & PAD_BUTTON_B)
|
|
{
|
|
quit = 1;
|
|
ret = -1;
|
|
}
|
|
|
|
if (fastmove)
|
|
{
|
|
if (p & PAD_BUTTON_RIGHT)
|
|
{
|
|
quit = 1;
|
|
ret = menu;
|
|
}
|
|
else if (p & PAD_BUTTON_LEFT)
|
|
{
|
|
quit = 1;
|
|
ret = 0 - 2 - menu;
|
|
}
|
|
}
|
|
}
|
|
|
|
return ret;
|
|
}
|
|
|
|
/****************************************************************************
|
|
* Sound Option menu
|
|
*
|
|
****************************************************************************/
|
|
extern struct ym2612__ YM2612;
|
|
void soundmenu ()
|
|
{
|
|
int ret;
|
|
int quit = 0;
|
|
int prevmenu = menu;
|
|
int count = 6;
|
|
char items[6][25];
|
|
|
|
strcpy (menutitle, "Press B to return");
|
|
|
|
menu = 0;
|
|
while (quit == 0)
|
|
{
|
|
sprintf (items[0], "PSG Volume: %1.2f", config.psg_preamp);
|
|
sprintf (items[1], "FM Volume: %1.2f", config.fm_preamp);
|
|
sprintf (items[2], "Volume Boost: %dX", config.boost);
|
|
sprintf (items[3], "LowPass Filter: %s", config.filter ? " ON":"OFF");
|
|
if (config.hq_fm == 0) sprintf (items[4], "HQ YM2612: OFF");
|
|
else if ((config.hq_fm == 1) || config.fm_core) sprintf (items[4], "HQ YM2612: LINEAR");
|
|
else sprintf (items[4], "HQ YM2612: SINC");
|
|
sprintf (items[5], "FM core: %s", config.fm_core ? "GENS" : "MAME");
|
|
|
|
ret = domenu (&items[0], count, 1);
|
|
switch (ret)
|
|
{
|
|
case 0:
|
|
case -2:
|
|
if (ret<0) config.psg_preamp -= 0.01;
|
|
else config.psg_preamp += 0.01;
|
|
if (config.psg_preamp < 0.0) config.psg_preamp = 5.0;
|
|
if (config.psg_preamp > 5.0) config.psg_preamp = 0.0;
|
|
break;
|
|
|
|
case 1:
|
|
case -3:
|
|
if (ret<0) config.fm_preamp -= 0.01;
|
|
else config.fm_preamp += 0.01;
|
|
if (config.fm_preamp < 0.0) config.fm_preamp = 5.0;
|
|
if (config.fm_preamp > 5.0) config.fm_preamp = 0.0;
|
|
break;
|
|
|
|
case 2:
|
|
config.boost ++;
|
|
if (config.boost > 4) config.boost = 0;
|
|
break;
|
|
|
|
case 3:
|
|
config.filter ^= 1;
|
|
break;
|
|
|
|
case 4:
|
|
config.hq_fm ++;
|
|
if ((config.hq_fm>2)||(config.fm_core && (config.hq_fm>1))) config.hq_fm = 0;
|
|
if (genromsize)
|
|
{
|
|
audio_init(48000);
|
|
fm_restore();
|
|
}
|
|
break;
|
|
|
|
case 5:
|
|
config.fm_core ^= 1;
|
|
config.psg_preamp = config.fm_core ? 2.5 : 1.5;
|
|
config.fm_preamp = 1.0;
|
|
if (genromsize)
|
|
{
|
|
if (!config.fm_core) memcpy(fm_reg,YM2612.REG,sizeof(fm_reg));
|
|
audio_init(48000);
|
|
fm_restore();
|
|
}
|
|
break;
|
|
|
|
case -1:
|
|
quit = 1;
|
|
break;
|
|
}
|
|
}
|
|
menu = prevmenu;
|
|
}
|
|
|
|
/****************************************************************************
|
|
* Misc Option menu
|
|
*
|
|
****************************************************************************/
|
|
void miscmenu ()
|
|
{
|
|
int ret;
|
|
int quit = 0;
|
|
int prevmenu = menu;
|
|
int count = 6;
|
|
char items[6][25];
|
|
strcpy (menutitle, "Press B to return");
|
|
menu = 0;
|
|
|
|
while (quit == 0)
|
|
{
|
|
if (config.region_detect == 0) sprintf (items[0], "Region: AUTO");
|
|
else if (config.region_detect == 1) sprintf (items[0], "Region: USA");
|
|
else if (config.region_detect == 2) sprintf (items[0], "Region: EUR");
|
|
else if (config.region_detect == 3) sprintf (items[0], "Region: JAP");
|
|
sprintf (items[1], "Force DTACK: %s", config.force_dtack ? "Y" : "N");
|
|
if (config.bios_enabled & 1) sprintf (items[2], "Use BIOS: ON");
|
|
else sprintf (items[2], "Use BIOS: OFF");
|
|
sprintf (items[3], "SVP Cycles: %d", SVP_cycles);
|
|
if (config.sram_auto == 0) sprintf (items[4], "Auto SRAM: FAT");
|
|
else if (config.sram_auto == 1) sprintf (items[4], "Auto SRAM: MCARD A");
|
|
else if (config.sram_auto == 2) sprintf (items[4], "Auto SRAM: MCARD B");
|
|
else sprintf (items[4], "Auto SRAM: OFF");
|
|
if (config.freeze_auto == 0) sprintf (items[5], "Auto FREEZE: FAT");
|
|
else if (config.freeze_auto == 1) sprintf (items[5], "Auto FREEZE: MCARD A");
|
|
else if (config.freeze_auto == 2) sprintf (items[5], "Auto FREEZE: MCARD B");
|
|
else sprintf (items[5], "Auto FREEZE: OFF");
|
|
|
|
ret = domenu (&items[0], count, 1);
|
|
switch (ret)
|
|
{
|
|
case 0: /*** Region Force ***/
|
|
config.region_detect = (config.region_detect + 1) % 4;
|
|
if (genromsize)
|
|
{
|
|
/* force region & cpu mode */
|
|
set_region();
|
|
|
|
/* reinitialize timings */
|
|
system_init ();
|
|
audio_init(48000);
|
|
fm_restore();
|
|
|
|
/* reinitialize HVC tables */
|
|
vctab = (vdp_pal) ? ((reg[1] & 8) ? vc_pal_240 : vc_pal_224) : vc_ntsc_224;
|
|
hctab = (reg[12] & 1) ? cycle2hc40 : cycle2hc32;
|
|
|
|
/* reinitialize overscan area */
|
|
bitmap.viewport.x = config.overscan ? ((reg[12] & 1) ? 16 : 12) : 0;
|
|
bitmap.viewport.y = config.overscan ? (((reg[1] & 8) ? 0 : 8) + (vdp_pal ? 24 : 0)) : 0;
|
|
}
|
|
break;
|
|
|
|
case 1: /*** force DTACK ***/
|
|
config.force_dtack ^= 1;
|
|
break;
|
|
|
|
case 2: /*** BIOS support ***/
|
|
config.bios_enabled ^= 1;
|
|
if (genromsize || (config.bios_enabled == 3))
|
|
{
|
|
system_init ();
|
|
audio_init(48000);
|
|
system_reset ();
|
|
}
|
|
break;
|
|
|
|
case 3: /*** SVP emulation ***/
|
|
case -5:
|
|
if (ret<0) SVP_cycles = SVP_cycles ? (SVP_cycles-1) : 1500;
|
|
else SVP_cycles++;
|
|
if (SVP_cycles > 1500) SVP_cycles = 0;
|
|
break;
|
|
|
|
case 4: /*** SRAM autoload/autosave ***/
|
|
config.sram_auto ++;
|
|
if (config.sram_auto > 2) config.sram_auto = -1;
|
|
break;
|
|
|
|
case 5: /*** FreezeState autoload/autosave ***/
|
|
config.freeze_auto ++;
|
|
if (config.freeze_auto > 2) config.freeze_auto = -1;
|
|
break;
|
|
|
|
case -1:
|
|
quit = 1;
|
|
break;
|
|
}
|
|
}
|
|
|
|
menu = prevmenu;
|
|
}
|
|
|
|
/****************************************************************************
|
|
* Display Option menu
|
|
*
|
|
****************************************************************************/
|
|
uint8 old_overscan = 1;
|
|
|
|
void dispmenu ()
|
|
{
|
|
int ret;
|
|
int quit = 0;
|
|
int prevmenu = menu;
|
|
int count = config.aspect ? 8 : 10;
|
|
char items[10][25];
|
|
|
|
strcpy (menutitle, "Press B to return");
|
|
menu = 0;
|
|
|
|
while (quit == 0)
|
|
{
|
|
sprintf (items[0], "Aspect: %s", config.aspect ? "ORIGINAL" : "STRETCHED");
|
|
if (config.render == 1) sprintf (items[1], "Render: INTERLACED");
|
|
else if (config.render == 2) sprintf (items[1], "Render: PROGRESSIVE");
|
|
else sprintf (items[1], "Render: ORIGINAL");
|
|
if (config.tv_mode == 0) sprintf (items[2], "TV Mode: 60HZ");
|
|
else if (config.tv_mode == 1) sprintf (items[2], "TV Mode: 50HZ");
|
|
else sprintf (items[2], "TV Mode: 50/60HZ");
|
|
sprintf (items[3], "Bilinear Filter: %s", config.bilinear ? " ON" : "OFF");
|
|
if (config.ntsc == 1) sprintf (items[4], "NTSC Filter: COMPOSITE");
|
|
else if (config.ntsc == 2) sprintf (items[4], "NTSC Filter: S-VIDEO");
|
|
else if (config.ntsc == 3) sprintf (items[4], "NTSC Filter: RGB");
|
|
else sprintf (items[4], "NTSC Filter: OFF");
|
|
sprintf (items[5], "Borders: %s", config.overscan ? " ON" : "OFF");
|
|
sprintf (items[6], "Center X: %s%02d", config.xshift < 0 ? "-":"+", abs(config.xshift));
|
|
sprintf (items[7], "Center Y: %s%02d", config.yshift < 0 ? "-":"+", abs(config.yshift));
|
|
sprintf (items[8], "Scale X: %s%02d", config.xscale < 0 ? "-":"+", abs(config.xscale));
|
|
sprintf (items[9], "Scale Y: %s%02d", config.yscale < 0 ? "-":"+", abs(config.yscale));
|
|
|
|
ret = domenu (&items[0], count, 1);
|
|
|
|
switch (ret)
|
|
{
|
|
case 0: /*** config.aspect ratio ***/
|
|
config.aspect ^= 1;
|
|
count = config.aspect ? 8 : 10;
|
|
break;
|
|
|
|
case 1: /*** rendering ***/
|
|
config.render = (config.render + 1) % 3;
|
|
if (config.render == 2)
|
|
{
|
|
if (VIDEO_HaveComponentCable())
|
|
{
|
|
/* progressive mode (60hz only) */
|
|
config.tv_mode = 0;
|
|
}
|
|
else
|
|
{
|
|
/* do nothing if component cable is not detected */
|
|
config.render = 0;
|
|
}
|
|
}
|
|
break;
|
|
|
|
case 2: /*** tv mode ***/
|
|
if (config.render == 2) break; /* 60hz progressive only */
|
|
config.tv_mode = (config.tv_mode + 1) % 3;
|
|
break;
|
|
|
|
case 3: /*** bilinear filtering ***/
|
|
config.bilinear ^= 1;
|
|
break;
|
|
|
|
case 4: /*** NTSC filter ***/
|
|
config.ntsc ++;
|
|
if (config.ntsc > 3) config.ntsc = 0;
|
|
break;
|
|
|
|
case 5: /*** overscan emulation ***/
|
|
config.overscan ^= 1;
|
|
bitmap.viewport.x = config.overscan ? ((reg[12] & 1) ? 16 : 12) : 0;
|
|
bitmap.viewport.y = config.overscan ? (((reg[1] & 8) ? 0 : 8) + (vdp_pal ? 24 : 0)) : 0;
|
|
break;
|
|
|
|
case 6: /*** Center X ***/
|
|
case -8:
|
|
if (ret<0) config.xshift --;
|
|
else config.xshift ++;
|
|
break;
|
|
|
|
case 7: /*** Center Y ***/
|
|
case -9:
|
|
if (ret<0) config.yshift --;
|
|
else config.yshift ++;
|
|
break;
|
|
|
|
case 8: /*** Scale X ***/
|
|
case -10:
|
|
if (config.aspect) break;
|
|
if (ret<0) config.xscale --;
|
|
else config.xscale ++;
|
|
break;
|
|
|
|
case 9: /*** Scale Y ***/
|
|
case -11:
|
|
if (config.aspect) break;
|
|
if (ret<0) config.yscale --;
|
|
else config.yscale ++;
|
|
break;
|
|
|
|
case -1:
|
|
quit = 1;
|
|
break;
|
|
}
|
|
}
|
|
menu = prevmenu;
|
|
}
|
|
|
|
/****************************************************************************
|
|
* ConfigureJoypads
|
|
****************************************************************************/
|
|
extern int old_system[2];
|
|
void ConfigureJoypads ()
|
|
{
|
|
int ret, max_players;
|
|
int i = 0;
|
|
int quit = 0;
|
|
int prevmenu = menu;
|
|
char padmenu[8][25];
|
|
|
|
int player = 0;
|
|
#ifdef HW_RVL
|
|
u32 exp;
|
|
#endif
|
|
|
|
strcpy (menutitle, "Press B to return");
|
|
|
|
menu = 0;
|
|
while (quit == 0)
|
|
{
|
|
/* update max players */
|
|
max_players = 0;
|
|
if (input.system[0] == SYSTEM_GAMEPAD)
|
|
{
|
|
sprintf (padmenu[0], "Port 1: GAMEPAD");
|
|
max_players ++;
|
|
}
|
|
else if (input.system[0] == SYSTEM_MOUSE)
|
|
{
|
|
sprintf (padmenu[0], "Port 1: MOUSE");
|
|
max_players ++;
|
|
}
|
|
else if (input.system[0] == SYSTEM_WAYPLAY)
|
|
{
|
|
sprintf (padmenu[0], "Port 1: 4-WAYPLAY");
|
|
max_players += 4;
|
|
}
|
|
else if (input.system[0] == SYSTEM_TEAMPLAYER)
|
|
{
|
|
sprintf (padmenu[0], "Port 1: TEAMPLAYER");
|
|
max_players += 4;
|
|
}
|
|
else
|
|
sprintf (padmenu[0], "Port 1: NONE");
|
|
|
|
if (input.system[1] == SYSTEM_GAMEPAD)
|
|
{
|
|
sprintf (padmenu[1], "Port 2: GAMEPAD");
|
|
max_players ++;
|
|
}
|
|
else if (input.system[1] == SYSTEM_MOUSE)
|
|
{
|
|
sprintf (padmenu[1], "Port 2: MOUSE");
|
|
max_players ++;
|
|
}
|
|
else if (input.system[1] == SYSTEM_WAYPLAY)
|
|
{
|
|
sprintf (padmenu[1], "Port 2: 4-WAYPLAY");
|
|
}
|
|
else if (input.system[1] == SYSTEM_TEAMPLAYER)
|
|
{
|
|
sprintf (padmenu[1], "Port 2: TEAMPLAYER");
|
|
max_players += 4;
|
|
}
|
|
else if (input.system[1] == SYSTEM_MENACER)
|
|
{
|
|
sprintf (padmenu[1], "Port 2: MENACER");
|
|
max_players += 1;
|
|
}
|
|
else if (input.system[1] == SYSTEM_JUSTIFIER)
|
|
{
|
|
sprintf (padmenu[1], "Port 2: JUSTIFIERS");
|
|
max_players += 2;
|
|
}
|
|
else
|
|
sprintf (padmenu[1], "Port 2: NONE");
|
|
|
|
/* JCART special case */
|
|
if (j_cart) max_players +=2;
|
|
|
|
/* reset current player nr */
|
|
if (player >= max_players)
|
|
{
|
|
/* remove duplicate assigned inputs */
|
|
if ((0!=player) && (config.input[0].device == config.input[player].device) && (config.input[0].port == config.input[player].port))
|
|
{
|
|
config.input[0].device = -1;
|
|
config.input[0].port = i%4;
|
|
}
|
|
player = 0;
|
|
}
|
|
|
|
sprintf (padmenu[2], "Gun Cursor: %s", config.gun_cursor ? " ON":"OFF");
|
|
sprintf (padmenu[3], "Invert Mouse: %s", config.invert_mouse ? " ON":"OFF");
|
|
sprintf (padmenu[4], "Set Player: %d%s", player + 1, (j_cart && (player > 1)) ? "-JCART" : "");
|
|
|
|
if (config.input[player].device == 0)
|
|
sprintf (padmenu[5], "Device: GAMECUBE %d", config.input[player].port + 1);
|
|
#ifdef HW_RVL
|
|
else if (config.input[player].device == 1)
|
|
sprintf (padmenu[5], "Device: WIIMOTE %d", config.input[player].port + 1);
|
|
else if (config.input[player].device == 2)
|
|
sprintf (padmenu[5], "Device: NUNCHUK %d", config.input[player].port + 1);
|
|
else if (config.input[player].device == 3)
|
|
sprintf (padmenu[5], "Device: CLASSIC %d", config.input[player].port + 1);
|
|
#endif
|
|
else
|
|
sprintf (padmenu[5], "Device: NONE");
|
|
|
|
/* when using wiimote, force to 3Buttons pad */
|
|
if (config.input[player].device == 1) input.padtype[player] = DEVICE_3BUTTON;
|
|
sprintf (padmenu[6], "%s", (input.padtype[player] == DEVICE_3BUTTON) ? "Type: 3BUTTONS":"Type: 6BUTTONS");
|
|
|
|
sprintf (padmenu[7], "Configure Input");
|
|
|
|
ret = domenu (&padmenu[0], 8,0);
|
|
|
|
switch (ret)
|
|
{
|
|
case 0:
|
|
if (j_cart)
|
|
{
|
|
WaitPrompt("JCART detected !");
|
|
break;
|
|
}
|
|
input.system[0] ++;
|
|
if (input.system[0] == SYSTEM_MENACER) input.system[0] ++;
|
|
if (input.system[0] == SYSTEM_JUSTIFIER) input.system[0] ++;
|
|
if ((input.system[0] == SYSTEM_MOUSE) && (input.system[1] == SYSTEM_MOUSE)) input.system[0] ++;
|
|
if (input.system[0] == SYSTEM_WAYPLAY) input.system[1] = SYSTEM_WAYPLAY;
|
|
if (input.system[0] > SYSTEM_WAYPLAY)
|
|
{
|
|
input.system[0] = NO_SYSTEM;
|
|
input.system[1] = SYSTEM_GAMEPAD;
|
|
}
|
|
io_reset();
|
|
old_system[0] = input.system[0];
|
|
old_system[1] = input.system[1];
|
|
break;
|
|
|
|
case 1:
|
|
if (j_cart)
|
|
{
|
|
WaitPrompt("JCART detected !");
|
|
break;
|
|
}
|
|
input.system[1] ++;
|
|
if ((input.system[0] == SYSTEM_MOUSE) && (input.system[1] == SYSTEM_MOUSE)) input.system[1] ++;
|
|
if (input.system[1] == SYSTEM_WAYPLAY) input.system[0] = SYSTEM_WAYPLAY;
|
|
if (input.system[1] > SYSTEM_WAYPLAY)
|
|
{
|
|
input.system[1] = NO_SYSTEM;
|
|
input.system[0] = SYSTEM_GAMEPAD;
|
|
}
|
|
io_reset();
|
|
old_system[0] = input.system[0];
|
|
old_system[1] = input.system[1];
|
|
break;
|
|
|
|
case 2:
|
|
config.gun_cursor ^= 1;
|
|
break;
|
|
|
|
case 3:
|
|
config.invert_mouse ^= 1;
|
|
break;
|
|
|
|
case 4:
|
|
/* remove duplicate assigned inputs */
|
|
for (i=0; i<8; i++)
|
|
{
|
|
if ((i!=player) && (config.input[i].device == config.input[player].device) && (config.input[i].port == config.input[player].port))
|
|
{
|
|
config.input[i].device = -1;
|
|
config.input[i].port = i%4;
|
|
}
|
|
}
|
|
player = (player + 1) % max_players;
|
|
break;
|
|
|
|
case 5:
|
|
#ifdef HW_RVL
|
|
if (config.input[player].device > 0)
|
|
{
|
|
config.input[player].port ++;
|
|
}
|
|
else
|
|
{
|
|
config.input[player].device ++;
|
|
if (config.input[player].device == 1) config.input[player].port = 0;
|
|
}
|
|
|
|
if (config.input[player].device == 1)
|
|
{
|
|
exp = 4;
|
|
if (config.input[player].port<4)
|
|
{
|
|
WPAD_Probe(config.input[player].port,&exp);
|
|
if (exp == WPAD_EXP_NUNCHUK) exp = 4;
|
|
}
|
|
|
|
while ((config.input[player].port<4) && (exp == 4))
|
|
{
|
|
config.input[player].port ++;
|
|
if (config.input[player].port<4)
|
|
{
|
|
exp = 4;
|
|
WPAD_Probe(config.input[player].port,&exp);
|
|
if (exp == WPAD_EXP_NUNCHUK) exp = 4;
|
|
}
|
|
}
|
|
|
|
if (config.input[player].port >= 4)
|
|
{
|
|
config.input[player].port = 0;
|
|
config.input[player].device = 2;
|
|
}
|
|
}
|
|
|
|
if (config.input[player].device == 2)
|
|
{
|
|
exp = 4;
|
|
if (config.input[player].port<4)
|
|
{
|
|
WPAD_Probe(config.input[player].port,&exp);
|
|
}
|
|
|
|
while ((config.input[player].port<4) && (exp != WPAD_EXP_NUNCHUK))
|
|
{
|
|
config.input[player].port ++;
|
|
if (config.input[player].port<4)
|
|
{
|
|
exp = 4;
|
|
WPAD_Probe(config.input[player].port,&exp);
|
|
}
|
|
}
|
|
|
|
if (config.input[player].port >= 4)
|
|
{
|
|
config.input[player].port = 0;
|
|
config.input[player].device = 3;
|
|
}
|
|
}
|
|
|
|
if (config.input[player].device == 3)
|
|
{
|
|
exp = 4;
|
|
if (config.input[player].port<4)
|
|
{
|
|
WPAD_Probe(config.input[player].port,&exp);
|
|
}
|
|
|
|
while ((config.input[player].port<4) && (exp != WPAD_EXP_CLASSIC))
|
|
{
|
|
config.input[player].port ++;
|
|
if (config.input[player].port<4)
|
|
{
|
|
exp = 4;
|
|
WPAD_Probe(config.input[player].port,&exp);
|
|
}
|
|
}
|
|
|
|
if (config.input[player].port >= 4)
|
|
{
|
|
config.input[player].port = player % 4;
|
|
config.input[player].device = 0;
|
|
}
|
|
}
|
|
#else
|
|
config.input[player].device = 0;
|
|
#endif
|
|
break;
|
|
|
|
case 6:
|
|
if (config.input[player].device == 1) break;
|
|
input.padtype[player] ^= 1;
|
|
io_reset();
|
|
break;
|
|
|
|
case 7:
|
|
if (config.input[player].device < 0) break;
|
|
ogc_input__config(config.input[player].port, config.input[player].device, input.padtype[player]);
|
|
break;
|
|
|
|
case -1:
|
|
/* remove duplicate assigned inputs */
|
|
for (i=0; i<8; i++)
|
|
{
|
|
if ((i!=player) && (config.input[i].device == config.input[player].device) && (config.input[i].port == config.input[player].port))
|
|
{
|
|
config.input[i].device = -1;
|
|
config.input[i].port = i%4;
|
|
}
|
|
}
|
|
quit = 1;
|
|
break;
|
|
}
|
|
}
|
|
|
|
menu = prevmenu;
|
|
}
|
|
|
|
/****************************************************************************
|
|
* Main Option menu
|
|
*
|
|
****************************************************************************/
|
|
void optionmenu ()
|
|
{
|
|
int ret;
|
|
int quit = 0;
|
|
int prevmenu = menu;
|
|
int count = 5;
|
|
char items[5][25] =
|
|
{
|
|
"Video Options",
|
|
"Sound Options",
|
|
"System Options",
|
|
"Controls Options",
|
|
"Game Genie Codes"
|
|
};
|
|
|
|
menu = 0;
|
|
while (quit == 0)
|
|
{
|
|
strcpy (menutitle, "Press B to return");
|
|
ret = domenu (&items[0], count, 0);
|
|
switch (ret)
|
|
{
|
|
case 0:
|
|
dispmenu();
|
|
break;
|
|
case 1:
|
|
soundmenu();
|
|
break;
|
|
case 2:
|
|
miscmenu();
|
|
break;
|
|
case 3:
|
|
ConfigureJoypads();
|
|
break;
|
|
case 4:
|
|
GetGGEntries();
|
|
break;
|
|
case -1:
|
|
quit = 1;
|
|
break;
|
|
}
|
|
}
|
|
|
|
config_save();
|
|
menu = prevmenu;
|
|
}
|
|
|
|
/****************************************************************************
|
|
* Generic Load/Save menu
|
|
*
|
|
****************************************************************************/
|
|
static u8 device = 0;
|
|
|
|
int loadsavemenu (int which)
|
|
{
|
|
int prevmenu = menu;
|
|
int quit = 0;
|
|
int ret;
|
|
int count = 3;
|
|
char items[3][25];
|
|
|
|
strcpy (menutitle, "Press B to return");
|
|
|
|
menu = 2;
|
|
|
|
if (which == 1)
|
|
{
|
|
sprintf(items[1], "Save State");
|
|
sprintf(items[2], "Load State");
|
|
}
|
|
else
|
|
{
|
|
sprintf(items[1], "Save SRAM");
|
|
sprintf(items[2], "Load SRAM");
|
|
}
|
|
|
|
while (quit == 0)
|
|
{
|
|
if (device == 0) sprintf(items[0], "Device: FAT");
|
|
else if (device == 1) sprintf(items[0], "Device: MCARD A");
|
|
else if (device == 2) sprintf(items[0], "Device: MCARD B");
|
|
|
|
ret = domenu (&items[0], count, 0);
|
|
switch (ret)
|
|
{
|
|
case -1:
|
|
quit = 1;
|
|
break;
|
|
|
|
case 0:
|
|
device = (device + 1)%3;
|
|
break;
|
|
|
|
case 1:
|
|
case 2:
|
|
if (which == 1) quit = ManageState(ret-1,device);
|
|
else if (which == 0) quit = ManageSRAM(ret-1,device);
|
|
if (quit) return 1;
|
|
break;
|
|
}
|
|
}
|
|
|
|
menu = prevmenu;
|
|
return 0;
|
|
}
|
|
|
|
|
|
/****************************************************************************
|
|
* File Manager menu
|
|
*
|
|
****************************************************************************/
|
|
int filemenu ()
|
|
{
|
|
int prevmenu = menu;
|
|
int ret;
|
|
int quit = 0;
|
|
int count = 2;
|
|
char items[2][25] = {
|
|
{"SRAM Manager"},
|
|
{"STATE Manager"}
|
|
};
|
|
|
|
menu = 0;
|
|
|
|
while (quit == 0)
|
|
{
|
|
strcpy (menutitle, "Press B to return");
|
|
ret = domenu (&items[0], count, 0);
|
|
switch (ret)
|
|
{
|
|
case -1: /*** Button B ***/
|
|
ret = 0;
|
|
quit = 1;
|
|
break;
|
|
|
|
case 0: /*** SRAM Manager ***/
|
|
case 1: /*** SaveState Manager ***/
|
|
if (loadsavemenu(ret)) return 1;
|
|
break;
|
|
}
|
|
}
|
|
|
|
menu = prevmenu;
|
|
return 0;
|
|
}
|
|
|
|
|
|
/****************************************************************************
|
|
* Load Rom menu
|
|
*
|
|
****************************************************************************/
|
|
extern char rom_filename[MAXJOLIET];
|
|
static u8 load_menu = 0;
|
|
static u8 dvd_on = 0;
|
|
|
|
int loadmenu ()
|
|
{
|
|
int prevmenu = menu;
|
|
int ret,count,size;
|
|
int quit = 0;
|
|
#ifdef HW_RVL
|
|
char item[5][25] = {
|
|
{"Load Recent"},
|
|
{"Load from SD"},
|
|
{"Load from USB"},
|
|
{"Load from DVD"},
|
|
{"Stop DVD Motor"}
|
|
};
|
|
#else
|
|
char item[4][25] = {
|
|
{"Load Recent"},
|
|
{"Load from SD"},
|
|
{"Load from DVD"},
|
|
{"Stop DVD Motor"}
|
|
};
|
|
#endif
|
|
|
|
menu = load_menu;
|
|
|
|
while (quit == 0)
|
|
{
|
|
#ifdef HW_RVL
|
|
count = 4 + dvd_on;
|
|
#else
|
|
count = 3 + dvd_on;
|
|
#endif
|
|
strcpy (menutitle, "Press B to return");
|
|
ret = domenu (&item[0], count, 0);
|
|
switch (ret)
|
|
{
|
|
/*** Button B ***/
|
|
case -1:
|
|
quit = 1;
|
|
break;
|
|
|
|
/*** Load from DVD ***/
|
|
#ifdef HW_RVL
|
|
case 3:
|
|
#else
|
|
case 2:
|
|
#endif
|
|
load_menu = menu;
|
|
size = DVD_Open(cart_rom);
|
|
if (size)
|
|
{
|
|
dvd_on = 1;
|
|
genromsize = size;
|
|
memfile_autosave();
|
|
reloadrom();
|
|
sprintf(rom_filename,"%s",filelist[selection].filename);
|
|
rom_filename[strlen(rom_filename) - 4] = 0;
|
|
memfile_autoload();
|
|
return 1;
|
|
}
|
|
break;
|
|
|
|
/*** Stop DVD Disc ***/
|
|
#ifdef HW_RVL
|
|
case 4:
|
|
#else
|
|
case 3:
|
|
#endif
|
|
dvd_motor_off();
|
|
dvd_on = 0;
|
|
menu = load_menu;
|
|
break;
|
|
|
|
/*** Load from FAT device ***/
|
|
default:
|
|
load_menu = menu;
|
|
size = FAT_Open(ret,cart_rom);
|
|
if (size)
|
|
{
|
|
memfile_autosave();
|
|
genromsize = size;
|
|
reloadrom();
|
|
sprintf(rom_filename,"%s",filelist[selection].filename);
|
|
rom_filename[strlen(rom_filename) - 4] = 0;
|
|
memfile_autoload();
|
|
return 1;
|
|
}
|
|
break;
|
|
|
|
}
|
|
}
|
|
|
|
menu = prevmenu;
|
|
return 0;
|
|
}
|
|
|
|
/***************************************************************************
|
|
* Show rom info screen
|
|
***************************************************************************/
|
|
void showrominfo ()
|
|
{
|
|
int ypos;
|
|
u8 i,j,quit,redraw,max;
|
|
char msg[128];
|
|
short p;
|
|
char pName[14][21];
|
|
|
|
quit = 0;
|
|
j = 0;
|
|
redraw = 1;
|
|
|
|
/*** Remove any still held buttons ***/
|
|
while (PAD_ButtonsHeld(0)) PAD_ScanPads();
|
|
#ifdef HW_RVL
|
|
while (WPAD_ButtonsHeld(0)) WPAD_ScanPads();
|
|
#endif
|
|
|
|
max = 14;
|
|
for (i = 0; i < 14; i++)
|
|
{
|
|
if (peripherals & (1 << i))
|
|
{
|
|
sprintf(pName[max-14],"%s", peripheralinfo[i].pName);
|
|
max ++;
|
|
}
|
|
}
|
|
|
|
while (quit == 0)
|
|
{
|
|
if (redraw)
|
|
{
|
|
ClearScreen ();
|
|
|
|
ypos = 134;
|
|
WriteCentre(ypos, "ROM Header Information");
|
|
ypos += 2*fheight;
|
|
|
|
for (i=0; i<8; i++)
|
|
{
|
|
switch (i+j)
|
|
{
|
|
case 0:
|
|
sprintf (msg, "Console type: %s", rominfo.consoletype);
|
|
break;
|
|
case 1:
|
|
sprintf (msg, "Copyright: %s", rominfo.copyright);
|
|
break;
|
|
case 2:
|
|
sprintf (msg, "Company: %s", companyinfo[getcompany ()].company);
|
|
break;
|
|
case 3:
|
|
sprintf (msg, "Game Domestic Name:");
|
|
break;
|
|
case 4:
|
|
sprintf(msg, " %s",rominfo.domestic);
|
|
break;
|
|
case 5:
|
|
sprintf (msg, "Game International Name:");
|
|
break;
|
|
case 6:
|
|
sprintf(msg, " %s",rominfo.international);
|
|
break;
|
|
case 7:
|
|
sprintf (msg, "Type - %s : %s", rominfo.ROMType, strcmp (rominfo.ROMType, "AI") ? "Game" : "Educational");
|
|
break;
|
|
case 8:
|
|
sprintf (msg, "Product - %s", rominfo.product);
|
|
break;
|
|
case 9:
|
|
sprintf (msg, "Checksum - %04x (%04x) (%s)", rominfo.checksum, realchecksum, (rominfo.checksum == realchecksum) ? "Good" : "Bad");
|
|
break;
|
|
case 10:
|
|
sprintf (msg, "ROM end: $%06X", rominfo.romend);
|
|
break;
|
|
case 11:
|
|
if (svp) sprintf (msg, "SVP Chip detected");
|
|
else if (sram.custom) sprintf (msg, "EEPROM(%dK) - $%06X", ((eeprom.type.size_mask+1)* 8) /1024, (unsigned int)sram.start);
|
|
else if (sram.detected) sprintf (msg, "SRAM Start - $%06X", sram.start);
|
|
else sprintf (msg, "External RAM undetected");
|
|
|
|
break;
|
|
case 12:
|
|
if (sram.custom) sprintf (msg, "EEPROM(%dK) - $%06X", ((eeprom.type.size_mask+1)* 8) /1024, (unsigned int)sram.end);
|
|
else if (sram.detected) sprintf (msg, "SRAM End - $%06X", sram.end);
|
|
else if (sram.on) sprintf (msg, "Default SRAM activated ");
|
|
else sprintf (msg, "SRAM is disactivated ");
|
|
break;
|
|
case 13:
|
|
if (region_code == REGION_USA) sprintf (msg, "Region - %s (USA)", rominfo.country);
|
|
else if (region_code == REGION_EUROPE) sprintf (msg, "Region - %s (EUR)", rominfo.country);
|
|
else if (region_code == REGION_JAPAN_NTSC) sprintf (msg, "Region - %s (JAP)", rominfo.country);
|
|
else if (region_code == REGION_JAPAN_PAL) sprintf (msg, "Region - %s (JPAL)", rominfo.country);
|
|
break;
|
|
default:
|
|
sprintf (msg, "Supports - %s", pName[i+j-14]);
|
|
break;
|
|
}
|
|
|
|
write_font (100, ypos, msg);
|
|
ypos += fheight;
|
|
}
|
|
|
|
ypos += fheight;
|
|
WriteCentre (ypos, "Press A to Continue");
|
|
SetScreen ();
|
|
}
|
|
|
|
p = ogc_input__getMenuButtons();
|
|
redraw = 0;
|
|
|
|
if ((j<(max-8)) && (p & PAD_BUTTON_DOWN)) {redraw = 1; j++;}
|
|
if ((j>0) && (p & PAD_BUTTON_UP)) {redraw = 1; j--;}
|
|
if (p & PAD_BUTTON_A) quit = 1;
|
|
if (p & PAD_BUTTON_B) quit = 1;
|
|
}
|
|
}
|
|
|
|
/****************************************************************************
|
|
* Main Menu
|
|
*
|
|
****************************************************************************/
|
|
void MainMenu (u32 fps)
|
|
{
|
|
menu = 0;
|
|
int ret;
|
|
int quit = 0;
|
|
uint32 crccheck;
|
|
|
|
int count = 8;
|
|
char items[8][25] =
|
|
{
|
|
{"Play Game"},
|
|
{"Game Infos"},
|
|
{"Hard Reset"},
|
|
{"Load New Game"},
|
|
{"File Management"},
|
|
{"Emulator Options"},
|
|
{"Return to Loader"},
|
|
{"System Reboot"}
|
|
};
|
|
|
|
/* autosave (SRAM only) */
|
|
int temp = config.freeze_auto;
|
|
config.freeze_auto = -1;
|
|
memfile_autosave();
|
|
config.freeze_auto = temp;
|
|
|
|
while (quit == 0)
|
|
{
|
|
crccheck = crc32 (0, &sram.sram[0], 0x10000);
|
|
if (genromsize && (crccheck != sram.crc)) strcpy (menutitle, "*** SRAM has been modified ***");
|
|
else if (genromsize) sprintf (menutitle, "%d FPS",fps);
|
|
|
|
ret = domenu (&items[0], count, 0);
|
|
switch (ret)
|
|
{
|
|
case -1: /*** Button B ***/
|
|
case 0: /*** Play Game ***/
|
|
if (genromsize) quit = 1;
|
|
break;
|
|
|
|
case 1: /*** ROM Information ***/
|
|
showrominfo ();
|
|
break;
|
|
|
|
case 2: /*** Emulator Reset ***/
|
|
if (genromsize || (config.bios_enabled == 3))
|
|
{
|
|
system_reset ();
|
|
quit = 1;
|
|
}
|
|
break;
|
|
|
|
case 3: /*** Load ROM Menu ***/
|
|
quit = loadmenu();
|
|
break;
|
|
|
|
case 4: /*** Memory Manager ***/
|
|
quit = filemenu ();
|
|
break;
|
|
|
|
case 5: /*** Emulator Options */
|
|
optionmenu ();
|
|
break;
|
|
|
|
case 6: /*** SD/PSO/TP Reload ***/
|
|
memfile_autosave();
|
|
system_shutdown();
|
|
audio_shutdown();
|
|
VIDEO_ClearFrameBuffer(vmode, xfb[whichfb], COLOR_BLACK);
|
|
VIDEO_Flush();
|
|
VIDEO_WaitVSync();
|
|
#ifdef HW_RVL
|
|
DI_Close();
|
|
#endif
|
|
exit(0);
|
|
break;
|
|
|
|
case 7: /*** Return to Wii System Menu ***/
|
|
memfile_autosave();
|
|
system_shutdown();
|
|
audio_shutdown();
|
|
VIDEO_ClearFrameBuffer(vmode, xfb[whichfb], COLOR_BLACK);
|
|
VIDEO_Flush();
|
|
VIDEO_WaitVSync();
|
|
#ifdef HW_RVL
|
|
DI_Close();
|
|
SYS_ResetSystem(SYS_RETURNTOMENU, 0, 0);
|
|
#else
|
|
SYS_ResetSystem(SYS_HOTRESET,0,0);
|
|
#endif
|
|
break;
|
|
}
|
|
}
|
|
|
|
/*** Remove any still held buttons ***/
|
|
while (PAD_ButtonsHeld(0)) PAD_ScanPads();
|
|
#ifdef HW_RVL
|
|
while (WPAD_ButtonsHeld(0)) WPAD_ScanPads();
|
|
#endif
|
|
|
|
#ifndef HW_RVL
|
|
/*** Stop the DVD from causing clicks while playing ***/
|
|
uselessinquiry ();
|
|
#endif
|
|
}
|