diff options
author | crupest <crupest@outlook.com> | 2020-11-09 20:06:04 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2020-11-09 20:06:04 +0800 |
commit | 68fc33443981fcd499dfe263c228787e213ae943 (patch) | |
tree | 6a11d424a958d9c566e4c0b85b32212bfad9a1dc /include/cru/ui/controls/RootControl.hpp | |
parent | ddc6d6478f849ef10b832bc8b1d8ab7fe9454601 (diff) | |
download | cru-68fc33443981fcd499dfe263c228787e213ae943.tar.gz cru-68fc33443981fcd499dfe263c228787e213ae943.tar.bz2 cru-68fc33443981fcd499dfe263c228787e213ae943.zip |
...
Diffstat (limited to 'include/cru/ui/controls/RootControl.hpp')
-rw-r--r-- | include/cru/ui/controls/RootControl.hpp | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/include/cru/ui/controls/RootControl.hpp b/include/cru/ui/controls/RootControl.hpp new file mode 100644 index 00000000..ff1b545a --- /dev/null +++ b/include/cru/ui/controls/RootControl.hpp @@ -0,0 +1,40 @@ +#pragma once +#include "LayoutControl.hpp" + +#include "cru/common/Base.hpp" +#include "cru/platform/gui/Base.hpp" +#include "cru/ui/Base.hpp" + +namespace cru::ui::controls { +class RootControl : public LayoutControl { + protected: + explicit RootControl(Control* attached_control); + + public: + CRU_DELETE_COPY(RootControl) + CRU_DELETE_MOVE(RootControl) + ~RootControl() override; + + public: + render::RenderObject* GetRenderObject() const override; + + // If create is false and native window is not create, it will not be created + // and shown. + void Show(bool create = true); + + protected: + virtual gsl::not_null<platform::gui::INativeWindow*> CreateNativeWindow( + gsl::not_null<host::WindowHost*> host, + platform::gui::INativeWindow* parent) = 0; + + private: + platform::gui::INativeWindow* GetNativeWindow(bool create); + + private: + std::unique_ptr<host::WindowHost> window_host_; + + std::unique_ptr<render::StackLayoutRenderObject> render_object_; + + Control* attached_control_; +}; +} // namespace cru::ui::controls |