From 39c0b5ad6814db9e46ac2cb4ab64a37e0e19749b Mon Sep 17 00:00:00 2001 From: crupest Date: Thu, 16 Apr 2020 16:22:50 +0800 Subject: ... --- include/cru/win/native/input_method.hpp | 56 +++++++++++++++++++++++---------- include/cru/win/native/window.hpp | 2 ++ 2 files changed, 42 insertions(+), 16 deletions(-) (limited to 'include/cru/win') diff --git a/include/cru/win/native/input_method.hpp b/include/cru/win/native/input_method.hpp index 7dc9526a..56e678a9 100644 --- a/include/cru/win/native/input_method.hpp +++ b/include/cru/win/native/input_method.hpp @@ -1,5 +1,6 @@ // Some useful information can be found from chromium code: // https://chromium.googlesource.com/chromium/chromium/+/refs/heads/master/ui/base/win/ime_input.h +// https://chromium.googlesource.com/chromium/chromium/+/refs/heads/master/ui/base/win/ime_input.cc #pragma once #include "resource.hpp" @@ -10,23 +11,47 @@ #include namespace cru::platform::native::win { -class WinInputMethodContextRef : public WinNativeResource, - public virtual IInputMethodContextRef { +class AutoHIMC : public Object { public: - WinInputMethodContextRef(WinNativeWindow* window); + explicit AutoHIMC(HWND hwnd); - CRU_DELETE_COPY(WinInputMethodContextRef) - CRU_DELETE_MOVE(WinInputMethodContextRef) + CRU_DELETE_COPY(AutoHIMC) - ~WinInputMethodContextRef() override; + AutoHIMC(AutoHIMC&& other); + AutoHIMC& operator=(AutoHIMC&& other); - ::HIMC GetHandle() const { return handle_; } + ~AutoHIMC() override; + + HWND GetHwnd() const { return hwnd_; } + + HIMC Get() const { return handle_; } + + private: + HWND hwnd_; + HIMC handle_; +}; + +class WinInputMethodContext : public WinNativeResource, + public virtual IInputMethodContext { + public: + WinInputMethodContext(gsl::not_null window); + + CRU_DELETE_COPY(WinInputMethodContext) + CRU_DELETE_MOVE(WinInputMethodContext) + + ~WinInputMethodContext() override; bool ShouldManuallyDrawCompositionText() override { return true; } - void Reset() override; + void EnableIME() override; + + void DisableIME() override; + + void CompleteComposition() override; - std::string GetCompositionText() override; + void CancelComposition() override; + + const CompositionText& GetCompositionText() override; void SetCandidateWindowPosition(const Point& point) override; @@ -34,22 +59,21 @@ class WinInputMethodContextRef : public WinNativeResource, IEvent* CompositionEndEvent() override; - IEvent* CompositionTextChangeEvent() override; + IEvent* CompositionEvent() override; private: void OnWindowNativeMessage(WindowNativeMessageEventArgs& args); + std::optional TryGetHIMC(); + private: - [[maybe_unused]] WinNativeWindow* window_; + std::shared_ptr native_window_resolver_; std::vector event_revoker_guards_; - ::HWND window_handle_; - ::HIMC handle_; - Event composition_start_event_; Event composition_end_event_; - Event composition_text_change_event_; + Event composition_event_; }; class WinInputMethodManager : public WinNativeResource, @@ -63,7 +87,7 @@ class WinInputMethodManager : public WinNativeResource, ~WinInputMethodManager() override; public: - std::unique_ptr GetContext( + std::unique_ptr GetContext( INativeWindow* window) override; }; } // namespace cru::platform::native::win diff --git a/include/cru/win/native/window.hpp b/include/cru/win/native/window.hpp index 2129895c..45f1f16a 100644 --- a/include/cru/win/native/window.hpp +++ b/include/cru/win/native/window.hpp @@ -177,4 +177,6 @@ class WinNativeWindowResolver : public WinNativeResource, private: WinNativeWindow* window_; }; + +WinNativeWindow* Resolve(gsl::not_null resolver); } // namespace cru::platform::native::win -- cgit v1.2.3