aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/gui/WindowNativeMessageEventArgs.h
diff options
context:
space:
mode:
Diffstat (limited to 'include/cru/win/gui/WindowNativeMessageEventArgs.h')
-rw-r--r--include/cru/win/gui/WindowNativeMessageEventArgs.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/include/cru/win/gui/WindowNativeMessageEventArgs.h b/include/cru/win/gui/WindowNativeMessageEventArgs.h
new file mode 100644
index 00000000..bc85a597
--- /dev/null
+++ b/include/cru/win/gui/WindowNativeMessageEventArgs.h
@@ -0,0 +1,40 @@
+#pragma once
+#include "Base.h"
+
+#include "cru/common/Base.h"
+
+namespace cru::platform::gui::win {
+struct CRU_WIN_GUI_API WindowNativeMessage {
+ HWND hwnd;
+ UINT msg;
+ WPARAM w_param;
+ LPARAM l_param;
+};
+
+class CRU_WIN_GUI_API WindowNativeMessageEventArgs : public Object {
+ public:
+ WindowNativeMessageEventArgs(const WindowNativeMessage& message)
+ : message_(message) {}
+ CRU_DEFAULT_COPY(WindowNativeMessageEventArgs)
+ CRU_DEFAULT_MOVE(WindowNativeMessageEventArgs)
+ ~WindowNativeMessageEventArgs() override = default;
+
+ const WindowNativeMessage& GetWindowMessage() const { return message_; }
+
+ LRESULT GetResult() const { return result_; }
+ void SetResult(LRESULT result) { result_ = result; }
+
+ bool IsHandled() const { return handled_; }
+ void SetHandled(bool handled) { handled_ = handled; }
+
+ void HandleWithResult(LRESULT result) {
+ handled_ = true;
+ result_ = result;
+ }
+
+ private:
+ WindowNativeMessage message_;
+ LRESULT result_;
+ bool handled_ = false;
+};
+} // namespace cru::platform::gui::win