ImGuiManager: Add Begin/EndTextInput()
This commit is contained in:
parent
55c5e17fdc
commit
272aa4f933
|
@ -234,8 +234,7 @@ bool QtHost::SaveGameSettings(SettingsInterface* sif, bool delete_if_empty)
|
||||||
// to read it at the same time.
|
// to read it at the same time.
|
||||||
const auto lock = Host::GetSettingsLock();
|
const auto lock = Host::GetSettingsLock();
|
||||||
|
|
||||||
if (FileSystem::FileExists(ini->GetPath().c_str()) &&
|
if (FileSystem::FileExists(ini->GetPath().c_str()) && !FileSystem::DeleteFile(ini->GetPath().c_str(), &error))
|
||||||
!FileSystem::DeleteFile(ini->GetPath().c_str(), &error))
|
|
||||||
{
|
{
|
||||||
Host::ReportErrorAsync(
|
Host::ReportErrorAsync(
|
||||||
TRANSLATE_SV("QtHost", "Error"),
|
TRANSLATE_SV("QtHost", "Error"),
|
||||||
|
@ -1647,6 +1646,25 @@ void Host::OpenHostFileSelectorAsync(std::string_view title, bool select_directo
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Host::BeginTextInput()
|
||||||
|
{
|
||||||
|
DEV_LOG("Host::BeginTextInput()");
|
||||||
|
|
||||||
|
// NOTE: Called on GPU thread.
|
||||||
|
QInputMethod* method = qApp->inputMethod();
|
||||||
|
if (method)
|
||||||
|
QMetaObject::invokeMethod(method, "show", Qt::QueuedConnection);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Host::EndTextInput()
|
||||||
|
{
|
||||||
|
DEV_LOG("Host::EndTextInput()");
|
||||||
|
|
||||||
|
QInputMethod* method = qApp->inputMethod();
|
||||||
|
if (method)
|
||||||
|
QMetaObject::invokeMethod(method, "hide", Qt::QueuedConnection);
|
||||||
|
}
|
||||||
|
|
||||||
bool Host::CreateAuxiliaryRenderWindow(s32 x, s32 y, u32 width, u32 height, std::string_view title,
|
bool Host::CreateAuxiliaryRenderWindow(s32 x, s32 y, u32 width, u32 height, std::string_view title,
|
||||||
std::string_view icon_name, AuxiliaryRenderWindowUserData userdata,
|
std::string_view icon_name, AuxiliaryRenderWindowUserData userdata,
|
||||||
AuxiliaryRenderWindowHandle* handle, WindowInfo* wi, Error* error)
|
AuxiliaryRenderWindowHandle* handle, WindowInfo* wi, Error* error)
|
||||||
|
|
|
@ -370,6 +370,16 @@ void Host::ReleaseRenderWindow()
|
||||||
//
|
//
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Host::BeginTextInput()
|
||||||
|
{
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
|
void Host::EndTextInput()
|
||||||
|
{
|
||||||
|
//
|
||||||
|
}
|
||||||
|
|
||||||
bool Host::CreateAuxiliaryRenderWindow(s32 x, s32 y, u32 width, u32 height, std::string_view title,
|
bool Host::CreateAuxiliaryRenderWindow(s32 x, s32 y, u32 width, u32 height, std::string_view title,
|
||||||
std::string_view icon_name, AuxiliaryRenderWindowUserData userdata,
|
std::string_view icon_name, AuxiliaryRenderWindowUserData userdata,
|
||||||
AuxiliaryRenderWindowHandle* handle, WindowInfo* wi, Error* error)
|
AuxiliaryRenderWindowHandle* handle, WindowInfo* wi, Error* error)
|
||||||
|
|
|
@ -119,6 +119,7 @@ static Timer s_last_render_time;
|
||||||
// cached copies of WantCaptureKeyboard/Mouse, used to know when to dispatch events
|
// cached copies of WantCaptureKeyboard/Mouse, used to know when to dispatch events
|
||||||
static std::atomic_bool s_imgui_wants_keyboard{false};
|
static std::atomic_bool s_imgui_wants_keyboard{false};
|
||||||
static std::atomic_bool s_imgui_wants_mouse{false};
|
static std::atomic_bool s_imgui_wants_mouse{false};
|
||||||
|
static std::atomic_bool s_imgui_wants_text{false};
|
||||||
|
|
||||||
// mapping of host key -> imgui key
|
// mapping of host key -> imgui key
|
||||||
static std::unordered_map<u32, ImGuiKey> s_imgui_key_map;
|
static std::unordered_map<u32, ImGuiKey> s_imgui_key_map;
|
||||||
|
@ -375,6 +376,16 @@ void ImGuiManager::NewFrame()
|
||||||
ImGui::GetCurrentWindowRead()->Flags |= ImGuiWindowFlags_NoNavInputs;
|
ImGui::GetCurrentWindowRead()->Flags |= ImGuiWindowFlags_NoNavInputs;
|
||||||
s_imgui_wants_keyboard.store(io.WantCaptureKeyboard, std::memory_order_relaxed);
|
s_imgui_wants_keyboard.store(io.WantCaptureKeyboard, std::memory_order_relaxed);
|
||||||
s_imgui_wants_mouse.store(io.WantCaptureMouse, std::memory_order_release);
|
s_imgui_wants_mouse.store(io.WantCaptureMouse, std::memory_order_release);
|
||||||
|
|
||||||
|
const bool wants_text_input = io.WantTextInput;
|
||||||
|
if (s_imgui_wants_text.load(std::memory_order_relaxed) != wants_text_input)
|
||||||
|
{
|
||||||
|
s_imgui_wants_text.store(wants_text_input, std::memory_order_release);
|
||||||
|
if (wants_text_input)
|
||||||
|
Host::BeginTextInput();
|
||||||
|
else
|
||||||
|
Host::EndTextInput();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImGuiManager::SetStyle(ImGuiStyle& style, float scale)
|
void ImGuiManager::SetStyle(ImGuiStyle& style, float scale)
|
||||||
|
|
|
@ -230,6 +230,13 @@ void RemoveKeyedOSDMessage(std::string key);
|
||||||
void RemoveKeyedOSDWarning(std::string key);
|
void RemoveKeyedOSDWarning(std::string key);
|
||||||
void ClearOSDMessages(bool clear_warnings);
|
void ClearOSDMessages(bool clear_warnings);
|
||||||
|
|
||||||
|
/// Called by ImGuiManager when the cursor enters a text field. The host may choose to open an on-screen
|
||||||
|
/// keyboard for devices without a physical keyboard.
|
||||||
|
void BeginTextInput();
|
||||||
|
|
||||||
|
/// Called by ImGuiManager when the cursor leaves a text field.
|
||||||
|
void EndTextInput();
|
||||||
|
|
||||||
#ifndef __ANDROID__
|
#ifndef __ANDROID__
|
||||||
|
|
||||||
/// Auxiliary window management.
|
/// Auxiliary window management.
|
||||||
|
|
Loading…
Reference in New Issue