diff options
author | 杨宇千 <crupest@outlook.com> | 2019-09-07 21:47:01 +0800 |
---|---|---|
committer | 杨宇千 <crupest@outlook.com> | 2019-09-07 21:47:01 +0800 |
commit | 78c00a8329dcabf86b30f5510bd6dfd3a4c141a1 (patch) | |
tree | f0ee60e8201e4c542fe8fb8c8799d3d4376516be /include/cru/platform | |
parent | 04367ead7027e9f0359d24681f5cc0dd916b934d (diff) | |
download | cru-78c00a8329dcabf86b30f5510bd6dfd3a4c141a1.tar.gz cru-78c00a8329dcabf86b30f5510bd6dfd3a4c141a1.tar.bz2 cru-78c00a8329dcabf86b30f5510bd6dfd3a4c141a1.zip |
Add cursor.
Diffstat (limited to 'include/cru/platform')
-rw-r--r-- | include/cru/platform/native/cursor.hpp | 37 | ||||
-rw-r--r-- | include/cru/platform/native/ui_applicaition.hpp | 4 |
2 files changed, 41 insertions, 0 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 |