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/win/native | |
parent | 04367ead7027e9f0359d24681f5cc0dd916b934d (diff) | |
download | cru-78c00a8329dcabf86b30f5510bd6dfd3a4c141a1.tar.gz cru-78c00a8329dcabf86b30f5510bd6dfd3a4c141a1.tar.bz2 cru-78c00a8329dcabf86b30f5510bd6dfd3a4c141a1.zip |
Add cursor.
Diffstat (limited to 'include/cru/win/native')
-rw-r--r-- | include/cru/win/native/cursor.hpp | 51 | ||||
-rw-r--r-- | include/cru/win/native/ui_application.hpp | 9 |
2 files changed, 58 insertions, 2 deletions
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 |