mirror of
https://github.com/hrydgard/ppsspp.git
synced 2025-04-02 11:01:50 -04:00
Merge pull request #20177 from hrydgard/more-minor-ui-fixes
More minor UI fixes
This commit is contained in:
commit
b2a94a7deb
9 changed files with 28 additions and 75 deletions
|
@ -91,6 +91,10 @@ public:
|
|||
}
|
||||
StringWriter(const StringWriter &) = delete;
|
||||
|
||||
std::string_view as_view() const {
|
||||
return std::string_view(start_, p_ - start_);
|
||||
}
|
||||
|
||||
size_t size() const {
|
||||
return p_ - start_;
|
||||
}
|
||||
|
|
|
@ -31,6 +31,7 @@
|
|||
#include <android/log.h>
|
||||
#elif PPSSPP_PLATFORM(WINDOWS)
|
||||
#include "CommonWindows.h"
|
||||
static HWND g_dialogParent;
|
||||
#endif
|
||||
|
||||
#define LOG_BUF_SIZE 2048
|
||||
|
@ -44,6 +45,14 @@ static bool g_exitOnAssert;
|
|||
static AssertNoCallbackFunc g_assertCancelCallback = 0;
|
||||
static void *g_assertCancelCallbackUserData = 0;
|
||||
|
||||
|
||||
|
||||
void SetAssertDialogParent(void *handle) {
|
||||
#if PPSSPP_PLATFORM(WINDOWS)
|
||||
g_dialogParent = (HWND)handle;
|
||||
#endif
|
||||
}
|
||||
|
||||
void SetExtraAssertInfo(const char *info) {
|
||||
std::lock_guard<std::mutex> guard(g_extraAssertInfoMutex);
|
||||
g_extraAssertInfo = info ? info : "menu";
|
||||
|
@ -106,7 +115,7 @@ bool HandleAssert(const char *function, const char *file, int line, const char *
|
|||
OutputDebugStringA(formatted);
|
||||
printf("%s\n", formatted);
|
||||
std::wstring wcaption = ConvertUTF8ToWString(std::string(caption) + " " + (threadName ? threadName : "(unknown thread)"));
|
||||
switch (MessageBox(0, ConvertUTF8ToWString(text).c_str(), wcaption.c_str(), msgBoxStyle)) {
|
||||
switch (MessageBox(g_dialogParent, ConvertUTF8ToWString(text).c_str(), wcaption.c_str(), msgBoxStyle)) {
|
||||
case IDYES:
|
||||
return true;
|
||||
case IDNO:
|
||||
|
|
|
@ -138,6 +138,7 @@ typedef void (*AssertNoCallbackFunc)(const char *message, void *userdata);
|
|||
void SetAssertCancelCallback(AssertNoCallbackFunc callback, void *userdata);
|
||||
void SetCleanExitOnAssert();
|
||||
void BreakIntoPSPDebugger(const char *reason = "(userbreak)");
|
||||
void SetAssertDialogParent(void *handle); // HWND on windows. Ignored on other platforms.
|
||||
|
||||
#if defined(__ANDROID__)
|
||||
// Tricky macro to get the basename, that also works if *built* on Win32.
|
||||
|
|
|
@ -4,7 +4,7 @@
|
|||
#include "Common/Data/Text/I18n.h"
|
||||
#include "Common/CPUDetect.h"
|
||||
#include "Common/StringUtils.h"
|
||||
#include "Common/Buffer.h"
|
||||
#include "Common/Data/Text/Parsers.h"
|
||||
|
||||
#include "Core/MIPS/MIPS.h"
|
||||
#include "Core/HW/Display.h"
|
||||
|
@ -454,33 +454,33 @@ void DrawFPS(UIContext *ctx, const Bounds &bounds) {
|
|||
float vps, fps, actual_fps;
|
||||
__DisplayGetFPS(&vps, &fps, &actual_fps);
|
||||
|
||||
Buffer buffer;
|
||||
char temp[256];
|
||||
StringWriter w(temp, sizeof(temp));
|
||||
|
||||
if ((g_Config.iShowStatusFlags & ((int)ShowStatusFlags::FPS_COUNTER | (int)ShowStatusFlags::SPEED_COUNTER)) == ((int)ShowStatusFlags::FPS_COUNTER | (int)ShowStatusFlags::SPEED_COUNTER)) {
|
||||
// Both at the same time gets a shorter formulation.
|
||||
buffer.Printf("%0.0f/%0.0f (%0.1f%%)", actual_fps, fps, vps / ((g_Config.iDisplayRefreshRate / 60.0f * 59.94f) / 100.0f));
|
||||
w.F("%0.0f/%0.0f (%0.1f%%)", actual_fps, fps, vps / ((g_Config.iDisplayRefreshRate / 60.0f * 59.94f) / 100.0f));
|
||||
} else {
|
||||
if (g_Config.iShowStatusFlags & (int)ShowStatusFlags::FPS_COUNTER) {
|
||||
buffer.Printf("FPS: %0.1f", actual_fps);
|
||||
w.F("FPS: %0.1f", actual_fps);
|
||||
} else if (g_Config.iShowStatusFlags & (int)ShowStatusFlags::SPEED_COUNTER) {
|
||||
buffer.Printf("Speed: %0.1f%%", vps / (59.94f / 100.0f));
|
||||
w.F("Speed: %0.1f%%", vps / (59.94f / 100.0f));
|
||||
}
|
||||
}
|
||||
if (System_GetPropertyBool(SYSPROP_CAN_READ_BATTERY_PERCENTAGE)) {
|
||||
if (g_Config.iShowStatusFlags & (int)ShowStatusFlags::BATTERY_PERCENT) {
|
||||
const int percentage = System_GetPropertyInt(SYSPROP_BATTERY_PERCENTAGE);
|
||||
// Just plain append battery. Add linebreak?
|
||||
buffer.Printf(" Battery: %d%%", percentage);
|
||||
w.F(" Battery: %d%%", percentage);
|
||||
}
|
||||
}
|
||||
|
||||
ctx->Flush();
|
||||
|
||||
std::string fpsBuf;
|
||||
buffer.TakeAll(&fpsBuf);
|
||||
ctx->BindFontTexture();
|
||||
ctx->Draw()->SetFontScale(0.7f, 0.7f);
|
||||
ctx->Draw()->DrawText(ubuntu24, fpsBuf, bounds.x2() - 8, 20, 0xc0000000, ALIGN_TOPRIGHT | FLAG_DYNAMIC_ASCII);
|
||||
ctx->Draw()->DrawText(ubuntu24, fpsBuf, bounds.x2() - 10, 19, 0xFF3fFF3f, ALIGN_TOPRIGHT | FLAG_DYNAMIC_ASCII);
|
||||
ctx->Draw()->DrawText(ubuntu24, w.as_view(), bounds.x2() - 8, 20, 0xc0000000, ALIGN_TOPRIGHT | FLAG_DYNAMIC_ASCII);
|
||||
ctx->Draw()->DrawText(ubuntu24, w.as_view(), bounds.x2() - 10, 19, 0xFF3fFF3f, ALIGN_TOPRIGHT | FLAG_DYNAMIC_ASCII);
|
||||
ctx->Draw()->SetFontScale(1.0f, 1.0f);
|
||||
ctx->Flush();
|
||||
ctx->RebindTexture();
|
||||
|
|
|
@ -1876,7 +1876,7 @@ void EmuScreen::renderUI() {
|
|||
root_->Draw(*ctx);
|
||||
}
|
||||
|
||||
if (!PSP_IsInited()) {
|
||||
if (PSP_IsInited()) {
|
||||
if ((DebugOverlay)g_Config.iDebugOverlay == DebugOverlay::CONTROL) {
|
||||
DrawControlMapperOverlay(ctx, ctx->GetLayoutBounds(), controlMapper_);
|
||||
}
|
||||
|
|
|
@ -1503,7 +1503,7 @@ UI::EventReturn GameSettingsScreen::OnMemoryStickOther(UI::EventParams &e) {
|
|||
if (otherinstalled_) {
|
||||
auto di = GetI18NCategory(I18NCat::DIALOG);
|
||||
std::string initialPath = g_Config.memStickDirectory.ToCString();
|
||||
std::string folder = W32Util::BrowseForFolder(MainWindow::GetHWND(), di->T("Choose PPSSPP save folder"), initialPath);
|
||||
std::string folder = W32Util::BrowseForFolder2(MainWindow::GetHWND(), di->T("Choose PPSSPP save folder"), initialPath);
|
||||
if (folder.size()) {
|
||||
g_Config.memStickDirectory = Path(folder);
|
||||
FILE *f = File::OpenCFile(PPSSPPpath / "installed.txt", "wb");
|
||||
|
|
|
@ -861,6 +861,7 @@ namespace MainWindow
|
|||
if (g_darkModeSupported) {
|
||||
SendMessageW(hWnd, WM_THEMECHANGED, 0, 0);
|
||||
}
|
||||
SetAssertDialogParent(hWnd);
|
||||
break;
|
||||
|
||||
case WM_USER_RUN_CALLBACK:
|
||||
|
|
|
@ -71,64 +71,6 @@ std::string BrowseForFolder2(HWND parent, std::string_view title, std::string_vi
|
|||
return ConvertWStringToUTF8(selectedFolder);
|
||||
}
|
||||
|
||||
static int CALLBACK BrowseFolderCallback(HWND hwnd, UINT uMsg, LPARAM lParam, LPARAM lpData) {
|
||||
if (uMsg == BFFM_INITIALIZED) {
|
||||
LPCTSTR path = reinterpret_cast<LPCTSTR>(lpData);
|
||||
::SendMessage(hwnd, BFFM_SETSELECTION, true, (LPARAM)path);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
std::string BrowseForFolder(HWND parent, const wchar_t *title, std::string_view initialPath) {
|
||||
BROWSEINFO info{};
|
||||
info.hwndOwner = parent;
|
||||
info.lpszTitle = title;
|
||||
info.ulFlags = BIF_EDITBOX | BIF_RETURNONLYFSDIRS | BIF_USENEWUI | BIF_NEWDIALOGSTYLE;
|
||||
|
||||
std::wstring initialPathW;
|
||||
|
||||
if (!initialPath.empty()) {
|
||||
initialPathW = ConvertUTF8ToWString(initialPath);
|
||||
info.lParam = reinterpret_cast<LPARAM>(initialPathW.c_str());
|
||||
info.lpfn = BrowseFolderCallback;
|
||||
}
|
||||
|
||||
//info.pszDisplayName
|
||||
auto idList = SHBrowseForFolder(&info);
|
||||
HMODULE shell32 = GetModuleHandle(L"shell32.dll");
|
||||
typedef BOOL (WINAPI *SHGetPathFromIDListEx_f)(PCIDLIST_ABSOLUTE pidl, PWSTR pszPath, DWORD cchPath, GPFIDL_FLAGS uOpts);
|
||||
SHGetPathFromIDListEx_f SHGetPathFromIDListEx_ = nullptr;
|
||||
if (shell32)
|
||||
SHGetPathFromIDListEx_ = (SHGetPathFromIDListEx_f)GetProcAddress(shell32, "SHGetPathFromIDListEx");
|
||||
|
||||
std::string result;
|
||||
if (SHGetPathFromIDListEx_) {
|
||||
std::wstring temp;
|
||||
do {
|
||||
// Assume it's failing if it goes on too long.
|
||||
if (temp.size() > 32768 * 10) {
|
||||
temp.clear();
|
||||
break;
|
||||
}
|
||||
temp.resize(temp.size() + MAX_PATH);
|
||||
} while (SHGetPathFromIDListEx_(idList, &temp[0], (DWORD)temp.size(), GPFIDL_DEFAULT) == 0);
|
||||
result = ConvertWStringToUTF8(temp);
|
||||
} else {
|
||||
wchar_t temp[MAX_PATH]{};
|
||||
SHGetPathFromIDList(idList, temp);
|
||||
result = ConvertWStringToUTF8(temp);
|
||||
}
|
||||
|
||||
CoTaskMemFree(idList);
|
||||
return result;
|
||||
}
|
||||
|
||||
std::string BrowseForFolder(HWND parent, std::string_view title, std::string_view initialPath) {
|
||||
std::wstring titleString = ConvertUTF8ToWString(title);
|
||||
return BrowseForFolder(parent, titleString.c_str(), initialPath);
|
||||
}
|
||||
|
||||
|
||||
bool BrowseForFileName(bool _bLoad, HWND _hParent, const wchar_t *_pTitle,
|
||||
const wchar_t *_pInitialFolder, const wchar_t *_pFilter, const wchar_t *_pExtension,
|
||||
std::string &_strFileName) {
|
||||
|
|
|
@ -9,10 +9,6 @@ class Path;
|
|||
|
||||
namespace W32Util {
|
||||
|
||||
// Can't make initialPath a string_view, need the null so might as well require it.
|
||||
std::string BrowseForFolder(HWND parent, std::string_view title, std::string_view initialPath);
|
||||
std::string BrowseForFolder(HWND parent, const wchar_t *title, std::string_view initialPath);
|
||||
// Modern dialog
|
||||
std::string BrowseForFolder2(HWND parent, std::string_view title, std::string_view initialPath);
|
||||
|
||||
bool BrowseForFileName(bool _bLoad, HWND _hParent, const wchar_t*_pTitle,
|
||||
|
|
Loading…
Add table
Reference in a new issue