Core: Added playtime counter on a per ROM basis.
This commit is contained in:
parent
210ebd42de
commit
a2c356f16e
|
@ -195,6 +195,7 @@ enum LanguageStringID
|
||||||
RB_FORCE_FEEDBACK = 318,
|
RB_FORCE_FEEDBACK = 318,
|
||||||
RB_FILE_FORMAT = 319,
|
RB_FILE_FORMAT = 319,
|
||||||
RB_NAME = 321,
|
RB_NAME = 321,
|
||||||
|
RB_PLAYTIME = 3114,
|
||||||
|
|
||||||
// Select ROM
|
// Select ROM
|
||||||
SELECT_ROM_DIR = 320,
|
SELECT_ROM_DIR = 320,
|
||||||
|
|
|
@ -145,6 +145,7 @@ void CLanguage::LoadDefaultStrings(void)
|
||||||
DEF_STR(RB_FORCE_FEEDBACK, "Force Feedback");
|
DEF_STR(RB_FORCE_FEEDBACK, "Force Feedback");
|
||||||
DEF_STR(RB_FILE_FORMAT, "File Format");
|
DEF_STR(RB_FILE_FORMAT, "File Format");
|
||||||
DEF_STR(RB_NAME, "Name");
|
DEF_STR(RB_NAME, "Name");
|
||||||
|
DEF_STR(RB_PLAYTIME, "Playtime");
|
||||||
|
|
||||||
// Select ROM
|
// Select ROM
|
||||||
DEF_STR(SELECT_ROM_DIR, "Select current ROM directory");
|
DEF_STR(SELECT_ROM_DIR, "Select current ROM directory");
|
||||||
|
|
|
@ -44,6 +44,7 @@ CRomList::CRomList() :
|
||||||
m_NotesIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_Notes).c_str());
|
m_NotesIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_Notes).c_str());
|
||||||
m_ExtIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_ExtInfo).c_str());
|
m_ExtIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_ExtInfo).c_str());
|
||||||
m_RomIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_RomDatabase).c_str());
|
m_RomIniFile = new CIniFile(g_Settings->LoadStringVal(SupportFile_RomDatabase).c_str());
|
||||||
|
m_PlaytimeFile = std::make_unique<CIniFile>(g_Settings->LoadStringVal(SupportFile_Playtime).c_str());
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
m_ZipIniFile = new CIniFile(g_Settings->LoadStringVal(RomList_7zipCache).c_str());
|
m_ZipIniFile = new CIniFile(g_Settings->LoadStringVal(RomList_7zipCache).c_str());
|
||||||
#endif
|
#endif
|
||||||
|
@ -89,6 +90,16 @@ CRomList::~CRomList()
|
||||||
WriteTrace(TraceRomList, TraceVerbose, "Done");
|
WriteTrace(TraceRomList, TraceVerbose, "Done");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t CRomList::LoadPlaytime(const std::string & ApplicationName)
|
||||||
|
{
|
||||||
|
return m_PlaytimeFile->GetNumber(ApplicationName.c_str(), "Playtime", 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void CRomList::SavePlaytime(const std::string & ApplicationName, uint32_t Playtime)
|
||||||
|
{
|
||||||
|
m_PlaytimeFile->SaveNumber(ApplicationName.c_str(), "Playtime", Playtime);
|
||||||
|
}
|
||||||
|
|
||||||
void CRomList::RefreshRomList(void)
|
void CRomList::RefreshRomList(void)
|
||||||
{
|
{
|
||||||
if (m_RefreshThread.isRunning())
|
if (m_RefreshThread.isRunning())
|
||||||
|
|
|
@ -1,10 +1,13 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <Common/IniFile.h>
|
#include <Common/IniFile.h>
|
||||||
#include <Common/StdString.h>
|
#include <Common/StdString.h>
|
||||||
#include <Common/Thread.h>
|
#include <Common/Thread.h>
|
||||||
#include <Common/md5.h>
|
#include <Common/md5.h>
|
||||||
#include <Common/path.h>
|
#include <Common/path.h>
|
||||||
#include <Project64-core/N64System/N64Types.h>
|
#include <Project64-core/N64System/N64Types.h>
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
class CRomList
|
class CRomList
|
||||||
{
|
{
|
||||||
|
@ -51,6 +54,9 @@ public:
|
||||||
void RefreshRomList(void);
|
void RefreshRomList(void);
|
||||||
void LoadRomList(void);
|
void LoadRomList(void);
|
||||||
|
|
||||||
|
uint32_t LoadPlaytime(const std::string & ApplicationName);
|
||||||
|
void SavePlaytime(const std::string & ApplicationName, uint32_t Playtime);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
typedef std::vector<ROM_INFO> ROMINFO_LIST;
|
typedef std::vector<ROM_INFO> ROMINFO_LIST;
|
||||||
|
|
||||||
|
@ -87,6 +93,7 @@ private:
|
||||||
CIniFile * m_NotesIniFile;
|
CIniFile * m_NotesIniFile;
|
||||||
CIniFile * m_ExtIniFile;
|
CIniFile * m_ExtIniFile;
|
||||||
CIniFile * m_RomIniFile;
|
CIniFile * m_RomIniFile;
|
||||||
|
std::unique_ptr<CIniFile> m_PlaytimeFile;
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
CIniFile * m_ZipIniFile;
|
CIniFile * m_ZipIniFile;
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -80,6 +80,8 @@ void CSettings::AddHowToHandleSetting(const char * BaseDirectory)
|
||||||
AddHandler(Cmd_ComboDiskFile, new CSettingTypeTempString(""));
|
AddHandler(Cmd_ComboDiskFile, new CSettingTypeTempString(""));
|
||||||
|
|
||||||
// Support files
|
// Support files
|
||||||
|
AddHandler(SupportFile_Playtime, new CSettingTypeApplicationPath("Settings", "Playtime", SupportFile_PlaytimeDefault));
|
||||||
|
AddHandler(SupportFile_PlaytimeDefault, new CSettingTypeRelativePath("Config", "Playtime.rdn"));
|
||||||
AddHandler(SupportFile_SettingsDirectory, new CSettingTypeTempString(""));
|
AddHandler(SupportFile_SettingsDirectory, new CSettingTypeTempString(""));
|
||||||
AddHandler(SupportFile_Settings, new CSettingTypeApplicationPath("Settings", "ConfigFile", SupportFile_SettingsDefault));
|
AddHandler(SupportFile_Settings, new CSettingTypeApplicationPath("Settings", "ConfigFile", SupportFile_SettingsDefault));
|
||||||
AddHandler(SupportFile_SettingsDefault, new CSettingTypeRelativePath("Config", "Project64.cfg"));
|
AddHandler(SupportFile_SettingsDefault, new CSettingTypeRelativePath("Config", "Project64.cfg"));
|
||||||
|
|
|
@ -18,6 +18,8 @@ enum SettingID
|
||||||
Cmd_ShowHelp,
|
Cmd_ShowHelp,
|
||||||
|
|
||||||
// Support files
|
// Support files
|
||||||
|
SupportFile_Playtime,
|
||||||
|
SupportFile_PlaytimeDefault,
|
||||||
SupportFile_SettingsDirectory,
|
SupportFile_SettingsDirectory,
|
||||||
SupportFile_Settings,
|
SupportFile_Settings,
|
||||||
SupportFile_SettingsDefault,
|
SupportFile_SettingsDefault,
|
||||||
|
|
|
@ -227,10 +227,19 @@ void CMainGui::GamePaused(CMainGui * Gui)
|
||||||
Gui->RefreshMenu();
|
Gui->RefreshMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CMainGui::SavePlaytime()
|
||||||
|
{
|
||||||
|
auto Now = std::chrono::steady_clock::now();
|
||||||
|
uint32_t Elapsed = std::chrono::duration_cast<std::chrono::seconds>(Now - m_CurrentPlaytime).count();
|
||||||
|
auto PastPlaytime = CRomList::LoadPlaytime(g_Settings->LoadStringVal(Rdb_GoodName));
|
||||||
|
CRomList::SavePlaytime(g_Settings->LoadStringVal(Rdb_GoodName), PastPlaytime + Elapsed);
|
||||||
|
}
|
||||||
|
|
||||||
void CMainGui::GameCpuRunning(CMainGui * Gui)
|
void CMainGui::GameCpuRunning(CMainGui * Gui)
|
||||||
{
|
{
|
||||||
if (g_Settings->LoadBool(GameRunning_CPU_Running))
|
if (g_Settings->LoadBool(GameRunning_CPU_Running))
|
||||||
{
|
{
|
||||||
|
Gui->m_CurrentPlaytime = std::chrono::steady_clock::now();
|
||||||
Gui->MakeWindowOnTop(UISettingsLoadBool(UserInterface_AlwaysOnTop));
|
Gui->MakeWindowOnTop(UISettingsLoadBool(UserInterface_AlwaysOnTop));
|
||||||
Gui->HideRomList();
|
Gui->HideRomList();
|
||||||
if (UISettingsLoadBool(Setting_AutoFullscreen))
|
if (UISettingsLoadBool(Setting_AutoFullscreen))
|
||||||
|
@ -251,6 +260,7 @@ void CMainGui::GameCpuRunning(CMainGui * Gui)
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
Gui->SavePlaytime();
|
||||||
if (Gui->m_CheatsUI.m_hWnd != nullptr)
|
if (Gui->m_CheatsUI.m_hWnd != nullptr)
|
||||||
{
|
{
|
||||||
Gui->m_CheatsUI.SendMessage(WM_COMMAND, MAKELONG(IDCANCEL, 0));
|
Gui->m_CheatsUI.SendMessage(WM_COMMAND, MAKELONG(IDCANCEL, 0));
|
||||||
|
|
|
@ -7,6 +7,7 @@
|
||||||
#include <Project64/UserInterface/EnhancementUI.h>
|
#include <Project64/UserInterface/EnhancementUI.h>
|
||||||
#include <Project64/UserInterface/ProjectSupport.h>
|
#include <Project64/UserInterface/ProjectSupport.h>
|
||||||
#include <Project64/UserInterface/RomBrowser.h>
|
#include <Project64/UserInterface/RomBrowser.h>
|
||||||
|
#include <chrono>
|
||||||
|
|
||||||
class CGfxPlugin; // Plugin that controls the rendering
|
class CGfxPlugin; // Plugin that controls the rendering
|
||||||
class CAudioPlugin; // Plugin for audio, need the hwnd
|
class CAudioPlugin; // Plugin for audio, need the hwnd
|
||||||
|
@ -119,6 +120,7 @@ private:
|
||||||
void AddRecentRom(const char * ImagePath);
|
void AddRecentRom(const char * ImagePath);
|
||||||
void SetWindowCaption(const wchar_t * Caption);
|
void SetWindowCaption(const wchar_t * Caption);
|
||||||
void ShowRomBrowser(void);
|
void ShowRomBrowser(void);
|
||||||
|
void SavePlaytime(void);
|
||||||
|
|
||||||
static LRESULT CALLBACK MainGui_Proc(HWND, DWORD, DWORD, DWORD);
|
static LRESULT CALLBACK MainGui_Proc(HWND, DWORD, DWORD, DWORD);
|
||||||
|
|
||||||
|
@ -156,4 +158,6 @@ private:
|
||||||
bool m_SaveRomBrowserPos;
|
bool m_SaveRomBrowserPos;
|
||||||
LONG m_SaveRomBrowserTop;
|
LONG m_SaveRomBrowserTop;
|
||||||
LONG m_SaveRomBrowserLeft;
|
LONG m_SaveRomBrowserLeft;
|
||||||
|
|
||||||
|
std::chrono::steady_clock::time_point m_CurrentPlaytime;
|
||||||
};
|
};
|
||||||
|
|
|
@ -59,6 +59,7 @@ void CRomBrowser::GetFieldInfo(ROMBROWSER_FIELDS_LIST & Fields, bool UseDefault
|
||||||
AddField(Fields, "Players", -1, RB_Players, 100, RB_PLAYERS, UseDefault);
|
AddField(Fields, "Players", -1, RB_Players, 100, RB_PLAYERS, UseDefault);
|
||||||
AddField(Fields, "Force Feedback", -1, RB_ForceFeedback, 100, RB_FORCE_FEEDBACK, UseDefault);
|
AddField(Fields, "Force Feedback", -1, RB_ForceFeedback, 100, RB_FORCE_FEEDBACK, UseDefault);
|
||||||
AddField(Fields, "File Format", -1, RB_FileFormat, 100, RB_FILE_FORMAT, UseDefault);
|
AddField(Fields, "File Format", -1, RB_FileFormat, 100, RB_FILE_FORMAT, UseDefault);
|
||||||
|
AddField(Fields, "Playtime", -1, RB_Playtime, 200, RB_PLAYTIME, UseDefault);
|
||||||
}
|
}
|
||||||
|
|
||||||
int32_t CRomBrowser::CalcSortPosition(uint32_t lParam)
|
int32_t CRomBrowser::CalcSortPosition(uint32_t lParam)
|
||||||
|
@ -845,6 +846,12 @@ void CRomBrowser::RomList_GetDispInfo(uint32_t pnmh)
|
||||||
default: swprintf(lpdi->item.pszText, lpdi->item.cchTextMax / sizeof(wchar_t), L"Unknown (%X)", pRomInfo->FileFormat); break;
|
default: swprintf(lpdi->item.pszText, lpdi->item.cchTextMax / sizeof(wchar_t), L"Unknown (%X)", pRomInfo->FileFormat); break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case RB_Playtime:
|
||||||
|
{
|
||||||
|
auto Playtime = LoadPlaytime(stdstr(pRomInfo->GoodName));
|
||||||
|
swprintf(lpdi->item.pszText, lpdi->item.cchTextMax / sizeof(wchar_t), L"%02d:%02d:%02d", Playtime / 3600, (Playtime / 60) % 60, Playtime % 60);
|
||||||
|
break;
|
||||||
|
}
|
||||||
default: wcsncpy(lpdi->item.pszText, L" ", lpdi->item.cchTextMax);
|
default: wcsncpy(lpdi->item.pszText, L" ", lpdi->item.cchTextMax);
|
||||||
}
|
}
|
||||||
if (lpdi->item.pszText == nullptr || wcslen(lpdi->item.pszText) == 0)
|
if (lpdi->item.pszText == nullptr || wcslen(lpdi->item.pszText) == 0)
|
||||||
|
|
|
@ -146,6 +146,7 @@ private:
|
||||||
RB_Players = 18,
|
RB_Players = 18,
|
||||||
RB_ForceFeedback = 19,
|
RB_ForceFeedback = 19,
|
||||||
RB_FileFormat = 20,
|
RB_FileFormat = 20,
|
||||||
|
RB_Playtime = 21,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum
|
enum
|
||||||
|
|
Loading…
Reference in New Issue