blob: 7edf4a1d77b6aa3d0474164add3e5d35ec08730e (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
|
#include "cru/ui/controls/RootControl.hpp"
#include "cru/common/Base.hpp"
#include "cru/platform/gui/Base.hpp"
#include "cru/platform/gui/Window.hpp"
#include "cru/ui/host/WindowHost.hpp"
#include "cru/ui/render/Base.hpp"
#include "cru/ui/render/StackLayoutRenderObject.hpp"
#include "gsl/pointers"
#include <memory>
namespace cru::ui::controls {
RootControl::RootControl(Control* attached_control)
: attached_control_(attached_control) {
render_object_ = std::make_unique<render::StackLayoutRenderObject>();
render_object_->SetAttachedControl(this);
SetContainerRenderObject(render_object_.get());
window_host_ = std::make_unique<host::WindowHost>(this);
}
RootControl::~RootControl() {}
render::RenderObject* RootControl::GetRenderObject() const {
return render_object_.get();
}
platform::gui::INativeWindow* RootControl::GetNativeWindow() {
return window_host_->GetNativeWindow();
}
void RootControl::SetGainFocusOnCreateAndDestroyWhenLoseFocus(bool value) {
gain_focus_on_create_and_destroy_when_lose_focus_event_guard_.Clear();
if (value) {
auto native_window = window_host_->GetNativeWindow();
gain_focus_on_create_and_destroy_when_lose_focus_event_guard_ +=
native_window->VisibilityChangeEvent()->AddHandler(
[native_window](platform::gui::WindowVisibilityType type) {
if (type == platform::gui::WindowVisibilityType::Show) {
native_window->RequestFocus();
}
});
gain_focus_on_create_and_destroy_when_lose_focus_event_guard_ +=
native_window->FocusEvent()->AddHandler(
[native_window](platform::gui::FocusChangeType type) {
if (type == platform::gui::FocusChangeType::Lose) {
native_window->Close();
}
});
}
}
} // namespace cru::ui::controls
|