#if defined(Hiro_HorizontalLayout) auto mHorizontalLayout::append(sSizable sizable, Size size, float spacing) -> type& { properties.append({size.width(), size.height(), spacing < 0 ? settings.spacing : spacing}); mLayout::append(sizable); return *this; } auto mHorizontalLayout::modify(sSizable sizable, Size size, float spacing) -> type& { if(sizable && this->sizable(sizable->offset()) == sizable) { auto& properties = this->properties[sizable->offset()]; properties.setWidth(size.width()); properties.setHeight(size.height()); properties.setSpacing(spacing); } return *this; } auto mHorizontalLayout::minimumSize() const -> Size { float width = 0, height = 0; for(auto n : range(sizableCount())) { auto& child = properties[sizable(n)->offset()]; if(child.width() == Size::Minimum || child.width() == Size::Maximum) { width += sizable(n)->minimumSize().width(); } else { width += child.width(); } if(&child != &properties.right()) width += child.spacing(); } for(auto n : range(sizableCount())) { auto& child = properties[sizable(n)->offset()]; if(child.height() == Size::Minimum || child.height() == Size::Maximum) { height = max(height, sizable(n)->minimumSize().height()); continue; } height = max(height, child.height()); } return { settings.padding.x() + width + settings.padding.width(), settings.padding.y() + height + settings.padding.height() }; } auto mHorizontalLayout::remove(sSizable sizable) -> type& { properties.remove(sizable->offset()); mLayout::remove(sizable); return *this; } auto mHorizontalLayout::reset() -> type& { mLayout::reset(); properties.reset(); return *this; } auto mHorizontalLayout::setAlignment(float alignment) -> type& { settings.alignment = max(0.0, min(1.0, alignment)); return *this; } auto mHorizontalLayout::setEnabled(bool enabled) -> type& { mLayout::setEnabled(enabled); for(auto n : range(sizableCount())) { sizable(n)->setEnabled(sizable(n)->enabled()); } return *this; } auto mHorizontalLayout::setFont(const Font& font) -> type& { mLayout::setFont(font); for(auto n : range(sizableCount())) { sizable(n)->setFont(sizable(n)->font()); } return *this; } auto mHorizontalLayout::setGeometry(Geometry containerGeometry) -> type& { mLayout::setGeometry(containerGeometry); auto properties = this->properties; for(auto n : range(sizableCount())) { auto& child = properties[sizable(n)->offset()]; if(child.width() == Size::Minimum) child.setWidth(sizable(n)->minimumSize().width()); if(child.height() == Size::Minimum) child.setHeight(sizable(n)->minimumSize().height()); } Geometry geometry = containerGeometry; geometry.setX (geometry.x() + settings.padding.x()); geometry.setY (geometry.y() + settings.padding.y()); geometry.setWidth (geometry.width() - settings.padding.x() - settings.padding.width()); geometry.setHeight(geometry.height() - settings.padding.y() - settings.padding.height()); float minimumWidth = 0, maximumWidthCounter = 0; for(auto& child : properties) { if(child.width() == Size::Maximum) maximumWidthCounter++; if(child.width() != Size::Maximum) minimumWidth += child.width(); if(&child != &properties.right()) minimumWidth += child.spacing(); } for(auto& child : properties) { if(child.width() == Size::Maximum) child.setWidth((geometry.width() - minimumWidth) / maximumWidthCounter); if(child.height() == Size::Maximum) child.setHeight(geometry.height()); } float maximumHeight = 0; for(auto& child : properties) maximumHeight = max(maximumHeight, child.height()); for(auto n : range(sizableCount())) { auto& child = properties[sizable(n)->offset()]; float pivot = (maximumHeight - child.height()) * settings.alignment; Geometry childGeometry = {geometry.x(), geometry.y() + pivot, child.width(), child.height()}; if(childGeometry.width() < 1) childGeometry.setWidth (1); if(childGeometry.height() < 1) childGeometry.setHeight(1); sizable(n)->setGeometry(childGeometry); geometry.setX (geometry.x() + child.width() + child.spacing()); geometry.setWidth(geometry.width() - child.width() + child.spacing()); } return *this; } auto mHorizontalLayout::setMargin(float margin) -> type& { setPadding({margin, margin, margin, margin}); return *this; } auto mHorizontalLayout::setPadding(Geometry padding) -> type& { settings.padding = padding; setGeometry(geometry()); return *this; } auto mHorizontalLayout::setSpacing(float spacing) -> type& { settings.spacing = spacing; setGeometry(geometry()); return *this; } auto mHorizontalLayout::setVisible(bool visible) -> type& { mLayout::setVisible(visible); for(auto n : range(sizableCount())) { sizable(n)->setVisible(sizable(n)->visible()); } return *this; } #endif