aboutsummaryrefslogtreecommitdiff
path: root/src/win/gui/WindowManager.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-03-24 19:14:19 +0800
committercrupest <crupest@outlook.com>2021-03-24 19:14:19 +0800
commit7f15a1ff9a2007e119798053083a0a87d042990a (patch)
treecb35c01a7eaee867376d959b96c9bbd15df939e5 /src/win/gui/WindowManager.hpp
parent74956951ee663012df0c3fe4ebe29799cb2f7732 (diff)
parent7703063a5816b089483e78ccd74bb9902ccfbea8 (diff)
downloadcru-7f15a1ff9a2007e119798053083a0a87d042990a.tar.gz
cru-7f15a1ff9a2007e119798053083a0a87d042990a.tar.bz2
cru-7f15a1ff9a2007e119798053083a0a87d042990a.zip
Merge branch 'master' of https://github.com/crupest/CruUI
Diffstat (limited to 'src/win/gui/WindowManager.hpp')
-rw-r--r--src/win/gui/WindowManager.hpp51
1 files changed, 51 insertions, 0 deletions
diff --git a/src/win/gui/WindowManager.hpp b/src/win/gui/WindowManager.hpp
new file mode 100644
index 00000000..3b037f89
--- /dev/null
+++ b/src/win/gui/WindowManager.hpp
@@ -0,0 +1,51 @@
+#pragma once
+#include "cru/win/WinPreConfig.hpp"
+
+#include "cru/common/Base.hpp"
+
+#include <map>
+#include <memory>
+#include <vector>
+
+namespace cru::platform::gui::win {
+class WinUiApplication;
+class WinNativeWindow;
+class WindowClass;
+
+class WindowManager : public Object {
+ public:
+ WindowManager(WinUiApplication* application);
+
+ CRU_DELETE_COPY(WindowManager)
+ CRU_DELETE_MOVE(WindowManager)
+
+ ~WindowManager() override;
+
+ // Get the general window class for creating ordinary window.
+ WindowClass* GetGeneralWindowClass() const {
+ return general_window_class_.get();
+ }
+
+ // Register a window newly created.
+ // This function adds the hwnd to hwnd-window map.
+ // It should be called immediately after a window was created.
+ void RegisterWindow(HWND hwnd, WinNativeWindow* window);
+
+ // Unregister a window that is going to be destroyed.
+ // This function removes the hwnd from the hwnd-window map.
+ // It should be called immediately before a window is going to be destroyed,
+ void UnregisterWindow(HWND hwnd);
+
+ // Return a pointer to the Window object related to the HWND or nullptr if the
+ // hwnd is not in the map.
+ WinNativeWindow* FromHandle(HWND hwnd);
+
+ std::vector<WinNativeWindow*> GetAllWindows() const;
+
+ private:
+ WinUiApplication* application_;
+
+ std::unique_ptr<WindowClass> general_window_class_;
+ std::map<HWND, WinNativeWindow*> window_map_;
+};
+} // namespace cru::platform::gui::win