RetroArch/360/menu.cpp

317 lines
8.8 KiB
C++
Raw Normal View History

/* SSNES - A Super Nintendo Entertainment System (SNES) Emulator frontend for libsnes.
* Copyright (C) 2010-2012 - Hans-Kristian Arntzen
* Copyright (C) 2011-2012 - Daniel De Matteis
*
* Some code herein may be based on code found in BSNES.
*
* SSNES 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 Found-
* ation, either version 3 of the License, or (at your option) any later version.
*
* SSNES 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 SSNES.
* If not, see <http://www.gnu.org/licenses/>.
*/
2012-01-23 22:22:54 +01:00
#include <stdint.h>
#include <crtdefs.h>
#include <tchar.h>
#include <xtl.h>
#include "file_browser.h"
2012-02-04 20:33:51 +01:00
#include "../console/rom_ext.h"
2012-01-22 21:47:34 +01:00
#include "xdk360_video.h"
#include "menu.h"
#include "shared.h"
#include "../general.h"
CSSNES app;
2012-02-04 20:33:51 +01:00
filebrowser_t browser;
char strbuffer[1024];
2012-01-22 21:47:34 +01:00
/* Register custom classes */
HRESULT CSSNES::RegisterXuiClasses (void)
{
CSSNESMain::Register();
2012-02-04 20:33:51 +01:00
CSSNESFileBrowser::Register();
CSSNESSettings::Register();
return S_OK;
}
/* Unregister custom classes */
HRESULT CSSNES::UnregisterXuiClasses (void)
{
CSSNESMain::Unregister();
2012-02-04 20:33:51 +01:00
CSSNESFileBrowser::Unregister();
CSSNESSettings::Unregister();
return S_OK;
}
static void filebrowser_fetch_directory_entries(const char *path, CXuiList * romlist,
CXuiTextElement * rompath_title)
2012-02-04 20:33:51 +01:00
{
filebrowser_parse_directory(&browser, path, ssnes_console_get_rom_ext());
2012-02-12 15:23:35 +01:00
unsigned long dwNum_rompath = MultiByteToWideChar(CP_ACP, 0, path, -1, NULL, 0);
wchar_t * rompath_name = new wchar_t[dwNum_rompath];
MultiByteToWideChar(CP_ACP, 0, path, -1, rompath_name, dwNum_rompath);
rompath_title->SetText(rompath_name);
romlist->DeleteItems(0, romlist->GetItemCount());
romlist->InsertItems(0, browser.file_count);
for(unsigned i = 0; i < browser.file_count; i++)
{
2012-02-12 15:23:35 +01:00
unsigned long dwNum = MultiByteToWideChar(CP_ACP, 0, browser.cur[i].d_name, -1, NULL, 0);
wchar_t * entry_name = new wchar_t[dwNum];
MultiByteToWideChar(CP_ACP, 0, browser.cur[i].d_name, -1, entry_name, dwNum);
romlist->SetText(i, entry_name);
delete []entry_name;
}
}
HRESULT CSSNESFileBrowser::OnInit(XUIMessageInit * pInitData, BOOL& bHandled)
{
GetChildById(L"XuiRomList", &m_romlist);
GetChildById(L"XuiBackButton1", &m_back);
GetChildById(L"XuiTxtRomPath", &m_rompathtitle);
filebrowser_fetch_directory_entries(g_console.default_rom_startup_dir, &m_romlist, &m_rompathtitle);
2012-02-04 20:33:51 +01:00
return S_OK;
}
static void set_filter_element(int index, CXuiControl * obj)
{
switch(index)
{
case FALSE:
obj->SetText(L"Point filtering");
break;
case TRUE:
obj->SetText(L"Linear interpolation");
break;
}
}
HRESULT CSSNESSettings::OnInit(XUIMessageInit * pInitData, BOOL& bHandled)
{
GetChildById(L"XuiBtnRewind", &m_rewind);
GetChildById(L"XuiCheckbox1", &m_rewind_cb);
GetChildById(L"XuiBackButton1", &m_back);
GetChildById(L"XuiBtnHWFilter", &m_hw_filter);
set_filter_element(g_settings.video.smooth, &m_hw_filter);
m_rewind_cb.SetCheck(g_settings.rewind_enable);
return S_OK;
}
HRESULT CSSNESMain::OnInit(XUIMessageInit * pInitData, BOOL& bHandled)
2012-01-24 00:02:02 +01:00
{
GetChildById(L"XuiBtnRomBrowser", &m_filebrowser);
GetChildById(L"XuiBtnSettings", &m_settings);
2012-01-24 00:02:02 +01:00
GetChildById(L"XuiBtnQuit", &m_quit);
GetChildById(L"XuiTxtTitle", &m_title);
GetChildById(L"XuiTxtCoreText", &m_core);
const char * core_text = snes_library_id();
char package_version[32];
sprintf(package_version, "SSNES %s", PACKAGE_VERSION);
2012-02-12 15:23:35 +01:00
unsigned long dwNum = MultiByteToWideChar(CP_ACP, 0, core_text, -1, NULL, 0);
unsigned long dwNum_package = MultiByteToWideChar(CP_ACP, 0, package_version, -1, NULL, 0);
wchar_t * core_text_utf = new wchar_t[dwNum];
wchar_t * package_version_utf = new wchar_t[dwNum_package];
MultiByteToWideChar(CP_ACP, 0, core_text, -1, core_text_utf, dwNum);
MultiByteToWideChar(CP_ACP, 0, package_version, -1, package_version_utf, dwNum_package);
m_core.SetText(core_text_utf);
m_title.SetText(package_version_utf);
delete []core_text_utf;
delete []package_version_utf;
2012-01-24 00:02:02 +01:00
return S_OK;
}
2012-02-04 20:33:51 +01:00
HRESULT CSSNESFileBrowser::OnNotifyPress( HXUIOBJ hObjPressed, BOOL& bHandled )
{
if(hObjPressed == m_romlist)
{
int index = m_romlist.GetCurSel();
if(browser.cur[index].d_type != FILE_ATTRIBUTE_DIRECTORY)
{
memset(strbuffer, 0, sizeof(strbuffer));
wcstombs(strbuffer, (const wchar_t *)m_romlist.GetText(index), sizeof(strbuffer));
memset(g_console.rom_path, 0, sizeof(g_console.rom_path));
sprintf(g_console.rom_path, "%s%s", g_console.default_rom_startup_dir, strbuffer);
g_console.menu_enable = false;
g_console.mode_switch = MODE_EMULATION;
g_console.initialize_ssnes_enable = 1;
}
else if(browser.cur[index].d_type == FILE_ATTRIBUTE_DIRECTORY)
{
memset(strbuffer, 0, sizeof(strbuffer));
wcstombs(strbuffer, (const wchar_t *)m_romlist.GetText(index), sizeof(strbuffer));
char strbuf[512];
snprintf(strbuf, sizeof(strbuf), "%s%s", g_console.default_rom_startup_dir, strbuffer);
filebrowser_fetch_directory_entries(strbuf, &m_romlist, &m_rompathtitle);
}
}
else if(hObjPressed == m_back)
{
2012-02-08 16:10:01 +01:00
NavigateBack(app.hMainScene);
}
2012-02-04 20:33:51 +01:00
bHandled = TRUE;
return S_OK;
}
HRESULT CSSNESSettings::OnNotifyPress( HXUIOBJ hObjPressed, int & bHandled )
{
if ( hObjPressed == m_rewind)
{
g_settings.rewind_enable = !g_settings.rewind_enable;
m_rewind_cb.SetCheck(g_settings.rewind_enable);
}
else if ( hObjPressed == m_hw_filter)
{
g_settings.video.smooth = !g_settings.video.smooth;
}
else if ( hObjPressed == m_back )
{
2012-02-08 16:10:01 +01:00
HRESULT hr = XuiSceneNavigateBack(app.hSSNESSettings, app.hMainScene, XUSER_INDEX_FOCUS);
if (FAILED(hr))
{
SSNES_ERR("Failed to load scene.\n");
}
2012-02-08 16:10:01 +01:00
NavigateBack(app.hMainScene);
}
set_filter_element(g_settings.video.smooth, &m_hw_filter);
bHandled = TRUE;
return S_OK;
}
HRESULT CSSNESMain::OnNotifyPress( HXUIOBJ hObjPressed, int & bHandled )
2012-01-24 00:02:02 +01:00
{
HRESULT hr;
2012-01-24 00:02:02 +01:00
if ( hObjPressed == m_filebrowser )
{
2012-02-08 16:10:01 +01:00
hr = XuiSceneCreate(L"file://game:/media/", L"ssnes_filebrowser.xur", NULL, &app.hFileBrowser);
if (FAILED(hr))
{
SSNES_ERR("Failed to load scene.\n");
}
2012-02-08 16:10:01 +01:00
NavigateForward(app.hFileBrowser);
2012-01-24 00:02:02 +01:00
}
else if ( hObjPressed == m_settings )
{
2012-02-08 16:10:01 +01:00
hr = XuiSceneCreate(L"file://game:/media/", L"ssnes_settings.xur", NULL, &app.hSSNESSettings);
if (FAILED(hr))
SSNES_ERR("Failed to load scene.\n");
2012-02-08 16:10:01 +01:00
NavigateForward(app.hSSNESSettings);
}
2012-01-24 00:32:44 +01:00
else if ( hObjPressed == m_quit )
{
2012-02-02 21:50:11 +01:00
g_console.menu_enable = false;
g_console.mode_switch = MODE_EXIT;
g_console.initialize_ssnes_enable = false;
2012-01-24 00:32:44 +01:00
}
2012-01-24 00:02:02 +01:00
bHandled = TRUE;
return S_OK;
}
2012-01-22 21:47:34 +01:00
int menu_init (void)
{
HRESULT hr;
xdk360_video_t *vid = (xdk360_video_t*)g_d3d;
hr = app.InitShared(vid->xdk360_render_device, &vid->d3dpp, XuiPNGTextureLoader);
2012-01-22 21:47:34 +01:00
if (FAILED(hr))
{
SSNES_ERR("Failed initializing XUI application.\n");
2012-01-22 21:47:34 +01:00
return 1;
}
/* Register font */
2012-01-23 21:49:21 +01:00
hr = app.RegisterDefaultTypeface(L"Arial Unicode MS", L"file://game:/media/ssnes.ttf" );
2012-01-22 21:47:34 +01:00
if (FAILED(hr))
{
SSNES_ERR("Failed to register default typeface.\n");
2012-01-22 21:47:34 +01:00
return 1;
}
2012-01-23 21:30:59 +01:00
hr = app.LoadSkin( L"file://game:/media/ssnes_scene_skin.xur");
if (FAILED(hr))
{
SSNES_ERR("Failed to load skin.\n");
return 1;
}
2012-02-08 16:10:01 +01:00
hr = XuiSceneCreate(L"file://game:/media/", L"ssnes_main.xur", NULL, &app.hMainScene);
if (FAILED(hr))
{
SSNES_ERR("Failed to create scene 'ssnes_main.xur'.\n");
return 1;
}
2012-02-08 16:10:01 +01:00
XuiSceneNavigateFirst(app.GetRootObj(), app.hMainScene, XUSER_INDEX_FOCUS);
2012-01-22 21:47:34 +01:00
return 0;
}
void menu_loop(void)
{
2012-02-02 21:50:11 +01:00
g_console.menu_enable = true;
2012-01-23 22:22:54 +01:00
HRESULT hr;
xdk360_video_t *vid = (xdk360_video_t*)g_d3d;
if(g_console.ingame_menu_enable)
video_xdk360.set_swap_block_state(NULL, true);
do
{
g_frame_count++;
if(g_console.ingame_menu_enable)
ssnes_render_cached_frame();
else
vid->xdk360_render_device->Clear(0, NULL,
D3DCLEAR_TARGET | D3DCLEAR_STENCIL | D3DCLEAR_ZBUFFER,
D3DCOLOR_ARGB(255, 32, 32, 64), 1.0, 0);
XINPUT_STATE state;
XInputGetState(0, &state);
g_console.menu_enable = !((state.Gamepad.wButtons & XINPUT_GAMEPAD_LEFT_THUMB)
&& (state.Gamepad.wButtons & XINPUT_GAMEPAD_RIGHT_THUMB) && (g_console.emulator_initialized)
&& IS_TIMER_EXPIRED());
g_console.mode_switch = g_console.menu_enable ? MODE_MENU : MODE_EMULATION;
if(g_console.mode_switch == MODE_EMULATION)
{
SET_TIMER_EXPIRATION(30);
}
app.RunFrame(); /* Update XUI */
hr = app.Render(); /* Render XUI */
hr = XuiTimersRun(); /* Update XUI timers */
/* Present the frame */
2012-01-23 22:22:54 +01:00
vid->xdk360_render_device->Present(NULL, NULL, NULL, NULL);
2012-02-02 21:50:11 +01:00
}while(g_console.menu_enable);
if(g_console.ingame_menu_enable)
video_xdk360.set_swap_block_state(NULL, false);
g_console.ingame_menu_enable = false;
2012-01-24 00:02:02 +01:00
}