2011-08-09 21:46:13 +00:00
|
|
|
/*
|
2013-02-06 21:05:00 -05:00
|
|
|
* Copyright 2010 Haiku, Inc. All rights reserved.
|
2011-08-09 21:46:13 +00:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
2013-02-06 21:05:00 -05:00
|
|
|
* Authors:
|
|
|
|
* Alex Wilson, yourpalal2@gmail.com
|
2020-04-18 07:27:42 +01:00
|
|
|
* Niels Sascha Reedijk, niels.reedijk@gmail.com
|
2013-02-06 21:05:00 -05:00
|
|
|
*
|
2011-08-09 21:46:13 +00:00
|
|
|
* Corresponds to:
|
2020-04-18 07:27:42 +01:00
|
|
|
* headers/os/interface/TwoDimensionalLayout.h rev 45833
|
|
|
|
* src/kits/interface/TwoDimensionalLayout.cpp rev 49507
|
2011-08-09 21:46:13 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\file TwoDimensionalLayout.h
|
2013-02-06 21:05:00 -05:00
|
|
|
\ingroup layout
|
|
|
|
\ingroup libbe
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Defines the BTwoDimensionalLayout class.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2010-10-23 02:33:08 +00:00
|
|
|
/*!
|
|
|
|
\class BTwoDimensionalLayout
|
|
|
|
\ingroup layout
|
|
|
|
\ingroup libbe
|
|
|
|
\brief Abstract BLayout subclass arranging items within rows and columns.
|
|
|
|
|
|
|
|
This class manages all the tricky work of actually positioning/resizing
|
|
|
|
items, as well as calculating size constraints and providing extra features,
|
2011-08-09 21:46:13 +00:00
|
|
|
such as spacing/insets and alignment of multiple
|
|
|
|
BTwoDimensionalLayout's. Derived classes need only implement a few hook
|
|
|
|
methods to get a working layout.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
\warning This class is not yet finalized, if you use it in your software
|
|
|
|
assume that it will break some time in the future.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\struct BTwoDimensionalLayout::ColumnRowConstraints
|
|
|
|
\brief Used by BTwoDimensionalLayout derived classes to communicate the
|
2014-06-13 17:25:02 -04:00
|
|
|
size constraints for a given column or row to the
|
|
|
|
BTwoDimensionalLayout class.
|
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2020-04-18 07:27:42 +01:00
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::ColumnRowConstraints::weight
|
|
|
|
\brief The weight of the given column or row.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::ColumnRowConstraints::min
|
|
|
|
\brief The minimum size of the given column or row.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::ColumnRowConstraints::max
|
|
|
|
\brief The maximum size of the given column or row.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2010-10-23 02:33:08 +00:00
|
|
|
/*!
|
|
|
|
\struct BTwoDimensionalLayout::Dimensions
|
|
|
|
\brief Used by BTwoDimensionalLayout derived classes to communicate the
|
2014-06-13 17:25:02 -04:00
|
|
|
positioning and size of a BLayoutItem, in terms of columns and rows
|
|
|
|
to the BTwoDimensionalLayout class.
|
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2020-04-18 07:27:42 +01:00
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::Dimensions::x
|
|
|
|
\brief The column of the layout item.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::Dimensions::y
|
|
|
|
\brief The row of the layout item.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::Dimensions::width
|
|
|
|
\brief The number of columns the layout item spans.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var BTwoDimensionalLayout::Dimensions::height
|
|
|
|
\brief The number of rows the layout item spans.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn BTwoDimensionalLayout::BTwoDimensionalLayout()
|
|
|
|
\brief Create an empty layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn BTwoDimensionalLayout::BTwoDimensionalLayout(BMessage* from)
|
|
|
|
\brief Unarchive constructor.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn virtual BTwoDimensionalLayout::~BTwoDimensionalLayout()
|
|
|
|
\brief Destructor.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2010-10-23 02:33:08 +00:00
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::AlignLayoutWith(
|
2013-07-08 18:27:55 -04:00
|
|
|
BTwoDimensionalLayout* other, orientation orientation)
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Align the BLayoutItem's in the specified \a orientation within
|
2014-06-13 17:25:02 -04:00
|
|
|
two or more BTwoDimensionalLayout's.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
2011-08-09 21:46:13 +00:00
|
|
|
When two (or more) BTwoDimensionalLayout's are aligned within a
|
|
|
|
certain \a orientation, then the BLayoutItem's within those
|
|
|
|
BTwoDimensionalLayout's will have identical widths or heights
|
|
|
|
(depending on how the BTwoDimensionalLayout's are aligned.)
|
2010-10-23 02:33:08 +00:00
|
|
|
|
2011-08-09 21:46:13 +00:00
|
|
|
If you align two BGroupLayout's horizontally for example, then the
|
|
|
|
BLayoutItem at index 0 in both BGroupLayout's will be given the same
|
|
|
|
horizontal area. The same is true for the BLayoutItem at index 1,
|
|
|
|
2, etc. Not all BTwoDimensionalLayout's have to have an item at each
|
|
|
|
index for the alignment to proceed.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
\param other The BTwoDimensionalLayout to be aligned with.
|
2011-08-09 21:46:13 +00:00
|
|
|
\param orientation The \a orientation on which to be aligned.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::SetInsets(float left, float top,
|
|
|
|
float right, float bottom)
|
2020-04-18 07:27:42 +01:00
|
|
|
\brief Set the insets for this layout.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
2020-04-18 07:27:42 +01:00
|
|
|
Set the spacing around the edges of this layout. If you pass
|
|
|
|
\c B_USE_DEFAULT_SPACING for a certain parameter, that parameter will
|
2010-10-23 02:33:08 +00:00
|
|
|
be replaced with the value returned by BControlLook::DefaultItemSpacing().
|
|
|
|
|
2020-04-18 07:27:42 +01:00
|
|
|
\since Haiku R1
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::SetInsets(float horizontal, float vertical)
|
|
|
|
\brief Set the insets for this layout.
|
|
|
|
|
|
|
|
This is a convenience method to easily set similar insets.
|
|
|
|
|
|
|
|
\param horizontal The insets to the \em left and \em right of the layout.
|
|
|
|
\param vertical The insets at the \em top and \em bottom of the layout.
|
|
|
|
|
|
|
|
\since Haiku R1
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::SetInsets(float insets)
|
|
|
|
\brief Set the insets for this layout.
|
|
|
|
|
|
|
|
This is a convenience method that to easily set all the insets of the
|
|
|
|
layout to the same value.
|
|
|
|
|
|
|
|
\param insets The inset to be applied to \em left, \em top, \em right and
|
|
|
|
\em bottom of this layout.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::GetInsets(float* left, float* top,
|
|
|
|
float* right, float* bottom) const
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Get the insets for the BTwoDimensionalLayout (in pixels).
|
2010-10-23 02:33:08 +00:00
|
|
|
|
2011-08-09 21:46:13 +00:00
|
|
|
Passing \c NULL for any parameter is not an error, those parameters will
|
2010-10-23 02:33:08 +00:00
|
|
|
be ignored.
|
|
|
|
|
|
|
|
\see BTwoDimensionalLayout::SetInsets();
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2014-06-13 17:25:02 -04:00
|
|
|
\name Hook Methods
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
These methods are called automatically as needed during layout, and
|
|
|
|
provide the BTwoDimensionalLayout class with the necessary information
|
2011-08-09 21:46:13 +00:00
|
|
|
to properly layout the BLayoutItem in this BTwoDimensionalLayout.
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2011-08-09 21:46:13 +00:00
|
|
|
//! @{
|
|
|
|
|
|
|
|
|
2010-10-23 02:33:08 +00:00
|
|
|
/*!
|
2013-07-08 18:27:55 -04:00
|
|
|
\fn void BTwoDimensionalLayout::PrepareItems(orientation orientation)
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Prepare the BLayoutItem in this BTwoDimensionalLayout subclass
|
2014-06-13 17:25:02 -04:00
|
|
|
for layout within a certain \a orientation.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
This is a good place to update cache information that will be used in
|
|
|
|
other hook methods, for example.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn bool BTwoDimensionalLayout::HasMultiColumnItems()
|
|
|
|
\brief Tests whether or not this BTwoDimensionalLayout contains any
|
2014-06-13 17:25:02 -04:00
|
|
|
BLayoutItem's spanning more than one column.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
The BTwoDimensionalLayout implementation returns false.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn bool BTwoDimensionalLayout::HasMultiRowItems()
|
|
|
|
\brief Tests whether or not this BTwoDimensionalLayout contains any
|
2014-06-13 17:25:02 -04:00
|
|
|
BLayoutItem's spanning more than one row.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
The BTwoDimensionalLayout implementation returns false.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn int32 BTwoDimensionalLayout::InternalCountColumns()
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Get the number of columns in the BTwoDimensionalLayout.
|
|
|
|
|
|
|
|
\returns The number of columns in the BTwoDimensionalLayout.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn int32 BTwoDimensionalLayout::InternalCountRows()
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Get the number of rows in the BTwoDimensionalLayout.
|
|
|
|
|
|
|
|
\returns The number of rows in the BTwoDimensionalLayout.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
2013-07-08 18:27:55 -04:00
|
|
|
\fn void BTwoDimensionalLayout::GetColumnRowConstraints(
|
|
|
|
orientation orientation, int32 index, ColumnRowConstraints* constraints)
|
2010-10-23 02:33:08 +00:00
|
|
|
\brief Fill in the ColumnRowConstraints for a certain column or row in
|
2014-06-13 17:25:02 -04:00
|
|
|
the BTwoDimensionalLayout.
|
2010-10-23 02:33:08 +00:00
|
|
|
|
|
|
|
This method is used to communicate the size constraints and weight for
|
2011-08-09 21:46:13 +00:00
|
|
|
a given row/column in the BTwoDimensionalLayout.
|
2014-06-13 17:25:02 -04:00
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::GetItemDimensions(BLayoutItem* item,
|
|
|
|
Dimensions* dimensions)
|
2011-08-09 21:46:13 +00:00
|
|
|
\brief Tell the base class what column and row a BLayoutItem is in as
|
2014-06-13 17:25:02 -04:00
|
|
|
well as how many columns and rows it covers.
|
|
|
|
|
|
|
|
\since Haiku R1
|
2010-10-23 02:33:08 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2011-08-09 21:46:13 +00:00
|
|
|
//! @}
|
2020-04-18 07:27:42 +01:00
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\name Protected helper methods for inset calculation.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn BSize BTwoDimensionalLayout::AddInsets(BSize size)
|
|
|
|
\brief Add the \a size to all the insets for this layout.
|
|
|
|
|
|
|
|
\since Haiku R1
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn void BTwoDimensionalLayout::AddInsets(float* minHeight,
|
|
|
|
float* maxHeight, float* preferredHeight)
|
|
|
|
\brief Add to the insets, and store the modified values.
|
|
|
|
|
|
|
|
\param[out] minHeight The value to add to the minimum height for this
|
|
|
|
layout. The new minimum height is stored at the variable of this
|
|
|
|
pointer.
|
|
|
|
\param[out] maxHeight The value to add to the maximum height for this
|
|
|
|
layout. The new maximum height is stored at the variable of this
|
|
|
|
pointer.
|
|
|
|
\param[out] preferredHeight the value to add to the preferred height for
|
|
|
|
this layout. The new preferred heifght is stored at the variable of
|
|
|
|
this pointer.
|
|
|
|
|
|
|
|
\since Haiku R1
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\fn BSize BTwoDimensionalLayout::SubtractInsets(BSize size)
|
|
|
|
\brief Substract the \a size from all the insets for this layout.
|
|
|
|
|
|
|
|
\since Haiku R1
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//! @}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\name Current settings for spacing
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//! @{
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var float BTwoDimensionalLayout::fLeftInset
|
|
|
|
\brief The current left inset for this layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var float BTwoDimensionalLayout::fRightInset
|
|
|
|
\brief The current right inset for this layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var float BTwoDimensionalLayout::fTopInset
|
|
|
|
\brief The current top inset for this layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var float BTwoDimensionalLayout::fBottomInset
|
|
|
|
\brief The current bottom inset for this layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var float BTwoDimensionalLayout::fHSpacing
|
|
|
|
\brief the current horizontal spacing between columns for this layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\var float BTwoDimensionalLayout::fVSpacing
|
|
|
|
\brief The current vertical spacing between rows for this layout.
|
|
|
|
*/
|
|
|
|
|
|
|
|
//! @}
|