18class HBox :
public Node {
20 explicit HBox(
Elements children) : Node(std::move(children)) {}
23 void ComputeRequirement()
override {
24 requirement_ = Requirement{};
26 for (
auto& child : children_) {
27 child->ComputeRequirement();
30 if (requirement_.focused.Prefer(child->requirement().focused)) {
31 requirement_.focused = child->requirement().focused;
32 requirement_.focused.box.Shift(requirement_.min_x, 0);
36 requirement_.min_x += child->requirement().min_x;
38 std::max(requirement_.min_y, child->requirement().min_y);
42 void SetBox(Box box)
override {
45 std::vector<box_helper::Element> elements(children_.size());
46 for (
size_t i = 0; i < children_.size(); ++i) {
47 auto& element = elements[i];
48 const auto& requirement = children_[i]->requirement();
49 element.min_size = requirement.min_x;
50 element.flex_grow = requirement.flex_grow_x;
51 element.flex_shrink = requirement.flex_shrink_x;
53 const int target_size = box.x_max - box.x_min + 1;
57 for (
size_t i = 0; i < children_.size(); ++i) {
59 box.x_max = x + elements[i].size - 1;
60 children_[i]->SetBox(box);
65 void Select(Selection& selection)
override {
72 Selection selection_saturated = selection.SaturateHorizontal(box_);
73 for (
auto& child : children_) {
74 child->Select(selection_saturated);
94 return std::make_shared<HBox>(std::move(children));
virtual void SetBox(Box box)
描画のために要素に位置と次元を割り当てます。
static auto Intersection(Box a, Box b) -> Box
void Compute(std::vector< Element > *elements, int target_size)
std::shared_ptr< Node > Element
Element hbox(Elements)
要素を水平方向に1つずつ表示するコンテナ。
std::vector< Element > Elements