aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/native/win_application.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2019-04-10 19:42:46 +0800
committercrupest <crupest@outlook.com>2019-04-10 19:42:46 +0800
commit7351020a582d70a1495249fba87d342c8a1fb634 (patch)
treee80f225041dc3816b3dce21c7e15aadbb211602e /include/cru/win/native/win_application.hpp
parenta94a806f69586e08a30fff0cdb3e52b0ce7acfa5 (diff)
downloadcru-7351020a582d70a1495249fba87d342c8a1fb634.tar.gz
cru-7351020a582d70a1495249fba87d342c8a1fb634.tar.bz2
cru-7351020a582d70a1495249fba87d342c8a1fb634.zip
Refactor.
Diffstat (limited to 'include/cru/win/native/win_application.hpp')
-rw-r--r--include/cru/win/native/win_application.hpp59
1 files changed, 59 insertions, 0 deletions
diff --git a/include/cru/win/native/win_application.hpp b/include/cru/win/native/win_application.hpp
new file mode 100644
index 00000000..458b10ae
--- /dev/null
+++ b/include/cru/win/native/win_application.hpp
@@ -0,0 +1,59 @@
+#pragma once
+#include "../win_pre_config.hpp"
+
+#include "cru/platform/native/ui_applicaition.hpp"
+
+#include <memory>
+
+namespace cru::win::native {
+class GodWindow;
+class TimerManager;
+class WindowManager;
+
+class WinApplication : public Object,
+ public virtual platform::native::UiApplication {
+ public:
+ static WinApplication* GetInstance();
+
+ private:
+ static WinApplication* instance_;
+
+ private:
+ explicit WinApplication(HINSTANCE h_instance);
+
+ public:
+ WinApplication(const WinApplication&) = delete;
+ WinApplication(WinApplication&&) = delete;
+ WinApplication& operator=(const WinApplication&) = delete;
+ WinApplication& operator=(WinApplication&&) = delete;
+ ~WinApplication() override;
+
+ public:
+ int Run() override;
+ void Quit(int quit_code) 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<platform::native::NativeWindow*> GetAllWindow() override;
+ platform::native::NativeWindow* CreateWindow(
+ platform::native::NativeWindow* parent) override;
+
+ 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:
+ HINSTANCE h_instance_;
+
+ std::shared_ptr<GodWindow> god_window_;
+ std::shared_ptr<TimerManager> timer_manager_;
+ std::shared_ptr<WindowManager> window_manager_;
+};
+} // namespace cru::win::native