mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 07:21:14 +01:00
DolphinWX: Separate the information panel from ISOProperties
Makes the information panel self-contained. This was done first, as opposed to isolating the GameConfig panel--the first panel in the group--as this panel had code all over the place in ISOProperties, so I figured it'd be best to fix this one up first.
This commit is contained in:
parent
0705c53681
commit
20fcfd0ed8
@ -34,6 +34,8 @@ set(GUI_SRCS
|
|||||||
Debugger/RegisterWindow.cpp
|
Debugger/RegisterWindow.cpp
|
||||||
Debugger/WatchView.cpp
|
Debugger/WatchView.cpp
|
||||||
Debugger/WatchWindow.cpp
|
Debugger/WatchWindow.cpp
|
||||||
|
ISOProperties/InfoPanel.cpp
|
||||||
|
ISOProperties/ISOProperties.cpp
|
||||||
NetPlay/ChangeGameDialog.cpp
|
NetPlay/ChangeGameDialog.cpp
|
||||||
NetPlay/MD5Dialog.cpp
|
NetPlay/MD5Dialog.cpp
|
||||||
NetPlay/NetPlayLauncher.cpp
|
NetPlay/NetPlayLauncher.cpp
|
||||||
@ -58,7 +60,6 @@ set(GUI_SRCS
|
|||||||
FrameTools.cpp
|
FrameTools.cpp
|
||||||
GameListCtrl.cpp
|
GameListCtrl.cpp
|
||||||
ISOFile.cpp
|
ISOFile.cpp
|
||||||
ISOProperties.cpp
|
|
||||||
LogConfigWindow.cpp
|
LogConfigWindow.cpp
|
||||||
LogWindow.cpp
|
LogWindow.cpp
|
||||||
Main.cpp
|
Main.cpp
|
||||||
|
@ -11,7 +11,6 @@
|
|||||||
#include "Core/ActionReplay.h"
|
#include "Core/ActionReplay.h"
|
||||||
#include "DolphinWX/Cheats/CheatsWindow.h"
|
#include "DolphinWX/Cheats/CheatsWindow.h"
|
||||||
#include "DolphinWX/Cheats/CreateCodeDialog.h"
|
#include "DolphinWX/Cheats/CreateCodeDialog.h"
|
||||||
#include "DolphinWX/ISOProperties.h"
|
|
||||||
#include "DolphinWX/WxUtils.h"
|
#include "DolphinWX/WxUtils.h"
|
||||||
|
|
||||||
CreateCodeDialog::CreateCodeDialog(wxWindow* const parent, const u32 address)
|
CreateCodeDialog::CreateCodeDialog(wxWindow* const parent, const u32 address)
|
||||||
|
@ -90,6 +90,8 @@
|
|||||||
<ClCompile Include="Debugger\WatchView.cpp" />
|
<ClCompile Include="Debugger\WatchView.cpp" />
|
||||||
<ClCompile Include="Debugger\WatchWindow.cpp" />
|
<ClCompile Include="Debugger\WatchWindow.cpp" />
|
||||||
<ClCompile Include="DolphinSlider.cpp" />
|
<ClCompile Include="DolphinSlider.cpp" />
|
||||||
|
<ClCompile Include="ISOProperties\InfoPanel.cpp" />
|
||||||
|
<ClCompile Include="ISOProperties\ISOProperties.cpp" />
|
||||||
<ClCompile Include="NetPlay\ChangeGameDialog.cpp" />
|
<ClCompile Include="NetPlay\ChangeGameDialog.cpp" />
|
||||||
<ClCompile Include="NetPlay\MD5Dialog.cpp" />
|
<ClCompile Include="NetPlay\MD5Dialog.cpp" />
|
||||||
<ClCompile Include="NetPlay\NetPlayLauncher.cpp" />
|
<ClCompile Include="NetPlay\NetPlayLauncher.cpp" />
|
||||||
@ -112,7 +114,6 @@
|
|||||||
<ClCompile Include="Input\DrumsInputConfigDiag.cpp" />
|
<ClCompile Include="Input\DrumsInputConfigDiag.cpp" />
|
||||||
<ClCompile Include="Input\TurntableInputConfigDiag.cpp" />
|
<ClCompile Include="Input\TurntableInputConfigDiag.cpp" />
|
||||||
<ClCompile Include="ISOFile.cpp" />
|
<ClCompile Include="ISOFile.cpp" />
|
||||||
<ClCompile Include="ISOProperties.cpp" />
|
|
||||||
<ClCompile Include="LogConfigWindow.cpp" />
|
<ClCompile Include="LogConfigWindow.cpp" />
|
||||||
<ClCompile Include="LogWindow.cpp" />
|
<ClCompile Include="LogWindow.cpp" />
|
||||||
<ClCompile Include="Main.cpp" />
|
<ClCompile Include="Main.cpp" />
|
||||||
@ -145,6 +146,8 @@
|
|||||||
<ClInclude Include="Config\PathConfigPane.h" />
|
<ClInclude Include="Config\PathConfigPane.h" />
|
||||||
<ClInclude Include="Config\WiiConfigPane.h" />
|
<ClInclude Include="Config\WiiConfigPane.h" />
|
||||||
<ClInclude Include="DolphinSlider.h" />
|
<ClInclude Include="DolphinSlider.h" />
|
||||||
|
<ClInclude Include="ISOProperties\InfoPanel.h" />
|
||||||
|
<ClInclude Include="ISOProperties\ISOProperties.h" />
|
||||||
<ClInclude Include="NetPlay\ChangeGameDialog.h" />
|
<ClInclude Include="NetPlay\ChangeGameDialog.h" />
|
||||||
<ClInclude Include="NetPlay\MD5Dialog.h" />
|
<ClInclude Include="NetPlay\MD5Dialog.h" />
|
||||||
<ClInclude Include="NetPlay\NetPlayLauncher.h" />
|
<ClInclude Include="NetPlay\NetPlayLauncher.h" />
|
||||||
@ -190,7 +193,6 @@
|
|||||||
<ClInclude Include="Input\DrumsInputConfigDiag.h" />
|
<ClInclude Include="Input\DrumsInputConfigDiag.h" />
|
||||||
<ClInclude Include="Input\TurntableInputConfigDiag.h" />
|
<ClInclude Include="Input\TurntableInputConfigDiag.h" />
|
||||||
<ClInclude Include="ISOFile.h" />
|
<ClInclude Include="ISOFile.h" />
|
||||||
<ClInclude Include="ISOProperties.h" />
|
|
||||||
<ClInclude Include="LogConfigWindow.h" />
|
<ClInclude Include="LogConfigWindow.h" />
|
||||||
<ClInclude Include="LogWindow.h" />
|
<ClInclude Include="LogWindow.h" />
|
||||||
<ClInclude Include="Main.h" />
|
<ClInclude Include="Main.h" />
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Filter Include="GUI">
|
<Filter Include="GUI">
|
||||||
@ -31,6 +31,9 @@
|
|||||||
<Filter Include="GUI\Widgets">
|
<Filter Include="GUI\Widgets">
|
||||||
<UniqueIdentifier>{a894e2e3-e577-4b65-8572-055699f23a49}</UniqueIdentifier>
|
<UniqueIdentifier>{a894e2e3-e577-4b65-8572-055699f23a49}</UniqueIdentifier>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
<Filter Include="GUI\ISOProperties">
|
||||||
|
<UniqueIdentifier>{d72aa7f0-ed24-4fed-9d3a-38b82d1b753c}</UniqueIdentifier>
|
||||||
|
</Filter>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ClCompile Include="Main.cpp" />
|
<ClCompile Include="Main.cpp" />
|
||||||
@ -167,9 +170,6 @@
|
|||||||
<ClCompile Include="GameListCtrl.cpp">
|
<ClCompile Include="GameListCtrl.cpp">
|
||||||
<Filter>GUI</Filter>
|
<Filter>GUI</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<ClCompile Include="ISOProperties.cpp">
|
|
||||||
<Filter>GUI</Filter>
|
|
||||||
</ClCompile>
|
|
||||||
<ClCompile Include="LogConfigWindow.cpp">
|
<ClCompile Include="LogConfigWindow.cpp">
|
||||||
<Filter>GUI</Filter>
|
<Filter>GUI</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
@ -224,6 +224,12 @@
|
|||||||
<ClCompile Include="Config\AdvancedConfigPane.cpp">
|
<ClCompile Include="Config\AdvancedConfigPane.cpp">
|
||||||
<Filter>GUI\Config</Filter>
|
<Filter>GUI\Config</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="ISOProperties\InfoPanel.cpp">
|
||||||
|
<Filter>GUI\ISOProperties</Filter>
|
||||||
|
</ClCompile>
|
||||||
|
<ClCompile Include="ISOProperties\ISOProperties.cpp">
|
||||||
|
<Filter>GUI\ISOProperties</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="NetPlay\NetPlaySetupFrame.cpp">
|
<ClCompile Include="NetPlay\NetPlaySetupFrame.cpp">
|
||||||
<Filter>GUI\NetPlay</Filter>
|
<Filter>GUI\NetPlay</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
@ -377,9 +383,6 @@
|
|||||||
<ClInclude Include="Globals.h">
|
<ClInclude Include="Globals.h">
|
||||||
<Filter>GUI</Filter>
|
<Filter>GUI</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
<ClInclude Include="ISOProperties.h">
|
|
||||||
<Filter>GUI</Filter>
|
|
||||||
</ClInclude>
|
|
||||||
<ClInclude Include="LogConfigWindow.h">
|
<ClInclude Include="LogConfigWindow.h">
|
||||||
<Filter>GUI</Filter>
|
<Filter>GUI</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
@ -434,6 +437,12 @@
|
|||||||
<ClInclude Include="Config\AdvancedConfigPane.h">
|
<ClInclude Include="Config\AdvancedConfigPane.h">
|
||||||
<Filter>GUI\Config</Filter>
|
<Filter>GUI\Config</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="ISOProperties\InfoPanel.h">
|
||||||
|
<Filter>GUI\ISOProperties</Filter>
|
||||||
|
</ClInclude>
|
||||||
|
<ClInclude Include="ISOProperties\ISOProperties.h">
|
||||||
|
<Filter>GUI\ISOProperties</Filter>
|
||||||
|
</ClInclude>
|
||||||
<ClInclude Include="NetPlay\NetPlaySetupFrame.h">
|
<ClInclude Include="NetPlay\NetPlaySetupFrame.h">
|
||||||
<Filter>GUI\NetPlay</Filter>
|
<Filter>GUI\NetPlay</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
@ -58,7 +58,7 @@
|
|||||||
#include "DolphinWX/GameListCtrl.h"
|
#include "DolphinWX/GameListCtrl.h"
|
||||||
#include "DolphinWX/Globals.h"
|
#include "DolphinWX/Globals.h"
|
||||||
#include "DolphinWX/ISOFile.h"
|
#include "DolphinWX/ISOFile.h"
|
||||||
#include "DolphinWX/ISOProperties.h"
|
#include "DolphinWX/ISOProperties/ISOProperties.h"
|
||||||
#include "DolphinWX/Main.h"
|
#include "DolphinWX/Main.h"
|
||||||
#include "DolphinWX/NetPlay/NetPlayLauncher.h"
|
#include "DolphinWX/NetPlay/NetPlayLauncher.h"
|
||||||
#include "DolphinWX/WxUtils.h"
|
#include "DolphinWX/WxUtils.h"
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
// Licensed under GPLv2+
|
// Licensed under GPLv2+
|
||||||
// Refer to the license.txt file included.
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
#include "DolphinWX/ISOProperties.h"
|
#include "DolphinWX/ISOProperties/ISOProperties.h"
|
||||||
|
|
||||||
#include <array>
|
#include <array>
|
||||||
#include <cinttypes>
|
#include <cinttypes>
|
||||||
@ -10,7 +10,6 @@
|
|||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <fstream>
|
#include <fstream>
|
||||||
#include <mbedtls/md5.h>
|
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
@ -25,7 +24,6 @@
|
|||||||
#include <wx/dialog.h>
|
#include <wx/dialog.h>
|
||||||
#include <wx/dirdlg.h>
|
#include <wx/dirdlg.h>
|
||||||
#include <wx/filedlg.h>
|
#include <wx/filedlg.h>
|
||||||
#include <wx/gbsizer.h>
|
|
||||||
#include <wx/image.h>
|
#include <wx/image.h>
|
||||||
#include <wx/imaglist.h>
|
#include <wx/imaglist.h>
|
||||||
#include <wx/itemid.h>
|
#include <wx/itemid.h>
|
||||||
@ -44,16 +42,13 @@
|
|||||||
#include <wx/treebase.h>
|
#include <wx/treebase.h>
|
||||||
#include <wx/treectrl.h>
|
#include <wx/treectrl.h>
|
||||||
#include <wx/utils.h>
|
#include <wx/utils.h>
|
||||||
#include <wx/validate.h>
|
|
||||||
|
|
||||||
#include "Common/CommonPaths.h"
|
#include "Common/CommonPaths.h"
|
||||||
#include "Common/CommonTypes.h"
|
#include "Common/CommonTypes.h"
|
||||||
#include "Common/FileUtil.h"
|
#include "Common/FileUtil.h"
|
||||||
#include "Common/IniFile.h"
|
#include "Common/IniFile.h"
|
||||||
#include "Common/MD5.h"
|
|
||||||
#include "Common/StringUtil.h"
|
#include "Common/StringUtil.h"
|
||||||
#include "Common/SysConf.h"
|
#include "Common/SysConf.h"
|
||||||
#include "Core/Boot/Boot.h"
|
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/Core.h"
|
#include "Core/Core.h"
|
||||||
#include "Core/GeckoCodeConfig.h"
|
#include "Core/GeckoCodeConfig.h"
|
||||||
@ -70,6 +65,7 @@
|
|||||||
#include "DolphinWX/Frame.h"
|
#include "DolphinWX/Frame.h"
|
||||||
#include "DolphinWX/Globals.h"
|
#include "DolphinWX/Globals.h"
|
||||||
#include "DolphinWX/ISOFile.h"
|
#include "DolphinWX/ISOFile.h"
|
||||||
|
#include "DolphinWX/ISOProperties/InfoPanel.h"
|
||||||
#include "DolphinWX/Main.h"
|
#include "DolphinWX/Main.h"
|
||||||
#include "DolphinWX/PatchAddEdit.h"
|
#include "DolphinWX/PatchAddEdit.h"
|
||||||
#include "DolphinWX/WxUtils.h"
|
#include "DolphinWX/WxUtils.h"
|
||||||
@ -189,18 +185,18 @@ private:
|
|||||||
State m_state = State::Inactive;
|
State m_state = State::Inactive;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
wxDEFINE_EVENT(DOLPHIN_EVT_CHANGE_ISO_PROPERTIES_TITLE, wxCommandEvent);
|
||||||
|
|
||||||
BEGIN_EVENT_TABLE(CISOProperties, wxDialog)
|
BEGIN_EVENT_TABLE(CISOProperties, wxDialog)
|
||||||
EVT_CLOSE(CISOProperties::OnClose)
|
EVT_CLOSE(CISOProperties::OnClose)
|
||||||
EVT_BUTTON(wxID_OK, CISOProperties::OnCloseClick)
|
EVT_BUTTON(wxID_OK, CISOProperties::OnCloseClick)
|
||||||
EVT_BUTTON(ID_EDITCONFIG, CISOProperties::OnEditConfig)
|
EVT_BUTTON(ID_EDITCONFIG, CISOProperties::OnEditConfig)
|
||||||
EVT_BUTTON(ID_MD5SUMCOMPUTE, CISOProperties::OnComputeMD5Sum)
|
|
||||||
EVT_BUTTON(ID_SHOWDEFAULTCONFIG, CISOProperties::OnShowDefaultConfig)
|
EVT_BUTTON(ID_SHOWDEFAULTCONFIG, CISOProperties::OnShowDefaultConfig)
|
||||||
EVT_CHOICE(ID_EMUSTATE, CISOProperties::OnEmustateChanged)
|
EVT_CHOICE(ID_EMUSTATE, CISOProperties::OnEmustateChanged)
|
||||||
EVT_LISTBOX(ID_PATCHES_LIST, CISOProperties::PatchListSelectionChanged)
|
EVT_LISTBOX(ID_PATCHES_LIST, CISOProperties::PatchListSelectionChanged)
|
||||||
EVT_BUTTON(ID_EDITPATCH, CISOProperties::PatchButtonClicked)
|
EVT_BUTTON(ID_EDITPATCH, CISOProperties::PatchButtonClicked)
|
||||||
EVT_BUTTON(ID_ADDPATCH, CISOProperties::PatchButtonClicked)
|
EVT_BUTTON(ID_ADDPATCH, CISOProperties::PatchButtonClicked)
|
||||||
EVT_BUTTON(ID_REMOVEPATCH, CISOProperties::PatchButtonClicked)
|
EVT_BUTTON(ID_REMOVEPATCH, CISOProperties::PatchButtonClicked)
|
||||||
EVT_MENU(IDM_BNRSAVEAS, CISOProperties::OnBannerImageSave)
|
|
||||||
EVT_TREE_ITEM_RIGHT_CLICK(ID_TREECTRL, CISOProperties::OnRightClickOnTree)
|
EVT_TREE_ITEM_RIGHT_CLICK(ID_TREECTRL, CISOProperties::OnRightClickOnTree)
|
||||||
EVT_MENU(IDM_EXTRACTFILE, CISOProperties::OnExtractFile)
|
EVT_MENU(IDM_EXTRACTFILE, CISOProperties::OnExtractFile)
|
||||||
EVT_MENU(IDM_EXTRACTDIR, CISOProperties::OnExtractDir)
|
EVT_MENU(IDM_EXTRACTDIR, CISOProperties::OnExtractDir)
|
||||||
@ -208,7 +204,6 @@ EVT_MENU(IDM_EXTRACTALL, CISOProperties::OnExtractDir)
|
|||||||
EVT_MENU(IDM_EXTRACTAPPLOADER, CISOProperties::OnExtractDataFromHeader)
|
EVT_MENU(IDM_EXTRACTAPPLOADER, CISOProperties::OnExtractDataFromHeader)
|
||||||
EVT_MENU(IDM_EXTRACTDOL, CISOProperties::OnExtractDataFromHeader)
|
EVT_MENU(IDM_EXTRACTDOL, CISOProperties::OnExtractDataFromHeader)
|
||||||
EVT_MENU(IDM_CHECKINTEGRITY, CISOProperties::CheckPartitionIntegrity)
|
EVT_MENU(IDM_CHECKINTEGRITY, CISOProperties::CheckPartitionIntegrity)
|
||||||
EVT_CHOICE(ID_LANG, CISOProperties::OnChangeBannerLang)
|
|
||||||
END_EVENT_TABLE()
|
END_EVENT_TABLE()
|
||||||
|
|
||||||
CISOProperties::CISOProperties(const GameListItem& game_list_item, wxWindow* parent, wxWindowID id,
|
CISOProperties::CISOProperties(const GameListItem& game_list_item, wxWindow* parent, wxWindowID id,
|
||||||
@ -216,6 +211,8 @@ CISOProperties::CISOProperties(const GameListItem& game_list_item, wxWindow* par
|
|||||||
long style)
|
long style)
|
||||||
: wxDialog(parent, id, title, position, size, style), OpenGameListItem(game_list_item)
|
: wxDialog(parent, id, title, position, size, style), OpenGameListItem(game_list_item)
|
||||||
{
|
{
|
||||||
|
Bind(DOLPHIN_EVT_CHANGE_ISO_PROPERTIES_TITLE, &CISOProperties::OnChangeTitle, this);
|
||||||
|
|
||||||
// Load ISO data
|
// Load ISO data
|
||||||
m_open_iso = DiscIO::CreateVolumeFromFilename(OpenGameListItem.GetFileName());
|
m_open_iso = DiscIO::CreateVolumeFromFilename(OpenGameListItem.GetFileName());
|
||||||
|
|
||||||
@ -228,82 +225,8 @@ CISOProperties::CISOProperties(const GameListItem& game_list_item, wxWindow* par
|
|||||||
|
|
||||||
// Setup GUI
|
// Setup GUI
|
||||||
CreateGUIControls();
|
CreateGUIControls();
|
||||||
|
|
||||||
LoadGameConfig();
|
LoadGameConfig();
|
||||||
|
|
||||||
// Disk header and apploader
|
|
||||||
|
|
||||||
m_InternalName->SetValue(StrToWxStr(m_open_iso->GetInternalName()));
|
|
||||||
m_GameID->SetValue(StrToWxStr(m_open_iso->GetGameID()));
|
|
||||||
switch (m_open_iso->GetCountry())
|
|
||||||
{
|
|
||||||
case DiscIO::Country::COUNTRY_AUSTRALIA:
|
|
||||||
m_Country->SetValue(_("Australia"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_EUROPE:
|
|
||||||
m_Country->SetValue(_("Europe"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_FRANCE:
|
|
||||||
m_Country->SetValue(_("France"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_ITALY:
|
|
||||||
m_Country->SetValue(_("Italy"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_GERMANY:
|
|
||||||
m_Country->SetValue(_("Germany"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_NETHERLANDS:
|
|
||||||
m_Country->SetValue(_("Netherlands"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_RUSSIA:
|
|
||||||
m_Country->SetValue(_("Russia"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_SPAIN:
|
|
||||||
m_Country->SetValue(_("Spain"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_USA:
|
|
||||||
m_Country->SetValue(_("USA"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_JAPAN:
|
|
||||||
m_Country->SetValue(_("Japan"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_KOREA:
|
|
||||||
m_Country->SetValue(_("Korea"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_TAIWAN:
|
|
||||||
m_Country->SetValue(_("Taiwan"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_WORLD:
|
|
||||||
m_Country->SetValue(_("World"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Country::COUNTRY_UNKNOWN:
|
|
||||||
default:
|
|
||||||
m_Country->SetValue(_("Unknown"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxString temp = "0x" + StrToWxStr(m_open_iso->GetMakerID());
|
|
||||||
m_MakerID->SetValue(temp);
|
|
||||||
m_Revision->SetValue(StrToWxStr(std::to_string(m_open_iso->GetRevision())));
|
|
||||||
m_Date->SetValue(StrToWxStr(m_open_iso->GetApploaderDate()));
|
|
||||||
m_FST->SetValue(StrToWxStr(std::to_string(m_open_iso->GetFSTSize())));
|
|
||||||
|
|
||||||
// Here we set all the info to be shown + we set the window title
|
|
||||||
bool wii = m_open_iso->GetVolumeType() != DiscIO::Platform::GAMECUBE_DISC;
|
|
||||||
ChangeBannerDetails(SConfig::GetInstance().GetCurrentLanguage(wii));
|
|
||||||
|
|
||||||
if (OpenGameListItem.GetBannerImage().IsOk())
|
|
||||||
{
|
|
||||||
m_Banner->SetBitmap(WxUtils::ScaleImageToBitmap(OpenGameListItem.GetBannerImage(), this,
|
|
||||||
m_Banner->GetMinSize()));
|
|
||||||
m_Banner->Bind(wxEVT_RIGHT_DOWN, &CISOProperties::RightClickOnBanner, this);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
m_Banner->SetBitmap(
|
|
||||||
WxUtils::LoadScaledResourceBitmap("nobanner", this, m_Banner->GetMinSize()));
|
|
||||||
}
|
|
||||||
|
|
||||||
// Filesystem browser/dumper
|
// Filesystem browser/dumper
|
||||||
// TODO : Should we add a way to browse the wad file ?
|
// TODO : Should we add a way to browse the wad file ?
|
||||||
if (m_open_iso->GetVolumeType() != DiscIO::Platform::WII_WAD)
|
if (m_open_iso->GetVolumeType() != DiscIO::Platform::WII_WAD)
|
||||||
@ -445,8 +368,8 @@ void CISOProperties::CreateGUIControls()
|
|||||||
m_Notebook->AddPage(m_CheatPage, _("AR Codes"));
|
m_Notebook->AddPage(m_CheatPage, _("AR Codes"));
|
||||||
wxPanel* const gecko_cheat_page = new wxPanel(m_Notebook);
|
wxPanel* const gecko_cheat_page = new wxPanel(m_Notebook);
|
||||||
m_Notebook->AddPage(gecko_cheat_page, _("Gecko Codes"));
|
m_Notebook->AddPage(gecko_cheat_page, _("Gecko Codes"));
|
||||||
wxPanel* const m_Information = new wxPanel(m_Notebook, ID_INFORMATION);
|
m_Notebook->AddPage(new InfoPanel(m_Notebook, ID_INFORMATION, OpenGameListItem, m_open_iso),
|
||||||
m_Notebook->AddPage(m_Information, _("Info"));
|
_("Info"));
|
||||||
|
|
||||||
// GameConfig editing - Overrides and emulation state
|
// GameConfig editing - Overrides and emulation state
|
||||||
wxStaticText* const OverrideText = new wxStaticText(
|
wxStaticText* const OverrideText = new wxStaticText(
|
||||||
@ -629,159 +552,6 @@ void CISOProperties::CreateGUIControls()
|
|||||||
gecko_layout->Add(m_geckocode_panel, 1, wxEXPAND);
|
gecko_layout->Add(m_geckocode_panel, 1, wxEXPAND);
|
||||||
gecko_cheat_page->SetSizer(gecko_layout);
|
gecko_cheat_page->SetSizer(gecko_layout);
|
||||||
|
|
||||||
// Info Page
|
|
||||||
wxStaticText* const m_InternalNameText =
|
|
||||||
new wxStaticText(m_Information, wxID_ANY, _("Internal Name:"));
|
|
||||||
m_InternalName = new wxTextCtrl(m_Information, ID_NAME, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
wxStaticText* const m_GameIDText = new wxStaticText(m_Information, wxID_ANY, _("Game ID:"));
|
|
||||||
m_GameID = new wxTextCtrl(m_Information, ID_GAMEID, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
wxStaticText* const m_CountryText = new wxStaticText(m_Information, wxID_ANY, _("Country:"));
|
|
||||||
m_Country = new wxTextCtrl(m_Information, ID_COUNTRY, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
wxStaticText* const m_MakerIDText = new wxStaticText(m_Information, wxID_ANY, _("Maker ID:"));
|
|
||||||
m_MakerID = new wxTextCtrl(m_Information, ID_MAKERID, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
wxStaticText* const m_RevisionText = new wxStaticText(m_Information, wxID_ANY, _("Revision:"));
|
|
||||||
m_Revision = new wxTextCtrl(m_Information, ID_REVISION, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
wxStaticText* const m_DateText = new wxStaticText(m_Information, wxID_ANY, _("Apploader Date:"));
|
|
||||||
m_Date = new wxTextCtrl(m_Information, ID_DATE, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
|
||||||
wxTE_READONLY);
|
|
||||||
wxStaticText* const m_FSTText = new wxStaticText(m_Information, wxID_ANY, _("FST Size:"));
|
|
||||||
m_FST = new wxTextCtrl(m_Information, ID_FST, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
|
||||||
wxTE_READONLY);
|
|
||||||
wxStaticText* const m_MD5SumText = new wxStaticText(m_Information, wxID_ANY, _("MD5 Checksum:"));
|
|
||||||
m_MD5Sum = new wxTextCtrl(m_Information, ID_MD5SUM, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
m_MD5SumCompute = new wxButton(m_Information, ID_MD5SUMCOMPUTE, _("Compute"));
|
|
||||||
|
|
||||||
wxStaticText* const m_LangText = new wxStaticText(m_Information, wxID_ANY, _("Show Language:"));
|
|
||||||
|
|
||||||
bool wii = m_open_iso->GetVolumeType() != DiscIO::Platform::GAMECUBE_DISC;
|
|
||||||
DiscIO::Language preferred_language = SConfig::GetInstance().GetCurrentLanguage(wii);
|
|
||||||
|
|
||||||
std::vector<DiscIO::Language> languages = OpenGameListItem.GetLanguages();
|
|
||||||
int preferred_language_index = 0;
|
|
||||||
for (size_t i = 0; i < languages.size(); ++i)
|
|
||||||
{
|
|
||||||
if (languages[i] == preferred_language)
|
|
||||||
preferred_language_index = i;
|
|
||||||
|
|
||||||
switch (languages[i])
|
|
||||||
{
|
|
||||||
case DiscIO::Language::LANGUAGE_JAPANESE:
|
|
||||||
arrayStringFor_Lang.Add(_("Japanese"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_ENGLISH:
|
|
||||||
arrayStringFor_Lang.Add(_("English"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_GERMAN:
|
|
||||||
arrayStringFor_Lang.Add(_("German"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_FRENCH:
|
|
||||||
arrayStringFor_Lang.Add(_("French"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_SPANISH:
|
|
||||||
arrayStringFor_Lang.Add(_("Spanish"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_ITALIAN:
|
|
||||||
arrayStringFor_Lang.Add(_("Italian"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_DUTCH:
|
|
||||||
arrayStringFor_Lang.Add(_("Dutch"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_SIMPLIFIED_CHINESE:
|
|
||||||
arrayStringFor_Lang.Add(_("Simplified Chinese"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_TRADITIONAL_CHINESE:
|
|
||||||
arrayStringFor_Lang.Add(_("Traditional Chinese"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_KOREAN:
|
|
||||||
arrayStringFor_Lang.Add(_("Korean"));
|
|
||||||
break;
|
|
||||||
case DiscIO::Language::LANGUAGE_UNKNOWN:
|
|
||||||
default:
|
|
||||||
arrayStringFor_Lang.Add(_("Unknown"));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
m_Lang =
|
|
||||||
new wxChoice(m_Information, ID_LANG, wxDefaultPosition, wxDefaultSize, arrayStringFor_Lang);
|
|
||||||
m_Lang->SetSelection(preferred_language_index);
|
|
||||||
if (arrayStringFor_Lang.size() <= 1)
|
|
||||||
m_Lang->Disable();
|
|
||||||
|
|
||||||
wxStaticText* const m_NameText = new wxStaticText(m_Information, wxID_ANY, _("Name:"));
|
|
||||||
m_Name = new wxTextCtrl(m_Information, ID_SHORTNAME, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_READONLY);
|
|
||||||
wxStaticText* const m_MakerText = new wxStaticText(m_Information, wxID_ANY, _("Maker:"));
|
|
||||||
m_Maker = new wxTextCtrl(m_Information, ID_MAKER, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
|
||||||
wxTE_READONLY);
|
|
||||||
wxStaticText* const m_CommentText = new wxStaticText(m_Information, wxID_ANY, _("Description:"));
|
|
||||||
m_Comment = new wxTextCtrl(m_Information, ID_COMMENT, wxEmptyString, wxDefaultPosition,
|
|
||||||
wxDefaultSize, wxTE_MULTILINE | wxTE_READONLY);
|
|
||||||
wxStaticText* const m_BannerText = new wxStaticText(m_Information, wxID_ANY, _("Banner:"));
|
|
||||||
m_Banner = new wxStaticBitmap(m_Information, ID_BANNER, wxNullBitmap, wxDefaultPosition,
|
|
||||||
FromDIP(wxSize(96, 32)));
|
|
||||||
|
|
||||||
// ISO Details
|
|
||||||
wxGridBagSizer* const sISODetails = new wxGridBagSizer(space10, space10);
|
|
||||||
sISODetails->Add(m_InternalNameText, wxGBPosition(0, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_InternalName, wxGBPosition(0, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_GameIDText, wxGBPosition(1, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_GameID, wxGBPosition(1, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_CountryText, wxGBPosition(2, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_Country, wxGBPosition(2, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_MakerIDText, wxGBPosition(3, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_MakerID, wxGBPosition(3, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_RevisionText, wxGBPosition(4, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_Revision, wxGBPosition(4, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_DateText, wxGBPosition(5, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_Date, wxGBPosition(5, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_FSTText, wxGBPosition(6, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_FST, wxGBPosition(6, 1), wxGBSpan(1, 2), wxEXPAND);
|
|
||||||
sISODetails->Add(m_MD5SumText, wxGBPosition(7, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sISODetails->Add(m_MD5Sum, wxGBPosition(7, 1), wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
sISODetails->Add(m_MD5SumCompute, wxGBPosition(7, 2), wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
|
|
||||||
sISODetails->AddGrowableCol(1);
|
|
||||||
wxStaticBoxSizer* const sbISODetails =
|
|
||||||
new wxStaticBoxSizer(wxVERTICAL, m_Information, _("ISO Details"));
|
|
||||||
sbISODetails->AddSpacer(space5);
|
|
||||||
sbISODetails->Add(sISODetails, 0, wxEXPAND | wxLEFT | wxRIGHT, space5);
|
|
||||||
sbISODetails->AddSpacer(space5);
|
|
||||||
|
|
||||||
// Banner Details
|
|
||||||
wxGridBagSizer* const sBannerDetails = new wxGridBagSizer(space10, space10);
|
|
||||||
sBannerDetails->Add(m_LangText, wxGBPosition(0, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
// Comboboxes cannot be safely stretched vertically on Windows.
|
|
||||||
sBannerDetails->Add(WxUtils::GiveMinSize(m_Lang, wxDefaultSize), wxGBPosition(0, 1),
|
|
||||||
wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
sBannerDetails->Add(m_NameText, wxGBPosition(1, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sBannerDetails->Add(m_Name, wxGBPosition(1, 1), wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
sBannerDetails->Add(m_MakerText, wxGBPosition(2, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
|
||||||
sBannerDetails->Add(m_Maker, wxGBPosition(2, 1), wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
sBannerDetails->Add(m_CommentText, wxGBPosition(3, 0), wxGBSpan(1, 1));
|
|
||||||
sBannerDetails->Add(m_Comment, wxGBPosition(3, 1), wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
sBannerDetails->Add(m_BannerText, wxGBPosition(4, 0), wxGBSpan(1, 1));
|
|
||||||
sBannerDetails->Add(m_Banner, wxGBPosition(4, 1), wxGBSpan(1, 1), wxEXPAND);
|
|
||||||
sBannerDetails->AddGrowableCol(1);
|
|
||||||
wxStaticBoxSizer* const sbBannerDetails =
|
|
||||||
new wxStaticBoxSizer(wxVERTICAL, m_Information, _("Banner Details"));
|
|
||||||
sbBannerDetails->AddSpacer(space5);
|
|
||||||
sbBannerDetails->Add(sBannerDetails, 0, wxEXPAND | wxLEFT | wxRIGHT, space5);
|
|
||||||
sbBannerDetails->AddSpacer(space5);
|
|
||||||
|
|
||||||
wxBoxSizer* const sInfoPage = new wxBoxSizer(wxVERTICAL);
|
|
||||||
sInfoPage->AddSpacer(space5);
|
|
||||||
sInfoPage->Add(sbISODetails, 0, wxEXPAND | wxLEFT | wxRIGHT, space5);
|
|
||||||
sInfoPage->AddSpacer(space5);
|
|
||||||
sInfoPage->Add(sbBannerDetails, 0, wxEXPAND | wxLEFT | wxRIGHT, space5);
|
|
||||||
sInfoPage->AddSpacer(space5);
|
|
||||||
m_Information->SetSizer(sInfoPage);
|
|
||||||
|
|
||||||
if (m_open_iso->GetVolumeType() != DiscIO::Platform::WII_WAD)
|
if (m_open_iso->GetVolumeType() != DiscIO::Platform::WII_WAD)
|
||||||
{
|
{
|
||||||
wxPanel* const filesystem_panel = new wxPanel(m_Notebook, ID_FILESYSTEM);
|
wxPanel* const filesystem_panel = new wxPanel(m_Notebook, ID_FILESYSTEM);
|
||||||
@ -856,29 +626,6 @@ void CISOProperties::OnCloseClick(wxCommandEvent& WXUNUSED(event))
|
|||||||
Close();
|
Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CISOProperties::RightClickOnBanner(wxMouseEvent& event)
|
|
||||||
{
|
|
||||||
wxMenu popupMenu;
|
|
||||||
popupMenu.Append(IDM_BNRSAVEAS, _("Save as..."));
|
|
||||||
PopupMenu(&popupMenu);
|
|
||||||
|
|
||||||
event.Skip();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CISOProperties::OnBannerImageSave(wxCommandEvent& WXUNUSED(event))
|
|
||||||
{
|
|
||||||
wxString dirHome;
|
|
||||||
|
|
||||||
wxFileDialog dialog(this, _("Save as..."), wxGetHomeDir(&dirHome),
|
|
||||||
wxString::Format("%s.png", m_GameID->GetValue().c_str()), wxALL_FILES_PATTERN,
|
|
||||||
wxFD_SAVE | wxFD_OVERWRITE_PROMPT);
|
|
||||||
if (dialog.ShowModal() == wxID_OK)
|
|
||||||
{
|
|
||||||
OpenGameListItem.GetBannerImage().SaveFile(dialog.GetPath());
|
|
||||||
}
|
|
||||||
Raise();
|
|
||||||
}
|
|
||||||
|
|
||||||
void CISOProperties::OnRightClickOnTree(wxTreeEvent& event)
|
void CISOProperties::OnRightClickOnTree(wxTreeEvent& event)
|
||||||
{
|
{
|
||||||
m_Treectrl->SelectItem(event.GetItem());
|
m_Treectrl->SelectItem(event.GetItem());
|
||||||
@ -1448,15 +1195,9 @@ void CISOProperties::OnCheatCodeToggled(wxCommandEvent&)
|
|||||||
m_cheats_disabled_gecko->UpdateState();
|
m_cheats_disabled_gecko->UpdateState();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CISOProperties::OnComputeMD5Sum(wxCommandEvent& WXUNUSED(event))
|
void CISOProperties::OnChangeTitle(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
wxProgressDialog progressDialog(_("Computing MD5 checksum"), _("Working..."), 100, this,
|
SetTitle(event.GetString());
|
||||||
wxPD_APP_MODAL | wxPD_CAN_ABORT | wxPD_ELAPSED_TIME |
|
|
||||||
wxPD_ESTIMATED_TIME | wxPD_REMAINING_TIME | wxPD_SMOOTH);
|
|
||||||
|
|
||||||
m_MD5Sum->SetValue(MD5::MD5Sum(OpenGameListItem.GetFileName(), [&progressDialog](int progress) {
|
|
||||||
return progressDialog.Update(progress);
|
|
||||||
}));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Opens all pre-defined INIs for the game. If there are multiple ones,
|
// Opens all pre-defined INIs for the game. If there are multiple ones,
|
||||||
@ -1571,30 +1312,3 @@ void CISOProperties::PatchButtonClicked(wxCommandEvent& event)
|
|||||||
EditPatch->Disable();
|
EditPatch->Disable();
|
||||||
RemovePatch->Disable();
|
RemovePatch->Disable();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CISOProperties::OnChangeBannerLang(wxCommandEvent& event)
|
|
||||||
{
|
|
||||||
ChangeBannerDetails(OpenGameListItem.GetLanguages()[event.GetSelection()]);
|
|
||||||
}
|
|
||||||
|
|
||||||
void CISOProperties::ChangeBannerDetails(DiscIO::Language language)
|
|
||||||
{
|
|
||||||
wxString const name = StrToWxStr(OpenGameListItem.GetName(language));
|
|
||||||
wxString const comment = StrToWxStr(OpenGameListItem.GetDescription(language));
|
|
||||||
wxString const maker = StrToWxStr(OpenGameListItem.GetCompany());
|
|
||||||
|
|
||||||
// Updates the information shown in the window
|
|
||||||
m_Name->SetValue(name);
|
|
||||||
m_Comment->SetValue(comment);
|
|
||||||
m_Maker->SetValue(maker); // dev too
|
|
||||||
|
|
||||||
std::string path, filename, extension;
|
|
||||||
SplitPath(OpenGameListItem.GetFileName(), &path, &filename, &extension);
|
|
||||||
// Real disk drives don't have filenames on Windows
|
|
||||||
if (filename.empty() && extension.empty())
|
|
||||||
filename = path + ' ';
|
|
||||||
// Also sets the window's title
|
|
||||||
SetTitle(StrToWxStr(StringFromFormat("%s%s: %s - ", filename.c_str(), extension.c_str(),
|
|
||||||
OpenGameListItem.GetGameID().c_str())) +
|
|
||||||
name);
|
|
||||||
}
|
|
@ -62,6 +62,8 @@ struct PHackData
|
|||||||
std::string PHZFar;
|
std::string PHZFar;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
wxDECLARE_EVENT(DOLPHIN_EVT_CHANGE_ISO_PROPERTIES_TITLE, wxCommandEvent);
|
||||||
|
|
||||||
class CISOProperties : public wxDialog
|
class CISOProperties : public wxDialog
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -102,22 +104,6 @@ private:
|
|||||||
wxButton* EditPatch;
|
wxButton* EditPatch;
|
||||||
wxButton* RemovePatch;
|
wxButton* RemovePatch;
|
||||||
|
|
||||||
wxTextCtrl* m_InternalName;
|
|
||||||
wxTextCtrl* m_GameID;
|
|
||||||
wxTextCtrl* m_Country;
|
|
||||||
wxTextCtrl* m_MakerID;
|
|
||||||
wxTextCtrl* m_Revision;
|
|
||||||
wxTextCtrl* m_Date;
|
|
||||||
wxTextCtrl* m_FST;
|
|
||||||
wxTextCtrl* m_MD5Sum;
|
|
||||||
wxButton* m_MD5SumCompute;
|
|
||||||
wxArrayString arrayStringFor_Lang;
|
|
||||||
wxChoice* m_Lang;
|
|
||||||
wxTextCtrl* m_Name;
|
|
||||||
wxTextCtrl* m_Maker;
|
|
||||||
wxTextCtrl* m_Comment;
|
|
||||||
wxStaticBitmap* m_Banner;
|
|
||||||
|
|
||||||
wxTreeCtrl* m_Treectrl;
|
wxTreeCtrl* m_Treectrl;
|
||||||
wxTreeItemId RootId;
|
wxTreeItemId RootId;
|
||||||
|
|
||||||
@ -162,29 +148,12 @@ private:
|
|||||||
ID_CONVERGENCE,
|
ID_CONVERGENCE,
|
||||||
ID_MONODEPTH,
|
ID_MONODEPTH,
|
||||||
|
|
||||||
ID_NAME,
|
|
||||||
ID_GAMEID,
|
|
||||||
ID_COUNTRY,
|
|
||||||
ID_MAKERID,
|
|
||||||
ID_REVISION,
|
|
||||||
ID_DATE,
|
|
||||||
ID_FST,
|
|
||||||
ID_MD5SUM,
|
|
||||||
ID_MD5SUMCOMPUTE,
|
|
||||||
ID_VERSION,
|
|
||||||
ID_LANG,
|
|
||||||
ID_SHORTNAME,
|
|
||||||
ID_LONGNAME,
|
|
||||||
ID_MAKER,
|
|
||||||
ID_COMMENT,
|
|
||||||
ID_BANNER,
|
|
||||||
IDM_EXTRACTDIR,
|
IDM_EXTRACTDIR,
|
||||||
IDM_EXTRACTALL,
|
IDM_EXTRACTALL,
|
||||||
IDM_EXTRACTFILE,
|
IDM_EXTRACTFILE,
|
||||||
IDM_EXTRACTAPPLOADER,
|
IDM_EXTRACTAPPLOADER,
|
||||||
IDM_EXTRACTDOL,
|
IDM_EXTRACTDOL,
|
||||||
IDM_CHECKINTEGRITY,
|
IDM_CHECKINTEGRITY,
|
||||||
IDM_BNRSAVEAS
|
|
||||||
};
|
};
|
||||||
|
|
||||||
void LaunchExternalEditor(const std::string& filename, bool wait_until_closed);
|
void LaunchExternalEditor(const std::string& filename, bool wait_until_closed);
|
||||||
@ -193,25 +162,20 @@ private:
|
|||||||
void OnClose(wxCloseEvent& event);
|
void OnClose(wxCloseEvent& event);
|
||||||
void OnCloseClick(wxCommandEvent& event);
|
void OnCloseClick(wxCommandEvent& event);
|
||||||
void OnEditConfig(wxCommandEvent& event);
|
void OnEditConfig(wxCommandEvent& event);
|
||||||
void OnComputeMD5Sum(wxCommandEvent& event);
|
|
||||||
void OnShowDefaultConfig(wxCommandEvent& event);
|
void OnShowDefaultConfig(wxCommandEvent& event);
|
||||||
void PatchListSelectionChanged(wxCommandEvent& event);
|
void PatchListSelectionChanged(wxCommandEvent& event);
|
||||||
void PatchButtonClicked(wxCommandEvent& event);
|
void PatchButtonClicked(wxCommandEvent& event);
|
||||||
void RightClickOnBanner(wxMouseEvent& event);
|
|
||||||
void OnBannerImageSave(wxCommandEvent& event);
|
|
||||||
void OnRightClickOnTree(wxTreeEvent& event);
|
void OnRightClickOnTree(wxTreeEvent& event);
|
||||||
void OnExtractFile(wxCommandEvent& event);
|
void OnExtractFile(wxCommandEvent& event);
|
||||||
void OnExtractDir(wxCommandEvent& event);
|
void OnExtractDir(wxCommandEvent& event);
|
||||||
void OnExtractDataFromHeader(wxCommandEvent& event);
|
void OnExtractDataFromHeader(wxCommandEvent& event);
|
||||||
void CheckPartitionIntegrity(wxCommandEvent& event);
|
void CheckPartitionIntegrity(wxCommandEvent& event);
|
||||||
void OnEmustateChanged(wxCommandEvent& event);
|
void OnEmustateChanged(wxCommandEvent& event);
|
||||||
void OnChangeBannerLang(wxCommandEvent& event);
|
|
||||||
void OnCheatCodeToggled(wxCommandEvent& event);
|
void OnCheatCodeToggled(wxCommandEvent& event);
|
||||||
|
void OnChangeTitle(wxCommandEvent& event);
|
||||||
|
|
||||||
const GameListItem OpenGameListItem;
|
const GameListItem OpenGameListItem;
|
||||||
|
|
||||||
typedef std::vector<const DiscIO::SFileInfo*>::iterator fileIter;
|
|
||||||
|
|
||||||
size_t CreateDirectoryTree(wxTreeItemId& parent, const std::vector<DiscIO::SFileInfo>& fileInfos);
|
size_t CreateDirectoryTree(wxTreeItemId& parent, const std::vector<DiscIO::SFileInfo>& fileInfos);
|
||||||
size_t CreateDirectoryTree(wxTreeItemId& parent, const std::vector<DiscIO::SFileInfo>& fileInfos,
|
size_t CreateDirectoryTree(wxTreeItemId& parent, const std::vector<DiscIO::SFileInfo>& fileInfos,
|
||||||
const size_t _FirstIndex, const size_t _LastIndex);
|
const size_t _FirstIndex, const size_t _LastIndex);
|
||||||
@ -231,7 +195,6 @@ private:
|
|||||||
void GenerateLocalIniModified();
|
void GenerateLocalIniModified();
|
||||||
void PatchList_Load();
|
void PatchList_Load();
|
||||||
void PatchList_Save();
|
void PatchList_Save();
|
||||||
void ChangeBannerDetails(DiscIO::Language language);
|
|
||||||
|
|
||||||
long GetElementStyle(const char* section, const char* key);
|
long GetElementStyle(const char* section, const char* key);
|
||||||
void SetCheckboxValueFromGameini(const char* section, const char* key, wxCheckBox* checkbox);
|
void SetCheckboxValueFromGameini(const char* section, const char* key, wxCheckBox* checkbox);
|
402
Source/Core/DolphinWX/ISOProperties/InfoPanel.cpp
Normal file
402
Source/Core/DolphinWX/ISOProperties/InfoPanel.cpp
Normal file
@ -0,0 +1,402 @@
|
|||||||
|
// Copyright 2016 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#include "DolphinWX/ISOProperties/InfoPanel.h"
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
|
#include <iterator>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
#include <wx/arrstr.h>
|
||||||
|
#include <wx/bitmap.h>
|
||||||
|
#include <wx/button.h>
|
||||||
|
#include <wx/choice.h>
|
||||||
|
#include <wx/filedlg.h>
|
||||||
|
#include <wx/gbsizer.h>
|
||||||
|
#include <wx/menu.h>
|
||||||
|
#include <wx/progdlg.h>
|
||||||
|
#include <wx/sizer.h>
|
||||||
|
#include <wx/statbmp.h>
|
||||||
|
#include <wx/stattext.h>
|
||||||
|
#include <wx/textctrl.h>
|
||||||
|
#include <wx/utils.h>
|
||||||
|
|
||||||
|
#include "Common/MD5.h"
|
||||||
|
#include "Common/StringUtil.h"
|
||||||
|
#include "Core/ConfigManager.h"
|
||||||
|
#include "DiscIO/Enums.h"
|
||||||
|
#include "DiscIO/Volume.h"
|
||||||
|
#include "DolphinWX/ISOFile.h"
|
||||||
|
#include "DolphinWX/ISOProperties/ISOProperties.h"
|
||||||
|
#include "DolphinWX/WxUtils.h"
|
||||||
|
|
||||||
|
namespace
|
||||||
|
{
|
||||||
|
wxArrayString GetLanguageChoiceStrings(const std::vector<DiscIO::Language>& languages)
|
||||||
|
{
|
||||||
|
wxArrayString available_languages;
|
||||||
|
|
||||||
|
for (auto language : languages)
|
||||||
|
{
|
||||||
|
switch (language)
|
||||||
|
{
|
||||||
|
case DiscIO::Language::LANGUAGE_JAPANESE:
|
||||||
|
available_languages.Add(_("Japanese"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_ENGLISH:
|
||||||
|
available_languages.Add(_("English"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_GERMAN:
|
||||||
|
available_languages.Add(_("German"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_FRENCH:
|
||||||
|
available_languages.Add(_("French"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_SPANISH:
|
||||||
|
available_languages.Add(_("Spanish"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_ITALIAN:
|
||||||
|
available_languages.Add(_("Italian"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_DUTCH:
|
||||||
|
available_languages.Add(_("Dutch"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_SIMPLIFIED_CHINESE:
|
||||||
|
available_languages.Add(_("Simplified Chinese"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_TRADITIONAL_CHINESE:
|
||||||
|
available_languages.Add(_("Traditional Chinese"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_KOREAN:
|
||||||
|
available_languages.Add(_("Korean"));
|
||||||
|
break;
|
||||||
|
case DiscIO::Language::LANGUAGE_UNKNOWN:
|
||||||
|
default:
|
||||||
|
available_languages.Add(_("Unknown"));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return available_languages;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxString GetCountryName(DiscIO::Country country)
|
||||||
|
{
|
||||||
|
switch (country)
|
||||||
|
{
|
||||||
|
case DiscIO::Country::COUNTRY_AUSTRALIA:
|
||||||
|
return _("Australia");
|
||||||
|
case DiscIO::Country::COUNTRY_EUROPE:
|
||||||
|
return _("Europe");
|
||||||
|
case DiscIO::Country::COUNTRY_FRANCE:
|
||||||
|
return _("France");
|
||||||
|
case DiscIO::Country::COUNTRY_ITALY:
|
||||||
|
return _("Italy");
|
||||||
|
case DiscIO::Country::COUNTRY_GERMANY:
|
||||||
|
return _("Germany");
|
||||||
|
case DiscIO::Country::COUNTRY_NETHERLANDS:
|
||||||
|
return _("Netherlands");
|
||||||
|
case DiscIO::Country::COUNTRY_RUSSIA:
|
||||||
|
return _("Russia");
|
||||||
|
case DiscIO::Country::COUNTRY_SPAIN:
|
||||||
|
return _("Spain");
|
||||||
|
case DiscIO::Country::COUNTRY_USA:
|
||||||
|
return _("USA");
|
||||||
|
case DiscIO::Country::COUNTRY_JAPAN:
|
||||||
|
return _("Japan");
|
||||||
|
case DiscIO::Country::COUNTRY_KOREA:
|
||||||
|
return _("Korea");
|
||||||
|
case DiscIO::Country::COUNTRY_TAIWAN:
|
||||||
|
return _("Taiwan");
|
||||||
|
case DiscIO::Country::COUNTRY_WORLD:
|
||||||
|
return _("World");
|
||||||
|
case DiscIO::Country::COUNTRY_UNKNOWN:
|
||||||
|
default:
|
||||||
|
return _("Unknown");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int FindPreferredLanguageIndex(DiscIO::Language preferred_language,
|
||||||
|
const std::vector<DiscIO::Language>& languages)
|
||||||
|
{
|
||||||
|
const auto iter =
|
||||||
|
std::find_if(languages.begin(), languages.end(),
|
||||||
|
[preferred_language](auto language) { return language == preferred_language; });
|
||||||
|
|
||||||
|
if (iter == languages.end())
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return static_cast<int>(std::distance(languages.begin(), iter));
|
||||||
|
}
|
||||||
|
} // Anonymous namespace
|
||||||
|
|
||||||
|
InfoPanel::InfoPanel(wxWindow* parent, wxWindowID id, const GameListItem& item,
|
||||||
|
const std::unique_ptr<DiscIO::IVolume>& opened_iso)
|
||||||
|
: wxPanel{parent, id}, m_game_list_item{item}, m_opened_iso{opened_iso}
|
||||||
|
{
|
||||||
|
CreateGUI();
|
||||||
|
BindEvents();
|
||||||
|
LoadGUIData();
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::CreateGUI()
|
||||||
|
{
|
||||||
|
const int space_5 = FromDIP(5);
|
||||||
|
|
||||||
|
auto* const main_sizer = new wxBoxSizer(wxVERTICAL);
|
||||||
|
main_sizer->AddSpacer(space_5);
|
||||||
|
main_sizer->Add(CreateISODetailsSizer(), 0, wxEXPAND | wxLEFT | wxRIGHT, space_5);
|
||||||
|
main_sizer->AddSpacer(space_5);
|
||||||
|
main_sizer->Add(CreateBannerDetailsSizer(), 0, wxEXPAND | wxLEFT | wxRIGHT, space_5);
|
||||||
|
main_sizer->AddSpacer(space_5);
|
||||||
|
|
||||||
|
SetSizer(main_sizer);
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::BindEvents()
|
||||||
|
{
|
||||||
|
m_md5_sum_compute->Bind(wxEVT_BUTTON, &InfoPanel::OnComputeMD5, this);
|
||||||
|
m_languages->Bind(wxEVT_CHOICE, &InfoPanel::OnChangeBannerLanguage, this);
|
||||||
|
|
||||||
|
Bind(wxEVT_MENU, &InfoPanel::OnSaveBannerImage, this, IDM_SAVE_BANNER);
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::LoadGUIData()
|
||||||
|
{
|
||||||
|
LoadISODetails();
|
||||||
|
LoadBannerDetails();
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::LoadISODetails()
|
||||||
|
{
|
||||||
|
m_internal_name->SetValue(StrToWxStr(m_opened_iso->GetInternalName()));
|
||||||
|
m_game_id->SetValue(StrToWxStr(m_opened_iso->GetGameID()));
|
||||||
|
m_country->SetValue(GetCountryName(m_opened_iso->GetCountry()));
|
||||||
|
m_maker_id->SetValue("0x" + StrToWxStr(m_opened_iso->GetMakerID()));
|
||||||
|
m_revision->SetValue(StrToWxStr(std::to_string(m_opened_iso->GetRevision())));
|
||||||
|
m_date->SetValue(StrToWxStr(m_opened_iso->GetApploaderDate()));
|
||||||
|
m_fst->SetValue(StrToWxStr(std::to_string(m_opened_iso->GetFSTSize())));
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::LoadBannerDetails()
|
||||||
|
{
|
||||||
|
LoadBannerImage();
|
||||||
|
|
||||||
|
const bool is_wii = m_opened_iso->GetVolumeType() != DiscIO::Platform::GAMECUBE_DISC;
|
||||||
|
ChangeBannerDetails(SConfig::GetInstance().GetCurrentLanguage(is_wii));
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::LoadBannerImage()
|
||||||
|
{
|
||||||
|
const auto& banner_image = m_game_list_item.GetBannerImage();
|
||||||
|
const auto banner_min_size = m_banner->GetMinSize();
|
||||||
|
|
||||||
|
if (banner_image.IsOk())
|
||||||
|
{
|
||||||
|
m_banner->SetBitmap(WxUtils::ScaleImageToBitmap(banner_image, this, banner_min_size));
|
||||||
|
m_banner->Bind(wxEVT_RIGHT_DOWN, &InfoPanel::OnRightClickBanner, this);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_banner->SetBitmap(WxUtils::LoadScaledResourceBitmap("nobanner", this, banner_min_size));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
wxStaticBoxSizer* InfoPanel::CreateISODetailsSizer()
|
||||||
|
{
|
||||||
|
auto* const internal_name_text = new wxStaticText(this, wxID_ANY, _("Internal Name:"));
|
||||||
|
m_internal_name =
|
||||||
|
new wxTextCtrl(this, ID_NAME, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxTE_READONLY);
|
||||||
|
|
||||||
|
auto* const game_id_text = new wxStaticText(this, wxID_ANY, _("Game ID:"));
|
||||||
|
m_game_id = new wxTextCtrl(this, ID_GAME_ID, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
auto* const country_text = new wxStaticText(this, wxID_ANY, _("Country:"));
|
||||||
|
m_country = new wxTextCtrl(this, ID_COUNTRY, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
auto* const maker_id_text = new wxStaticText(this, wxID_ANY, _("Maker ID:"));
|
||||||
|
m_maker_id = new wxTextCtrl(this, ID_MAKER_ID, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
auto* const revision_text = new wxStaticText(this, wxID_ANY, _("Revision:"));
|
||||||
|
m_revision = new wxTextCtrl(this, ID_REVISION, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
|
||||||
|
auto* const date_text = new wxStaticText(this, wxID_ANY, _("Apploader Date:"));
|
||||||
|
m_date =
|
||||||
|
new wxTextCtrl(this, ID_DATE, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxTE_READONLY);
|
||||||
|
|
||||||
|
auto* const fst_text = new wxStaticText(this, wxID_ANY, _("FST Size:"));
|
||||||
|
m_fst =
|
||||||
|
new wxTextCtrl(this, ID_FST, wxEmptyString, wxDefaultPosition, wxDefaultSize, wxTE_READONLY);
|
||||||
|
|
||||||
|
auto* const md5_sum_text = new wxStaticText(this, wxID_ANY, _("MD5 Checksum:"));
|
||||||
|
m_md5_sum = new wxTextCtrl(this, ID_MD5_SUM, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
m_md5_sum_compute = new wxButton(this, ID_MD5_SUM_COMPUTE, _("Compute"));
|
||||||
|
|
||||||
|
const int space_10 = FromDIP(10);
|
||||||
|
auto* const iso_details = new wxGridBagSizer(space_10, space_10);
|
||||||
|
iso_details->Add(internal_name_text, wxGBPosition(0, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_internal_name, wxGBPosition(0, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(game_id_text, wxGBPosition(1, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_game_id, wxGBPosition(1, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(country_text, wxGBPosition(2, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_country, wxGBPosition(2, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(maker_id_text, wxGBPosition(3, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_maker_id, wxGBPosition(3, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(revision_text, wxGBPosition(4, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_revision, wxGBPosition(4, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(date_text, wxGBPosition(5, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_date, wxGBPosition(5, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(fst_text, wxGBPosition(6, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_fst, wxGBPosition(6, 1), wxGBSpan(1, 2), wxEXPAND);
|
||||||
|
iso_details->Add(md5_sum_text, wxGBPosition(7, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
iso_details->Add(m_md5_sum, wxGBPosition(7, 1), wxGBSpan(1, 1), wxEXPAND);
|
||||||
|
iso_details->Add(m_md5_sum_compute, wxGBPosition(7, 2), wxGBSpan(1, 1), wxEXPAND);
|
||||||
|
iso_details->AddGrowableCol(1);
|
||||||
|
|
||||||
|
const int space_5 = FromDIP(5);
|
||||||
|
auto* const iso_details_sizer = new wxStaticBoxSizer(wxVERTICAL, this, _("ISO Details"));
|
||||||
|
iso_details_sizer->AddSpacer(space_5);
|
||||||
|
iso_details_sizer->Add(iso_details, 0, wxEXPAND | wxLEFT | wxRIGHT, space_5);
|
||||||
|
iso_details_sizer->AddSpacer(space_5);
|
||||||
|
|
||||||
|
return iso_details_sizer;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxStaticBoxSizer* InfoPanel::CreateBannerDetailsSizer()
|
||||||
|
{
|
||||||
|
auto* const name_text = new wxStaticText(this, wxID_ANY, _("Name:"));
|
||||||
|
m_name = new wxTextCtrl(this, ID_SHORT_NAME, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
auto* const maker_text = new wxStaticText(this, wxID_ANY, _("Maker:"));
|
||||||
|
m_maker = new wxTextCtrl(this, ID_MAKER, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_READONLY);
|
||||||
|
auto* const comment_text = new wxStaticText(this, wxID_ANY, _("Description:"));
|
||||||
|
m_comment = new wxTextCtrl(this, ID_COMMENT, wxEmptyString, wxDefaultPosition, wxDefaultSize,
|
||||||
|
wxTE_MULTILINE | wxTE_READONLY);
|
||||||
|
auto* const banner_text = new wxStaticText(this, wxID_ANY, _("Banner:"));
|
||||||
|
m_banner =
|
||||||
|
new wxStaticBitmap(this, ID_BANNER, wxNullBitmap, wxDefaultPosition, FromDIP(wxSize(96, 32)));
|
||||||
|
|
||||||
|
auto* const languages_text = new wxStaticText(this, wxID_ANY, _("Show Language:"));
|
||||||
|
m_languages = CreateCommentLanguageChoice();
|
||||||
|
|
||||||
|
const int space_10 = FromDIP(10);
|
||||||
|
auto* const banner_details = new wxGridBagSizer(space_10, space_10);
|
||||||
|
banner_details->Add(languages_text, wxGBPosition(0, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
// Comboboxes cannot be safely stretched vertically on Windows.
|
||||||
|
banner_details->Add(WxUtils::GiveMinSize(m_languages, wxDefaultSize), wxGBPosition(0, 1),
|
||||||
|
wxGBSpan(1, 1), wxEXPAND);
|
||||||
|
banner_details->Add(name_text, wxGBPosition(1, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
banner_details->Add(m_name, wxGBPosition(1, 1), wxGBSpan(1, 1), wxEXPAND);
|
||||||
|
banner_details->Add(maker_text, wxGBPosition(2, 0), wxGBSpan(1, 1), wxALIGN_CENTER_VERTICAL);
|
||||||
|
banner_details->Add(m_maker, wxGBPosition(2, 1), wxGBSpan(1, 1), wxEXPAND);
|
||||||
|
banner_details->Add(comment_text, wxGBPosition(3, 0), wxGBSpan(1, 1));
|
||||||
|
banner_details->Add(m_comment, wxGBPosition(3, 1), wxGBSpan(1, 1), wxEXPAND);
|
||||||
|
banner_details->Add(banner_text, wxGBPosition(4, 0), wxGBSpan(1, 1));
|
||||||
|
banner_details->Add(m_banner, wxGBPosition(4, 1), wxGBSpan(1, 1));
|
||||||
|
banner_details->AddGrowableCol(1);
|
||||||
|
|
||||||
|
const int space_5 = FromDIP(5);
|
||||||
|
auto* const banner_details_sizer = new wxStaticBoxSizer(wxVERTICAL, this, _("Banner Details"));
|
||||||
|
banner_details_sizer->AddSpacer(space_5);
|
||||||
|
banner_details_sizer->Add(banner_details, 0, wxEXPAND | wxLEFT | wxRIGHT, space_5);
|
||||||
|
banner_details_sizer->AddSpacer(space_5);
|
||||||
|
|
||||||
|
return banner_details_sizer;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxChoice* InfoPanel::CreateCommentLanguageChoice()
|
||||||
|
{
|
||||||
|
const auto languages = m_game_list_item.GetLanguages();
|
||||||
|
const bool is_wii = m_opened_iso->GetVolumeType() != DiscIO::Platform::GAMECUBE_DISC;
|
||||||
|
const auto preferred_language = SConfig::GetInstance().GetCurrentLanguage(is_wii);
|
||||||
|
const int preferred_language_index = FindPreferredLanguageIndex(preferred_language, languages);
|
||||||
|
const auto choices = GetLanguageChoiceStrings(languages);
|
||||||
|
|
||||||
|
auto* const choice = new wxChoice(this, ID_LANGUAGE, wxDefaultPosition, wxDefaultSize, choices);
|
||||||
|
choice->SetSelection(preferred_language_index);
|
||||||
|
|
||||||
|
if (choice->GetCount() <= 1)
|
||||||
|
choice->Disable();
|
||||||
|
|
||||||
|
return choice;
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::OnComputeMD5(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
wxProgressDialog progress_dialog(_("Computing MD5 checksum"), _("Working..."), 100, this,
|
||||||
|
wxPD_APP_MODAL | wxPD_AUTO_HIDE | wxPD_CAN_ABORT |
|
||||||
|
wxPD_ELAPSED_TIME | wxPD_ESTIMATED_TIME |
|
||||||
|
wxPD_REMAINING_TIME | wxPD_SMOOTH);
|
||||||
|
|
||||||
|
const auto result = MD5::MD5Sum(m_game_list_item.GetFileName(), [&progress_dialog](int progress) {
|
||||||
|
return progress_dialog.Update(progress);
|
||||||
|
});
|
||||||
|
|
||||||
|
if (progress_dialog.WasCancelled())
|
||||||
|
return;
|
||||||
|
|
||||||
|
m_md5_sum->SetValue(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::OnChangeBannerLanguage(wxCommandEvent& event)
|
||||||
|
{
|
||||||
|
ChangeBannerDetails(m_game_list_item.GetLanguages()[event.GetSelection()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::OnRightClickBanner(wxMouseEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
wxMenu menu;
|
||||||
|
menu.Append(IDM_SAVE_BANNER, _("Save as..."));
|
||||||
|
PopupMenu(&menu);
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::OnSaveBannerImage(wxCommandEvent& WXUNUSED(event))
|
||||||
|
{
|
||||||
|
wxFileDialog dialog(this, _("Save as..."), wxGetHomeDir(),
|
||||||
|
wxString::Format("%s.png", m_game_id->GetValue().c_str()),
|
||||||
|
wxALL_FILES_PATTERN, wxFD_SAVE | wxFD_OVERWRITE_PROMPT);
|
||||||
|
|
||||||
|
if (dialog.ShowModal() == wxID_OK)
|
||||||
|
{
|
||||||
|
m_game_list_item.GetBannerImage().SaveFile(dialog.GetPath());
|
||||||
|
}
|
||||||
|
|
||||||
|
Raise();
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::ChangeBannerDetails(DiscIO::Language language)
|
||||||
|
{
|
||||||
|
const auto name = StrToWxStr(m_game_list_item.GetName(language));
|
||||||
|
const auto comment = StrToWxStr(m_game_list_item.GetDescription(language));
|
||||||
|
const auto maker = StrToWxStr(m_game_list_item.GetCompany());
|
||||||
|
|
||||||
|
m_name->SetValue(name);
|
||||||
|
m_comment->SetValue(comment);
|
||||||
|
m_maker->SetValue(maker);
|
||||||
|
|
||||||
|
std::string path, filename, extension;
|
||||||
|
SplitPath(m_game_list_item.GetFileName(), &path, &filename, &extension);
|
||||||
|
|
||||||
|
// Real disk drives don't have filenames on Windows
|
||||||
|
if (filename.empty() && extension.empty())
|
||||||
|
filename = path + ' ';
|
||||||
|
|
||||||
|
const auto game_id = m_game_list_item.GetGameID();
|
||||||
|
const auto new_title = wxString::Format("%s%s: %s - %s", filename.c_str(), extension.c_str(),
|
||||||
|
game_id.c_str(), name.c_str());
|
||||||
|
|
||||||
|
EmitTitleChangeEvent(new_title);
|
||||||
|
}
|
||||||
|
|
||||||
|
void InfoPanel::EmitTitleChangeEvent(const wxString& new_title)
|
||||||
|
{
|
||||||
|
wxCommandEvent event{DOLPHIN_EVT_CHANGE_ISO_PROPERTIES_TITLE, GetId()};
|
||||||
|
event.SetEventObject(this);
|
||||||
|
event.SetString(new_title);
|
||||||
|
AddPendingEvent(event);
|
||||||
|
}
|
88
Source/Core/DolphinWX/ISOProperties/InfoPanel.h
Normal file
88
Source/Core/DolphinWX/ISOProperties/InfoPanel.h
Normal file
@ -0,0 +1,88 @@
|
|||||||
|
// Copyright 2016 Dolphin Emulator Project
|
||||||
|
// Licensed under GPLv2+
|
||||||
|
// Refer to the license.txt file included.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
#include <wx/panel.h>
|
||||||
|
|
||||||
|
class GameListItem;
|
||||||
|
class wxButton;
|
||||||
|
class wxChoice;
|
||||||
|
class wxStaticBitmap;
|
||||||
|
class wxStaticBoxSizer;
|
||||||
|
class wxTextCtrl;
|
||||||
|
|
||||||
|
namespace DiscIO
|
||||||
|
{
|
||||||
|
class IVolume;
|
||||||
|
enum class Language;
|
||||||
|
}
|
||||||
|
|
||||||
|
class InfoPanel final : public wxPanel
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
InfoPanel(wxWindow* parent, wxWindowID id, const GameListItem& item,
|
||||||
|
const std::unique_ptr<DiscIO::IVolume>& opened_iso);
|
||||||
|
|
||||||
|
private:
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
ID_NAME = 10000,
|
||||||
|
ID_GAME_ID,
|
||||||
|
ID_COUNTRY,
|
||||||
|
ID_MAKER_ID,
|
||||||
|
ID_REVISION,
|
||||||
|
ID_DATE,
|
||||||
|
ID_FST,
|
||||||
|
ID_MD5_SUM,
|
||||||
|
ID_MD5_SUM_COMPUTE,
|
||||||
|
ID_VERSION,
|
||||||
|
ID_LANGUAGE,
|
||||||
|
ID_SHORT_NAME,
|
||||||
|
ID_MAKER,
|
||||||
|
ID_COMMENT,
|
||||||
|
ID_BANNER,
|
||||||
|
|
||||||
|
IDM_SAVE_BANNER
|
||||||
|
};
|
||||||
|
|
||||||
|
void CreateGUI();
|
||||||
|
void BindEvents();
|
||||||
|
void LoadGUIData();
|
||||||
|
void LoadISODetails();
|
||||||
|
void LoadBannerDetails();
|
||||||
|
void LoadBannerImage();
|
||||||
|
|
||||||
|
wxStaticBoxSizer* CreateISODetailsSizer();
|
||||||
|
wxStaticBoxSizer* CreateBannerDetailsSizer();
|
||||||
|
wxChoice* CreateCommentLanguageChoice();
|
||||||
|
|
||||||
|
void OnComputeMD5(wxCommandEvent&);
|
||||||
|
void OnChangeBannerLanguage(wxCommandEvent&);
|
||||||
|
void OnRightClickBanner(wxMouseEvent&);
|
||||||
|
void OnSaveBannerImage(wxCommandEvent&);
|
||||||
|
|
||||||
|
void ChangeBannerDetails(DiscIO::Language language);
|
||||||
|
|
||||||
|
void EmitTitleChangeEvent(const wxString& new_title);
|
||||||
|
|
||||||
|
const GameListItem& m_game_list_item;
|
||||||
|
const std::unique_ptr<DiscIO::IVolume>& m_opened_iso;
|
||||||
|
|
||||||
|
wxTextCtrl* m_internal_name;
|
||||||
|
wxTextCtrl* m_game_id;
|
||||||
|
wxTextCtrl* m_country;
|
||||||
|
wxTextCtrl* m_maker_id;
|
||||||
|
wxTextCtrl* m_revision;
|
||||||
|
wxTextCtrl* m_date;
|
||||||
|
wxTextCtrl* m_fst;
|
||||||
|
wxTextCtrl* m_md5_sum;
|
||||||
|
wxButton* m_md5_sum_compute;
|
||||||
|
wxChoice* m_languages;
|
||||||
|
wxTextCtrl* m_name;
|
||||||
|
wxTextCtrl* m_maker;
|
||||||
|
wxTextCtrl* m_comment;
|
||||||
|
wxStaticBitmap* m_banner;
|
||||||
|
};
|
Loading…
x
Reference in New Issue
Block a user