aboutsummaryrefslogtreecommitdiff
path: root/include/cru/win/native/UiApplication.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-05-24 01:40:02 +0800
committercrupest <crupest@outlook.com>2020-05-24 01:40:02 +0800
commitd86a71f79afe0e4dac768f61d6bff690567aca5b (patch)
tree4957e9a64c77680deb07201fbd879bf036616dae /include/cru/win/native/UiApplication.hpp
parentf3a8fd608a9776ef0a5f547da918a32cf6074060 (diff)
downloadcru-d86a71f79afe0e4dac768f61d6bff690567aca5b.tar.gz
cru-d86a71f79afe0e4dac768f61d6bff690567aca5b.tar.bz2
cru-d86a71f79afe0e4dac768f61d6bff690567aca5b.zip
...
Diffstat (limited to 'include/cru/win/native/UiApplication.hpp')
-rw-r--r--include/cru/win/native/UiApplication.hpp76
1 files changed, 76 insertions, 0 deletions
diff --git a/include/cru/win/native/UiApplication.hpp b/include/cru/win/native/UiApplication.hpp
new file mode 100644
index 00000000..cbc08af7
--- /dev/null
+++ b/include/cru/win/native/UiApplication.hpp
@@ -0,0 +1,76 @@
+#pragma once
+#include "Resource.hpp"
+
+#include "cru/platform/native/UiApplication.hpp"
+
+#include <memory>
+
+namespace cru::platform::graph::win::direct {
+class DirectGraphFactory;
+}
+
+namespace cru::platform::native::win {
+class WinUiApplication : public WinNativeResource,
+ public virtual IUiApplication {
+ public:
+ static WinUiApplication* GetInstance() { return instance; }
+
+ private:
+ static WinUiApplication* instance;
+
+ public:
+ WinUiApplication();
+
+ CRU_DELETE_COPY(WinUiApplication)
+ CRU_DELETE_MOVE(WinUiApplication)
+
+ ~WinUiApplication() override;
+
+ public:
+ int Run() override;
+ void RequestQuit(int quit_code) override;
+
+ void AddOnQuitHandler(std::function<void()> handler) override;
+
+ void InvokeLater(std::function<void()> action) override;
+ long long SetTimeout(std::chrono::milliseconds milliseconds,
+ std::function<void()> action) override;
+ long long SetInterval(std::chrono::milliseconds milliseconds,
+ std::function<void()> action) override;
+ void CancelTimer(long long id) override;
+
+ std::vector<INativeWindow*> GetAllWindow() override;
+ std::shared_ptr<INativeWindowResolver> CreateWindow(
+ INativeWindow* parent) override;
+
+ cru::platform::graph::IGraphFactory* GetGraphFactory() override;
+
+ cru::platform::graph::win::direct::DirectGraphFactory* GetDirectFactory() {
+ return graph_factory_.get();
+ }
+
+ ICursorManager* GetCursorManager() override;
+ IInputMethodManager* GetInputMethodManager() override;
+
+ HINSTANCE GetInstanceHandle() const { return instance_handle_; }
+
+ GodWindow* GetGodWindow() const { return god_window_.get(); }
+ TimerManager* GetTimerManager() const { return timer_manager_.get(); }
+ WindowManager* GetWindowManager() const { return window_manager_.get(); }
+
+ private:
+ HINSTANCE instance_handle_;
+
+ std::unique_ptr<cru::platform::graph::win::direct::DirectGraphFactory>
+ graph_factory_;
+
+ std::unique_ptr<GodWindow> god_window_;
+ std::unique_ptr<TimerManager> timer_manager_;
+ std::unique_ptr<WindowManager> window_manager_;
+
+ std::unique_ptr<WinCursorManager> cursor_manager_;
+ std::unique_ptr<WinInputMethodManager> input_method_manager_;
+
+ std::vector<std::function<void()>> quit_handlers_;
+};
+} // namespace cru::platform::native::win