aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/native/ui_application.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2019-06-27 17:02:58 +0800
committercrupest <crupest@outlook.com>2019-06-27 17:02:58 +0800
commitb53527fbe50a953ad0e3225cc812eb76b8a1f82d (patch)
treeeb81cd14d0a165c47f841ad94835f8987109de7e /include/cru/win/native/ui_application.hpp
parent8c5b05bcfce96495b4ffc4209ab8feda12597729 (diff)
downloadcru-b53527fbe50a953ad0e3225cc812eb76b8a1f82d.tar.gz
cru-b53527fbe50a953ad0e3225cc812eb76b8a1f82d.tar.bz2
cru-b53527fbe50a953ad0e3225cc812eb76b8a1f82d.zip
...
Diffstat (limited to 'include/cru/win/native/ui_application.hpp')
-rw-r--r--include/cru/win/native/ui_application.hpp69
1 files changed, 69 insertions, 0 deletions
diff --git a/include/cru/win/native/ui_application.hpp b/include/cru/win/native/ui_application.hpp
new file mode 100644
index 00000000..08a9c3ed
--- /dev/null
+++ b/include/cru/win/native/ui_application.hpp
@@ -0,0 +1,69 @@
+#pragma once
+#include "../win_pre_config.hpp"
+
+#include "platform_id.hpp"
+
+#include "cru/platform/native/ui_applicaition.hpp"
+
+#include <memory>
+
+namespace cru::platform::native::win {
+class GodWindow;
+class TimerManager;
+class WindowManager;
+
+class WinUiApplication : public UiApplication {
+ friend UiApplication* UiApplication::CreateInstance();
+
+ public:
+ static WinUiApplication* GetInstance();
+
+ private:
+ explicit WinUiApplication(HINSTANCE h_instance);
+
+ public:
+ WinUiApplication(const WinUiApplication&) = delete;
+ WinUiApplication(WinUiApplication&&) = delete;
+ WinUiApplication& operator=(const WinUiApplication&) = delete;
+ WinUiApplication& operator=(WinUiApplication&&) = delete;
+ ~WinUiApplication() override;
+
+ CRU_PLATFORMID_IMPLEMENT_WIN
+
+ public:
+ int Run() override;
+ void Quit(int quit_code) override;
+
+ void AddOnQuitHandler(const std::function<void()>& handler) override;
+
+ void InvokeLater(const std::function<void()>& action) override;
+ unsigned long SetTimeout(std::chrono::milliseconds milliseconds,
+ const std::function<void()>& action) override;
+ unsigned long SetInterval(std::chrono::milliseconds milliseconds,
+ const std::function<void()>& action) override;
+ void CancelTimer(unsigned long id) override;
+
+ std::vector<NativeWindow*> GetAllWindow() override;
+ NativeWindow* CreateWindow(NativeWindow* parent) override;
+
+ bool IsAutoDelete() const { return auto_delete_; }
+ void SetAutoDelete(bool value) { auto_delete_ = value; }
+
+ HINSTANCE GetInstanceHandle() const { return h_instance_; }
+
+ GodWindow* GetGodWindow() const { return god_window_.get(); }
+ TimerManager* GetTimerManager() const { return timer_manager_.get(); }
+ WindowManager* GetWindowManager() const { return window_manager_.get(); }
+
+ private:
+ bool auto_delete_ = false;
+
+ HINSTANCE h_instance_;
+
+ std::shared_ptr<GodWindow> god_window_;
+ std::shared_ptr<TimerManager> timer_manager_;
+ std::shared_ptr<WindowManager> window_manager_;
+
+ std::vector<std::function<void()>> quit_handlers_;
+};
+} // namespace cru::platform::native::win