From 37bb421e963662e8203acbe3a03bdbd5d1f5858e Mon Sep 17 00:00:00 2001 From: crupest Date: Sun, 5 Apr 2020 00:04:05 +0800 Subject: ... --- include/cru/win/native/input_method.hpp | 19 +++++++++++++++---- .../win/native/window_native_message_event_args.hpp | 4 ++-- 2 files changed, 17 insertions(+), 6 deletions(-) (limited to 'include/cru/win/native') diff --git a/include/cru/win/native/input_method.hpp b/include/cru/win/native/input_method.hpp index 3ea16709..2e09aac4 100644 --- a/include/cru/win/native/input_method.hpp +++ b/include/cru/win/native/input_method.hpp @@ -2,6 +2,7 @@ #include "resource.hpp" #include "cru/platform/native/input_method.hpp" +#include "window_native_message_event_args.hpp" #include @@ -20,23 +21,33 @@ class WinInputMethodContextRef : public WinNativeResource, ::HIMC GetHandle() const { return handle_; } + bool ShouldManuallyDrawCompositionText() override { return true; } + void Reset() override; - std::string GetCompositionString() override; + std::string GetCompositionText() override; void SetCandidateWindowPosition(const Point& point) override; + IEvent* CompositionStartEvent() override; + + IEvent* CompositionEndEvent() override; + IEvent* CompositionTextChangeEvent() override; - IEvent* CharEvent() override; + private: + void OnWindowNativeMessage(WindowNativeMessageEventArgs& args); private: - WinNativeWindow* window_; + [[maybe_unused]] WinNativeWindow* window_; + + std::vector event_revoker_guards_; ::HWND window_handle_; ::HIMC handle_; + Event composition_start_event_; + Event composition_end_event_; Event composition_text_change_event_; - Event char_event_; }; } // namespace cru::platform::native::win diff --git a/include/cru/win/native/window_native_message_event_args.hpp b/include/cru/win/native/window_native_message_event_args.hpp index 18de1f46..f5476735 100644 --- a/include/cru/win/native/window_native_message_event_args.hpp +++ b/include/cru/win/native/window_native_message_event_args.hpp @@ -19,7 +19,7 @@ class WindowNativeMessageEventArgs : public Object { CRU_DEFAULT_MOVE(WindowNativeMessageEventArgs) ~WindowNativeMessageEventArgs() override = default; - WindowNativeMessage GetWindowMessage() const { return message_; } + const WindowNativeMessage& GetWindowMessage() const { return message_; } LRESULT GetResult() const { return result_; } void SetResult(LRESULT result) { result_ = result; } @@ -27,7 +27,7 @@ class WindowNativeMessageEventArgs : public Object { bool IsHandled() const { return handled_; } void SetHandled(bool handled) { handled_ = handled; } - void HandledAndSetResult(LRESULT result) { + void HandleWithResult(LRESULT result) { handled_ = true; result_ = result; } -- cgit v1.2.3