mirror of https://github.com/axmolengine/axmol.git
475 lines
14 KiB
C++
475 lines
14 KiB
C++
/****************************************************************************
|
|
Copyright (c) 2013-2016 Chukong Technologies Inc.
|
|
Copyright (c) 2017-2018 Xiamen Yaji Software Co., Ltd.
|
|
Copyright (c) 2019-present Axmol Engine contributors (see AUTHORS.md).
|
|
|
|
https://axmolengine.github.io/
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
in the Software without restriction, including without limitation the rights
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
all copies or substantial portions of the Software.
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
THE SOFTWARE.
|
|
****************************************************************************/
|
|
|
|
#ifndef __UILISTVIEW_H__
|
|
#define __UILISTVIEW_H__
|
|
|
|
#include "ui/UIScrollView.h"
|
|
#include "ui/GUIExport.h"
|
|
|
|
/**
|
|
* @addtogroup ui
|
|
* @{
|
|
*/
|
|
NS_AX_BEGIN
|
|
|
|
namespace ui
|
|
{
|
|
|
|
/**
|
|
*@brief ListView is a view group that displays a list of scrollable items.
|
|
*The list items are inserted to the list by using `addChild` or `insertDefaultItem`.
|
|
* @warning The list item in ListView doesn't support cell reuse at the moment, if you have a large amount of data need
|
|
*to be displayed, use `TableView` instead. ListView is a subclass of `ScrollView`, so it shares many features of
|
|
*ScrollView.
|
|
*/
|
|
class AX_GUI_DLL ListView : public ScrollView
|
|
{
|
|
|
|
DECLARE_CLASS_GUI_INFO
|
|
public:
|
|
/**
|
|
* Gravity for docking elements in ListView.
|
|
*/
|
|
enum class Gravity
|
|
{
|
|
LEFT,
|
|
RIGHT,
|
|
CENTER_HORIZONTAL,
|
|
TOP,
|
|
BOTTOM,
|
|
CENTER_VERTICAL
|
|
};
|
|
|
|
/**
|
|
* ListView element item click event.
|
|
*/
|
|
enum class EventType
|
|
{
|
|
ON_SELECTED_ITEM_START,
|
|
ON_SELECTED_ITEM_END
|
|
};
|
|
|
|
/**
|
|
* ListView supports magnetic scroll.
|
|
* With CENTER type, ListView tries to align its items in center of current view.
|
|
* With BOTH_END type, ListView tries to align its items in left or right end if it is horizontal, top or bottom in
|
|
* vertical. The aligning side (left or right, top or bottom) is determined by user's scroll direction.
|
|
*/
|
|
enum class MagneticType
|
|
{
|
|
NONE,
|
|
CENTER,
|
|
BOTH_END,
|
|
LEFT,
|
|
RIGHT,
|
|
TOP,
|
|
BOTTOM,
|
|
};
|
|
|
|
/**
|
|
* ListView item click callback.
|
|
*/
|
|
typedef std::function<void(Object*, EventType)> ccListViewCallback;
|
|
|
|
/**
|
|
* Default constructor
|
|
* @js ctor
|
|
* @lua new
|
|
*/
|
|
ListView();
|
|
|
|
/**
|
|
* Default destructor
|
|
* @js NA
|
|
* @lua NA
|
|
*/
|
|
~ListView() override;
|
|
|
|
/**
|
|
* Create an empty ListView.
|
|
*@return A ListView instance.
|
|
*/
|
|
static ListView* create();
|
|
|
|
/**
|
|
* Set an item model for listview.
|
|
*
|
|
* When calling `pushBackDefaultItem`, the model will be used as a blueprint and new model copy will be inserted
|
|
* into ListView.
|
|
* @param model Model in `Widget*`.
|
|
*/
|
|
void setItemModel(Widget* model);
|
|
|
|
/**
|
|
* Insert a default item(create by a cloned model) at the end of the listview.
|
|
*/
|
|
void pushBackDefaultItem();
|
|
|
|
/**
|
|
* Insert a default item(create by cloning model) into listview at a give index.
|
|
*@param index An index in ssize_t.
|
|
*/
|
|
void insertDefaultItem(ssize_t index);
|
|
|
|
/**
|
|
* Insert a custom item into the end of ListView.
|
|
*@param item An item in `Widget*`.
|
|
*/
|
|
void pushBackCustomItem(Widget* item);
|
|
|
|
/**
|
|
* @brief Insert a custom widget into ListView at a given index.
|
|
*
|
|
* @param item A widget pointer to be inserted.
|
|
* @param index A given index in ssize_t.
|
|
*/
|
|
void insertCustomItem(Widget* item, ssize_t index);
|
|
|
|
/**
|
|
* Removes the last item of ListView.
|
|
*/
|
|
void removeLastItem();
|
|
|
|
/**
|
|
* Remove an item at given index.
|
|
*
|
|
* @param index A given index in ssize_t.
|
|
*/
|
|
void removeItem(ssize_t index);
|
|
|
|
/**
|
|
* @brief Remove all items in current ListView.
|
|
*
|
|
|
|
*/
|
|
void removeAllItems();
|
|
|
|
/**
|
|
* Return an item at a given index.
|
|
*
|
|
* @param index A given index in ssize_t.
|
|
* @return A widget instance.
|
|
*/
|
|
Widget* getItem(ssize_t index) const;
|
|
|
|
/**
|
|
* Return all items in a ListView.
|
|
*@returns A vector of widget pointers.
|
|
*/
|
|
Vector<Widget*>& getItems();
|
|
|
|
/**
|
|
* Return the index of specified widget.
|
|
*
|
|
* @param item A widget pointer.
|
|
* @return The index of a given widget in ListView.
|
|
*/
|
|
ssize_t getIndex(Widget* item) const;
|
|
|
|
/**
|
|
* Set the gravity of ListView.
|
|
* @see `ListViewGravity`
|
|
*/
|
|
void setGravity(Gravity gravity);
|
|
|
|
/**
|
|
* Set magnetic type of ListView.
|
|
* @see `MagneticType`
|
|
*/
|
|
void setMagneticType(MagneticType magneticType);
|
|
|
|
/**
|
|
* Get magnetic type of ListView.
|
|
*/
|
|
MagneticType getMagneticType() const;
|
|
|
|
/**
|
|
* Set magnetic allowed out of boundary.
|
|
*/
|
|
void setMagneticAllowedOutOfBoundary(bool magneticAllowedOutOfBoundary);
|
|
|
|
/**
|
|
* Query whether the magnetic out of boundary is allowed.
|
|
*/
|
|
bool getMagneticAllowedOutOfBoundary() const;
|
|
|
|
/**
|
|
* Set the margin between each item in ListView.
|
|
*
|
|
* @param margin A margin in float.
|
|
*/
|
|
void setItemsMargin(float margin);
|
|
|
|
/**
|
|
* @brief Query margin between each item in ListView.
|
|
*
|
|
|
|
* @return A margin in float.
|
|
*/
|
|
float getItemsMargin() const;
|
|
|
|
/**
|
|
* Change padding with left, top, right, and bottom padding.
|
|
* @param l Left padding in float.
|
|
* @param t Top margin in float.
|
|
* @param r Right margin in float.
|
|
* @param b Bottom margin in float.
|
|
*/
|
|
void setPadding(float l, float t, float r, float b);
|
|
|
|
/**
|
|
* Change padding with left padding
|
|
* @param l Left padding in float.
|
|
*/
|
|
void setLeftPadding(float l);
|
|
|
|
/**
|
|
* Change padding with top padding
|
|
* @param t Top padding in float
|
|
*/
|
|
void setTopPadding(float t);
|
|
|
|
/**
|
|
* Change padding with right padding
|
|
* @param r Right padding in float
|
|
*/
|
|
void setRightPadding(float r);
|
|
|
|
/**
|
|
* Change padding with bottom padding
|
|
* @param b Bottom padding in float
|
|
*/
|
|
void setBottomPadding(float b);
|
|
|
|
/**
|
|
* Get the left padding in ListView
|
|
* @return Left padding in float
|
|
*/
|
|
float getLeftPadding() const;
|
|
|
|
/**
|
|
* Get the top padding in ListView
|
|
* @return Top padding in float
|
|
*/
|
|
float getTopPadding() const;
|
|
|
|
/**
|
|
* Get the right padding in ListView
|
|
* @return Right padding in float
|
|
*/
|
|
float getRightPadding() const;
|
|
|
|
/**
|
|
* Get the bottom padding in ListView
|
|
* @return Bottom padding in float
|
|
*/
|
|
float getBottomPadding() const;
|
|
|
|
// override methods
|
|
void doLayout() override;
|
|
void requestDoLayout() override;
|
|
void addChild(Node* child) override;
|
|
void addChild(Node* child, int localZOrder) override;
|
|
void addChild(Node* child, int zOrder, int tag) override;
|
|
void addChild(Node* child, int zOrder, std::string_view name) override;
|
|
void removeAllChildren() override;
|
|
void removeAllChildrenWithCleanup(bool cleanup) override;
|
|
void removeChild(Node* child, bool cleanup = true) override;
|
|
|
|
/**
|
|
* @brief Query the closest item to a specific position in inner container.
|
|
*
|
|
* @param targetPosition Specifies the target position in inner container's coordinates.
|
|
* @param itemAnchorPoint Specifies an anchor point of each item for position to calculate distance.
|
|
* @return An item instance if list view is not empty. Otherwise, returns null.
|
|
*/
|
|
Widget* getClosestItemToPosition(const Vec2& targetPosition, const Vec2& itemAnchorPoint) const;
|
|
|
|
/**
|
|
* @brief Query the closest item to a specific position in current view.
|
|
* For instance, to find the item in the center of view, call
|
|
* 'getClosestItemToPositionInCurrentView(Vec2::ANCHOR_MIDDLE, Vec2::ANCHOR_MIDDLE)'.
|
|
*
|
|
* @param positionRatioInView Specifies the target position with ratio in list view's content size.
|
|
* @param itemAnchorPoint Specifies an anchor point of each item for position to calculate distance.
|
|
* @return An item instance if list view is not empty. Otherwise, returns null.
|
|
*/
|
|
Widget* getClosestItemToPositionInCurrentView(const Vec2& positionRatioInView, const Vec2& itemAnchorPoint) const;
|
|
|
|
/**
|
|
* @brief Query the center item
|
|
* @return An item instance.
|
|
*/
|
|
Widget* getCenterItemInCurrentView() const;
|
|
|
|
/**
|
|
* @brief Query the leftmost item in horizontal list
|
|
* @return An item instance.
|
|
*/
|
|
Widget* getLeftmostItemInCurrentView() const;
|
|
|
|
/**
|
|
* @brief Query the rightmost item in horizontal list
|
|
* @return An item instance.
|
|
*/
|
|
Widget* getRightmostItemInCurrentView() const;
|
|
|
|
/**
|
|
* @brief Query the topmost item in horizontal list
|
|
* @return An item instance.
|
|
*/
|
|
Widget* getTopmostItemInCurrentView() const;
|
|
|
|
/**
|
|
* @brief Query the bottommost item in horizontal list
|
|
* @return An item instance.
|
|
*/
|
|
Widget* getBottommostItemInCurrentView() const;
|
|
|
|
/**
|
|
* Override functions
|
|
*/
|
|
void jumpToBottom() override;
|
|
void jumpToTop() override;
|
|
void jumpToLeft() override;
|
|
void jumpToRight() override;
|
|
void jumpToTopLeft() override;
|
|
void jumpToTopRight() override;
|
|
void jumpToBottomLeft() override;
|
|
void jumpToBottomRight() override;
|
|
void jumpToPercentVertical(float percent) override;
|
|
void jumpToPercentHorizontal(float percent) override;
|
|
void jumpToPercentBothDirection(const Vec2& percent) override;
|
|
|
|
/**
|
|
* @brief Jump to specific item
|
|
* @param itemIndex Specifies the item's index
|
|
* @param positionRatioInView Specifies the position with ratio in list view's content size.
|
|
* @param itemAnchorPoint Specifies an anchor point of each item for position to calculate distance.
|
|
*/
|
|
void jumpToItem(ssize_t itemIndex, const Vec2& positionRatioInView, const Vec2& itemAnchorPoint);
|
|
|
|
/**
|
|
* @brief Scroll to specific item
|
|
* @param positionRatioInView Specifies the position with ratio in list view's content size.
|
|
* @param itemAnchorPoint Specifies an anchor point of each item for position to calculate distance.
|
|
*/
|
|
void scrollToItem(ssize_t itemIndex, const Vec2& positionRatioInView, const Vec2& itemAnchorPoint);
|
|
|
|
/**
|
|
* @brief Scroll to specific item
|
|
* @param positionRatioInView Specifies the position with ratio in list view's content size.
|
|
* @param itemAnchorPoint Specifies an anchor point of each item for position to calculate distance.
|
|
* @param timeInSec Scroll time
|
|
*/
|
|
void scrollToItem(ssize_t itemIndex, const Vec2& positionRatioInView, const Vec2& itemAnchorPoint, float timeInSec);
|
|
|
|
/**
|
|
* @brief Query current selected widget's index.
|
|
*
|
|
* @return An index of a selected item.
|
|
*/
|
|
ssize_t getCurSelectedIndex() const;
|
|
|
|
/**
|
|
* @brief Set current selected widget's index and call TouchEventType::ENDED event.
|
|
* @param itemIndex A index of a selected item.
|
|
*/
|
|
void setCurSelectedIndex(int itemIndex);
|
|
|
|
/**
|
|
* Add an event click callback to ListView, then one item of Listview is clicked, the callback will be called.
|
|
*@param callback A callback function with type of `ccListViewCallback`.
|
|
*/
|
|
void addEventListener(const ccListViewCallback& callback);
|
|
using ScrollView::addEventListener;
|
|
|
|
/**
|
|
* Changes scroll direction of scrollview.
|
|
*
|
|
* Direction Direction::VERTICAL means vertical scroll, Direction::HORIZONTAL means horizontal scroll.
|
|
* @param dir Set the list view's scroll direction.
|
|
*/
|
|
void setDirection(Direction dir) override;
|
|
|
|
std::string getDescription() const override;
|
|
|
|
bool init() override;
|
|
|
|
protected:
|
|
void handleReleaseLogic(Touch* touch) override;
|
|
|
|
virtual void onItemListChanged();
|
|
|
|
virtual void remedyLayoutParameter(Widget* item);
|
|
void updateInnerContainerSize();
|
|
void remedyVerticalLayoutParameter(LinearLayoutParameter* layoutParameter, ssize_t itemIndex);
|
|
void remedyHorizontalLayoutParameter(LinearLayoutParameter* layoutParameter, ssize_t itemIndex);
|
|
|
|
void onSizeChanged() override;
|
|
Widget* createCloneInstance() override;
|
|
void copySpecialProperties(Widget* model) override;
|
|
void copyClonedWidgetChildren(Widget* model) override;
|
|
void selectedItemEvent(TouchEventType event);
|
|
void interceptTouchEvent(Widget::TouchEventType event, Widget* sender, Touch* touch) override;
|
|
|
|
Vec2 getHowMuchOutOfBoundary(const Vec2& addition = Vec2::ZERO) override;
|
|
|
|
void startAttenuatingAutoScroll(const Vec2& deltaMove, const Vec2& initialVelocity) override;
|
|
|
|
void startMagneticScroll();
|
|
|
|
protected:
|
|
Widget* _model;
|
|
|
|
Vector<Widget*> _items;
|
|
|
|
Gravity _gravity;
|
|
|
|
MagneticType _magneticType;
|
|
bool _magneticAllowedOutOfBoundary;
|
|
|
|
float _itemsMargin;
|
|
|
|
float _leftPadding;
|
|
float _topPadding;
|
|
float _rightPadding;
|
|
float _bottomPadding;
|
|
|
|
ssize_t _curSelectedIndex;
|
|
|
|
bool _innerContainerDoLayoutDirty;
|
|
ccListViewCallback _eventCallback;
|
|
};
|
|
|
|
} // namespace ui
|
|
NS_AX_END
|
|
// end of ui group
|
|
/// @}
|
|
|
|
#endif /* defined(__ListView__) */
|