|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- /*
- ==============================================================================
-
- This file is part of the JUCE library.
- Copyright (c) 2020 - Raw Material Software Limited
-
- JUCE is an open source library subject to commercial or open-source
- licensing.
-
- By using JUCE, you agree to the terms of both the JUCE 6 End-User License
- Agreement and JUCE Privacy Policy (both effective as of the 16th June 2020).
-
- End User License Agreement: www.juce.com/juce-6-licence
- Privacy Policy: www.juce.com/juce-privacy-policy
-
- Or: You may also use this code under the terms of the GPL v3 (see
- www.gnu.org/licenses).
-
- JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER
- EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE
- DISCLAIMED.
-
- ==============================================================================
- */
-
- namespace juce
- {
-
- /**
- Describes the properties of an item inside a FlexBox container.
-
- @see FlexBox
-
- @tags{GUI}
- */
- class JUCE_API FlexItem final
- {
- public:
- //==============================================================================
- /** Creates an item with default parameters, and zero size. */
- FlexItem() noexcept;
-
- /** Creates an item with the given size. */
- FlexItem (float width, float height) noexcept;
-
- /** Creates an item with the given size and target Component. */
- FlexItem (float width, float height, Component& targetComponent) noexcept;
-
- /** Creates an item that represents an embedded FlexBox with a given size. */
- FlexItem (float width, float height, FlexBox& flexBoxToControl) noexcept;
-
- /** Creates an item with a given target Component. */
- FlexItem (Component& componentToControl) noexcept;
-
- /** Creates an item that represents an embedded FlexBox. This class will not
- create a copy of the supplied flex box. You need to ensure that the
- life-time of flexBoxToControl is longer than the FlexItem. */
- FlexItem (FlexBox& flexBoxToControl) noexcept;
-
- //==============================================================================
- /** The item's current bounds. */
- Rectangle<float> currentBounds;
-
- /** If this is non-null, it represents a Component whose bounds are controlled by this item. */
- Component* associatedComponent = nullptr;
-
- /** If this is non-null, it represents a FlexBox whose bounds are controlled by this item. */
- FlexBox* associatedFlexBox = nullptr;
-
- /** Determines the order used to lay out items in their flex container.
- Elements are laid out in ascending order of thus order value. Elements with the same order value
- are laid out in the order in which they appear in the array.
- */
- int order = 0;
-
- /** Specifies the flex grow factor of this item.
- This indicates the amount of space inside the flex container the item should take up.
- */
- float flexGrow = 0.0f;
-
- /** Specifies the flex shrink factor of the item.
- This indicates the rate at which the item shrinks if there is insufficient space in
- the container.
- */
- float flexShrink = 1.0f;
-
- /** Specifies the flex-basis of the item.
- This is the initial main size of a flex item in the direction of flow. It determines the size
- of the content-box unless specified otherwise using box-sizing.
- */
- float flexBasis = 0.0f;
-
- /** Possible value for the alignSelf property */
- enum class AlignSelf
- {
- autoAlign, /**< Follows the FlexBox container's alignItems property. */
- flexStart, /**< Item is aligned towards the start of the cross axis. */
- flexEnd, /**< Item is aligned towards the end of the cross axis. */
- center, /**< Item is aligned towards the center of the cross axis. */
- stretch /**< Item is stretched from start to end of the cross axis. */
- };
-
- /** This is the align-self property of the item.
- This determines the alignment of the item along the cross-axis (perpendicular to the direction
- of flow).
- */
- AlignSelf alignSelf = AlignSelf::stretch;
-
- //==============================================================================
- /** This constant can be used for sizes to indicate that 'auto' mode should be used. */
- static const int autoValue = -2;
- /** This constant can be used for sizes to indicate that no value has been set. */
- static const int notAssigned = -1;
-
- float width = (float) notAssigned; /**< The item's width. */
- float minWidth = 0.0f; /**< The item's minimum width */
- float maxWidth = (float) notAssigned; /**< The item's maximum width */
-
- float height = (float) notAssigned; /**< The item's height */
- float minHeight = 0.0f; /**< The item's minimum height */
- float maxHeight = (float) notAssigned; /**< The item's maximum height */
-
- /** Represents a margin. */
- struct Margin final
- {
- Margin() noexcept; /**< Creates a margin of size zero. */
- Margin (float size) noexcept; /**< Creates a margin with this size on all sides. */
- Margin (float top, float right, float bottom, float left) noexcept; /**< Creates a margin with these sizes. */
-
- float left; /**< Left margin size */
- float right; /**< Right margin size */
- float top; /**< Top margin size */
- float bottom; /**< Bottom margin size */
- };
-
- /** The margin to leave around this item. */
- Margin margin;
-
- //==============================================================================
- /** Returns a copy of this object with a new flex-grow value. */
- FlexItem withFlex (float newFlexGrow) const noexcept;
-
- /** Returns a copy of this object with new flex-grow and flex-shrink values. */
- FlexItem withFlex (float newFlexGrow, float newFlexShrink) const noexcept;
-
- /** Returns a copy of this object with new flex-grow, flex-shrink and flex-basis values. */
- FlexItem withFlex (float newFlexGrow, float newFlexShrink, float newFlexBasis) const noexcept;
-
- /** Returns a copy of this object with a new width. */
- FlexItem withWidth (float newWidth) const noexcept;
-
- /** Returns a copy of this object with a new minimum width. */
- FlexItem withMinWidth (float newMinWidth) const noexcept;
-
- /** Returns a copy of this object with a new maximum width. */
- FlexItem withMaxWidth (float newMaxWidth) const noexcept;
-
- /** Returns a copy of this object with a new height. */
- FlexItem withHeight (float newHeight) const noexcept;
-
- /** Returns a copy of this object with a new minimum height. */
- FlexItem withMinHeight (float newMinHeight) const noexcept;
-
- /** Returns a copy of this object with a new maximum height. */
- FlexItem withMaxHeight (float newMaxHeight) const noexcept;
-
- /** Returns a copy of this object with a new margin. */
- FlexItem withMargin (Margin) const noexcept;
-
- /** Returns a copy of this object with a new order. */
- FlexItem withOrder (int newOrder) const noexcept;
-
- /** Returns a copy of this object with a new alignSelf value. */
- FlexItem withAlignSelf (AlignSelf newAlignSelf) const noexcept;
- };
-
- } // namespace juce
|