aboutsummaryrefslogtreecommitdiff
path: root/src/ui/controls/Window.cpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-11-09 20:06:04 +0800
committercrupest <crupest@outlook.com>2020-11-09 20:06:04 +0800
commit68fc33443981fcd499dfe263c228787e213ae943 (patch)
tree6a11d424a958d9c566e4c0b85b32212bfad9a1dc /src/ui/controls/Window.cpp
parentddc6d6478f849ef10b832bc8b1d8ab7fe9454601 (diff)
downloadcru-68fc33443981fcd499dfe263c228787e213ae943.tar.gz
cru-68fc33443981fcd499dfe263c228787e213ae943.tar.bz2
cru-68fc33443981fcd499dfe263c228787e213ae943.zip
...
Diffstat (limited to 'src/ui/controls/Window.cpp')
-rw-r--r--src/ui/controls/Window.cpp27
1 files changed, 9 insertions, 18 deletions
diff --git a/src/ui/controls/Window.cpp b/src/ui/controls/Window.cpp
index b302cb62..ba66f42e 100644
--- a/src/ui/controls/Window.cpp
+++ b/src/ui/controls/Window.cpp
@@ -2,32 +2,23 @@
#include "cru/common/Base.hpp"
#include "cru/platform/gui/Base.hpp"
+#include "cru/ui/controls/RootControl.hpp"
#include "cru/ui/host/WindowHost.hpp"
#include "cru/ui/render/Base.hpp"
#include "cru/ui/render/StackLayoutRenderObject.hpp"
namespace cru::ui::controls {
-Window* Window::CreateOverlapped() { return new Window(); }
-
-Window::Window() : render_object_(new render::StackLayoutRenderObject()) {
- render_object_->SetAttachedControl(this);
- SetContainerRenderObject(render_object_.get());
- window_host_ = std::make_unique<host::WindowHost>(this);
+Window* Window::Create(Control* attached_control) {
+ return new Window(attached_control);
}
-Window::~Window() {}
-
-std::u16string_view Window::GetControlType() const { return control_type; }
+Window::Window(Control* attached_control) : RootControl(attached_control) {}
-render::RenderObject* Window::GetRenderObject() const {
- return render_object_.get();
-}
+Window::~Window() {}
-void Window::Show(bool create) {
- platform::gui::INativeWindow* native_window =
- create ? window_host_->CreateNativeWindow().get()
- : window_host_->GetNativeWindow();
- if (!native_window) return;
- native_window->SetVisible(true);
+gsl::not_null<platform::gui::INativeWindow*> Window::CreateNativeWindow(
+ gsl::not_null<host::WindowHost*> host,
+ platform::gui::INativeWindow* parent) {
+ return host->CreateNativeWindow({parent});
}
} // namespace cru::ui::controls