9663972932
Change-Id: I4cfb369d21097ff49a53ebfc52ca57cab7c8049b Reviewed-on: https://review.haiku-os.org/c/haiku/+/2443 Reviewed-by: Adrien Destugues <pulkomandy@gmail.com>
573 lines
14 KiB
Plaintext
573 lines
14 KiB
Plaintext
/*
|
|
* Copyright 2020 Haiku, Inc. All rights reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*
|
|
* Authors:
|
|
* Niels Sascha Reedijk, niels.reedijk@gmail.com
|
|
*
|
|
* Reviewers:
|
|
* Adrien Destugues, pulkomandy@pulkomandy.tk
|
|
*
|
|
* Corresponds to:
|
|
* headers/os/interface/SplitView.h hrev49977
|
|
* src/kits/interface/SplitView.cpp hrev43279
|
|
*/
|
|
|
|
|
|
/*!
|
|
\file SplitView.h
|
|
\ingroup layout
|
|
\ingroup libbe
|
|
\brief Provides the BSplitView class.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\class BSplitView
|
|
\ingroup layout
|
|
\ingroup libbe
|
|
\brief A container with two or more sections, with dividers in between,
|
|
so that a user can manipulate the size of the sections by dragging
|
|
a slider.
|
|
|
|
This container view consists one of more items, that are laid out
|
|
horizontally or vertically. Between two adjoining items, there is a
|
|
splitter. This splitter allows the user to change how the space between the
|
|
individual items is divided.
|
|
|
|
The screenshot below shows the BSplitView being used in HaikuDepot. The
|
|
BSplitView is the main container of the window, in this case with a
|
|
\ref B_VERTICAL layout. The top part contains the list of packages, and
|
|
some filter tools. At the bottom are individual package details. In between
|
|
the two visual elements there is a dotted line, indicating the draggable
|
|
separator. At the right hand of this separator, above the \b Install
|
|
button, you can see that the mouse cursor changed into the double arrow,
|
|
indicating the user that the element is dragable.
|
|
|
|
\image html BSplitView_HaikuDepot.png
|
|
|
|
Because of the dynamic nature of the size of the sections within the
|
|
split view, it is best to use this container with the \link layout layout
|
|
system\endlink. It is fully supported by the layout builder utilities. See
|
|
the \ref BLayoutBuilder::Split<> documentation for the builder that
|
|
accompanies this view.
|
|
|
|
The container has the following properties:
|
|
- \b Insets are the padding for the split view.
|
|
- \b Spacing is the spacing between the components.
|
|
- \b Orientation is whether the splits are horizontal or vertical.
|
|
- \b Splitter \b size is the size of the splitter.
|
|
|
|
Specifically for individual elements, the following properties may also
|
|
be set:
|
|
- \b Weight for the weight of the item within the split view (determines
|
|
how space is allocated between the items).
|
|
- \b Collapsible determines if an element is collapsible, meaning the user
|
|
can drag the splitter as such as to hide the item completely. If an item
|
|
is not collapsible, at least a part of the item will always be visible
|
|
to the user.
|
|
|
|
\related The \ref BGroupView essentially has the same properties for
|
|
organizing the layout items, though it does not offer the functionality
|
|
for users to change the size of the elements.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BSplitView::BSplitView(orientation orientation=B_HORIZONTAL, float spacing=B_USE_DEFAULT_SPACING)
|
|
\brief Creates a new split view.
|
|
|
|
\param orientation The orientation of the splits.
|
|
\param spacing The spacing in between the elements.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn BSplitView::BSplitView(BMessage *from)
|
|
\brief Unarchive a split view.
|
|
|
|
\param from The \ref BMessage that contains the split view.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual BSplitView::~BSplitView()
|
|
\brief Destructor.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetInsets(float left, float top, float right, float bottom)
|
|
\brief Set the insets between the bounds of the view and the inner
|
|
elements.
|
|
|
|
\param left The left inset.
|
|
\param top The top inset.
|
|
\param right The right inset.
|
|
\param bottom The bottom inset.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetInsets(float horizontal, float vertical)
|
|
\brief Set the insets between the bounds of the view and the inner
|
|
elements.
|
|
|
|
\param horizontal The left and right inset.
|
|
\param vertical The top and bottom inset.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetInsets(float insets)
|
|
\brief Set the insets between the bounds of the view and the inner
|
|
elements.
|
|
|
|
\param insets The value for the left, top, right and bottom inset.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::GetInsets(float *left, float *top, float *right, float *bottom) const
|
|
\brief Get the insets that apply to this view.
|
|
|
|
You may pass \c NULL for any of the parameters, if you do not wish to
|
|
retrieve their value.
|
|
|
|
\param[out] left Will be set to the left inset.
|
|
\param[out] top Will be set to the top inset.
|
|
\param[out] right Will be set to the right inset.
|
|
\param[out] bottom Will be set to the bottom inset.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BSplitView::Spacing() const
|
|
\brief Get the spacing between elements in this view.
|
|
|
|
\return The spacing between elements as a \c float.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetSpacing(float spacing)
|
|
\brief Set the spacing between elements in this view.
|
|
|
|
\param spacing The desired spacing between elements. This will apply to all
|
|
elements.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn orientation BSplitView::Orientation() const
|
|
\brief Get the orientation of the elements in this view.
|
|
|
|
\retval B_HORIZONTAL The elements are ordered left-to-right.
|
|
\retval B_VERTICAL The elements are ordered top-to-bottom.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetOrientation(orientation orientation)
|
|
\brief Set the orientation of the elements in this view.
|
|
|
|
\param orientation May be \ref B_HORIZONTAL or \ref B_VERTICAL.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BSplitView::SplitterSize() const
|
|
\brief Get the size of the splitter(s) in this view.
|
|
|
|
\return The size of the splitter(s).
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetSplitterSize(float size)
|
|
\brief Set the size of the splitter(s) in this view.
|
|
|
|
\param size The size as a \c float that will be applied to all splitters
|
|
in this view.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn int32 BSplitView::CountItems() const
|
|
\brief The number of items in this view.
|
|
|
|
\return Returns the number of items in this view. The splitters themselves
|
|
are not included in this number.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BSplitView::ItemWeight(int32 index) const
|
|
\brief Get the item weight for the item at the \a index.
|
|
|
|
\param index The index of the item (zero-based).
|
|
|
|
\return The weight of the item, or \c 0.0 if there is no item at \a index.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn float BSplitView::ItemWeight(BLayoutItem *item) const
|
|
\brief Get the item weight for an existing \a item.
|
|
|
|
\param item An existing layout item object.
|
|
|
|
\return The weight of the \a item, or \c 0.0 if the item is not associated
|
|
with this view.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetItemWeight(int32 index, float weight, bool invalidateLayout)
|
|
\brief Set the weight of the item at \a index.
|
|
|
|
The weight is relative to all other items in the layout, and determines how
|
|
the available space is distributed over the items in the layout.
|
|
|
|
\param index The index of the item (zero-based).
|
|
\param weight The weight of the item.
|
|
\param invalidateLayout When \c true, calls
|
|
\ref BLayout::InvalidateLayout() to recalculate the layout.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetItemWeight(BLayoutItem *item, float weight)
|
|
\brief Set the weight of the \a item.
|
|
|
|
The weight is relative to all other items in the layout, and determines how
|
|
the available space is distributed over the items in the layout.
|
|
|
|
\param item The item within this view that the weight applies to.
|
|
\param weight The weight of the item.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::IsCollapsible(int32 index) const
|
|
\brief Get whether the item at \a index is collapsible.
|
|
|
|
\param index The index of the item (zero-based).
|
|
|
|
\retval true The user can collapse the item.
|
|
\retval false The user cannot collapse the item.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetCollapsible(bool collapsible)
|
|
\brief Set the whether all the layout items in this view are collapsible.
|
|
|
|
\param collapsible \c true if all items in this layout are collapsible,
|
|
\c false if they are not.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetCollapsible(int32 index, bool collapsible)
|
|
\brief Set whether the item at \a index is collapsible.
|
|
|
|
\param index The index of the item (zero-based).
|
|
\param collapsible \c true if the user may collaps the item, \c false if
|
|
they may not.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetCollapsible(int32 first, int32 last, bool collapsible)
|
|
\brief Set whether the items from \a first to \a last are collapsible.
|
|
|
|
\param first The index of the first item that you want the setting to apply
|
|
to (zero-based).
|
|
\param last The index of the last item that you want the setting to apply
|
|
to (zero-based).
|
|
\param collapsible \c true if the user may collaps the item, \c false if
|
|
they may not.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::IsItemCollapsed(int32 index) const
|
|
\brief Check whether the item at \a index is collapsed.
|
|
|
|
\param index The index of the item (zero-based).
|
|
|
|
\retval true The item is collapsed.
|
|
\retval false The item is not collapsed.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::SetItemCollapsed(int32 index, bool collapsed)
|
|
\brief Set whether the item at \a index is displayed as collapsed.
|
|
|
|
\param index The index of the item (zero-based).
|
|
\param collapsed \c true if the item should be rendered collapsed, \c
|
|
false if it needs to be visible.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn void BSplitView::AddChild(BView *child, BView *sibling=NULL)
|
|
\brief Add a \a child to the view.
|
|
|
|
Passthrough for \ref BView::AddChild(BView *child, BView *sibling). This
|
|
bypasses the layout system, so only use it when you know what you are
|
|
doing.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::AddChild(BView *child, float weight)
|
|
\brief Add a \a child with a \a weight.
|
|
|
|
The view will be added at the end of the existing layout items, meaning it
|
|
will be placed to the right or bottom of existing items.
|
|
|
|
\param child The view that should be added as a child. The ownership is
|
|
transferred to this view.
|
|
\param weight The weight of the item.
|
|
|
|
\return \c true when succesfully, \c false if there was an error.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::AddChild(int32 index, BView *child, float weight)
|
|
\brief Add a \a child at \a index with a \a weight.
|
|
|
|
\param index The desired position for the \a child. Existing items will be
|
|
shifted to the right or down based on the orientation. If the index is
|
|
higher than the number of items, the item will be added after farmost
|
|
item. The index is zero-based.
|
|
\param child The view that should be added as a child. The ownership is
|
|
transferred to this view.
|
|
\param weight The weight of the item.
|
|
|
|
\return \c true when succesfully, \c false if there was an error.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::AddChild(BLayoutItem *child)
|
|
\brief Add a \a child.
|
|
|
|
The child will be added at the end of the existing layout items, meaning it
|
|
will be placed to the right or bottom of existing items.
|
|
|
|
\param child The layout item to add.
|
|
|
|
\return \c true when succesfully, \c false if there was an error.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::AddChild(BLayoutItem *child, float weight)
|
|
\brief Add a \a child with a \a weight.
|
|
|
|
The child will be added at the end of the existing layout items, meaning it
|
|
will be placed to the right or bottom of existing items.
|
|
|
|
\param child The layout item to add.
|
|
\param weight The weight of the item.
|
|
|
|
\return \c true when succesfully, \c false if there was an error.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn bool BSplitView::AddChild(int32 index, BLayoutItem *child, float weight)
|
|
\brief Add a \a child at \a index with a \a weight.
|
|
|
|
\param index The desired position for the \a child. Existing items will be
|
|
shifted to the right or down based on the orientation. If the index is
|
|
higher than the number of items, the item will be added after farmost
|
|
item. The index is zero-based.
|
|
\param child The layout item to add.
|
|
\param weight The weight of the item.
|
|
|
|
\return \c true when succesfully, \c false if there was an error.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::AttachedToWindow()
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::Draw(BRect updateRect)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::DrawAfterChildren(BRect updateRect)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::MouseDown(BPoint where)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::MouseUp(BPoint where)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::MouseMoved(BPoint where, uint32 transit, const BMessage *message)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::MessageReceived(BMessage *message)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::SetLayout(BLayout *layout)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual status_t BSplitView::Archive(BMessage *into, bool deep=true) const
|
|
\copydoc BArchivable::Archive()
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual status_t BSplitView::Perform(perform_code d, void *arg)
|
|
\brief Hook method overridden from BView.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn static static BArchivable* BSplitView::Instantiate(BMessage *from)
|
|
\brief Instantiate the view from the message \a from.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual status_t BSplitView::AllArchived(BMessage *into) const
|
|
\brief Hook method overridden from BArchivable.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual status_t BSplitView::AllUnarchived(const BMessage *from)
|
|
\brief Hook method overridden from BArchivable.
|
|
|
|
\since Haiku R1
|
|
*/
|
|
|
|
|
|
/*!
|
|
\fn virtual virtual void BSplitView::DrawSplitter(BRect frame, const BRect &updateRect, orientation orientation, bool pressed)
|
|
\brief Hook method called when the splitter needs to be drawn.
|
|
|
|
This method is called in the context of a \ref BView::Draw() operation.
|
|
Derived classes can override this to draw a splitter.
|
|
|
|
\since Haiku R1
|
|
*/
|