aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
Diffstat (limited to 'include')
-rw-r--r--include/cru/platform/native/cursor.hpp37
-rw-r--r--include/cru/platform/native/ui_applicaition.hpp4
-rw-r--r--include/cru/win/native/cursor.hpp51
-rw-r--r--include/cru/win/native/ui_application.hpp9
4 files changed, 99 insertions, 2 deletions
diff --git a/include/cru/platform/native/cursor.hpp b/include/cru/platform/native/cursor.hpp
new file mode 100644
index 00000000..b0ff4494
--- /dev/null
+++ b/include/cru/platform/native/cursor.hpp
@@ -0,0 +1,37 @@
+#pragma once
+
+#include "../native_resource.hpp"
+
+#include <memory>
+
+namespace cru::platform::native {
+class Cursor : public NativeResource {
+ public:
+ Cursor() = default;
+
+ CRU_DELETE_COPY(Cursor)
+ CRU_DELETE_MOVE(Cursor)
+
+ ~Cursor() override = default;
+};
+
+enum class SystemCursor {
+ Arrow,
+ Hand,
+};
+
+class CursorManager : public NativeResource {
+ public:
+ CursorManager() = default;
+
+ CRU_DELETE_COPY(CursorManager)
+ CRU_DELETE_MOVE(CursorManager)
+
+ ~CursorManager() override = default;
+
+ public:
+ virtual std::shared_ptr<Cursor> GetSystemCursor(SystemCursor type) = 0;
+
+ //TODO: Add method to create cursor.
+};
+} // namespace cru::platform::native
diff --git a/include/cru/platform/native/ui_applicaition.hpp b/include/cru/platform/native/ui_applicaition.hpp
index aa8d98da..923fbaf7 100644
--- a/include/cru/platform/native/ui_applicaition.hpp
+++ b/include/cru/platform/native/ui_applicaition.hpp
@@ -1,6 +1,8 @@
#pragma once
#include "../native_resource.hpp"
+#include "cursor.hpp"
+
#include <chrono>
#include <functional>
#include <vector>
@@ -50,5 +52,7 @@ class UiApplication : public NativeResource {
virtual std::vector<NativeWindow*> GetAllWindow() = 0;
virtual NativeWindow* CreateWindow(NativeWindow* parent) = 0;
+
+ virtual CursorManager* GetCursorManager() = 0;
};
} // namespace cru::platform::native
diff --git a/include/cru/win/native/cursor.hpp b/include/cru/win/native/cursor.hpp
new file mode 100644
index 00000000..3ef480ea
--- /dev/null
+++ b/include/cru/win/native/cursor.hpp
@@ -0,0 +1,51 @@
+#pragma once
+#include <memory>
+#include "../win_pre_config.hpp"
+
+#include "cru/common/base.hpp"
+#include "cru/platform/native/cursor.hpp"
+#include "cru/win/native/platform_id.hpp"
+
+namespace cru::platform::native::win {
+class WinCursor : public Cursor {
+ public:
+ WinCursor(HCURSOR handle, bool auto_delete);
+
+ CRU_DELETE_COPY(WinCursor)
+ CRU_DELETE_MOVE(WinCursor)
+
+ ~WinCursor() override;
+
+ CRU_PLATFORMID_IMPLEMENT_WIN
+
+ public:
+ HCURSOR GetHandle() const { return handle_; }
+
+ private:
+ HCURSOR handle_;
+ bool auto_delete_;
+};
+
+class WinCursorManager : public CursorManager {
+ public:
+ WinCursorManager();
+
+ CRU_DELETE_COPY(WinCursorManager)
+ CRU_DELETE_MOVE(WinCursorManager)
+
+ ~WinCursorManager() override = default;
+
+ CRU_PLATFORMID_IMPLEMENT_WIN
+
+ public:
+ std::shared_ptr<WinCursor> GetSystemWinCursor(SystemCursor type);
+
+ std::shared_ptr<Cursor> GetSystemCursor(SystemCursor type) override {
+ return std::static_pointer_cast<Cursor>(GetSystemWinCursor(type));
+ }
+
+ private:
+ std::shared_ptr<WinCursor> sys_arrow_;
+ std::shared_ptr<WinCursor> sys_hand_;
+};
+} // namespace cru::platform::native::win
diff --git a/include/cru/win/native/ui_application.hpp b/include/cru/win/native/ui_application.hpp
index 08a9c3ed..d7da4409 100644
--- a/include/cru/win/native/ui_application.hpp
+++ b/include/cru/win/native/ui_application.hpp
@@ -1,10 +1,11 @@
#pragma once
#include "../win_pre_config.hpp"
-#include "platform_id.hpp"
-
#include "cru/platform/native/ui_applicaition.hpp"
+#include "platform_id.hpp"
+#include "cursor.hpp"
+
#include <memory>
namespace cru::platform::native::win {
@@ -46,6 +47,8 @@ class WinUiApplication : public UiApplication {
std::vector<NativeWindow*> GetAllWindow() override;
NativeWindow* CreateWindow(NativeWindow* parent) override;
+ WinCursorManager* GetCursorManager() override;
+
bool IsAutoDelete() const { return auto_delete_; }
void SetAutoDelete(bool value) { auto_delete_ = value; }
@@ -64,6 +67,8 @@ class WinUiApplication : public UiApplication {
std::shared_ptr<TimerManager> timer_manager_;
std::shared_ptr<WindowManager> window_manager_;
+ std::unique_ptr<WinCursorManager> cursor_manager_;
+
std::vector<std::function<void()>> quit_handlers_;
};
} // namespace cru::platform::native::win