X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Fdevel-api%2Flayouting%2Flayout-parent-impl.h;h=7c9414f6245daf1b7272cfa7a0fe748194a82d3d;hb=20125e47f9f183b0d39972ada01280da8984d942;hp=d55fb420e420d53b908fa9d64d51b0b88af6b3d0;hpb=53ec3e12de51d072444f302f901232bb313f98a0;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/devel-api/layouting/layout-parent-impl.h b/dali-toolkit/devel-api/layouting/layout-parent-impl.h index d55fb42..7c9414f 100755 --- a/dali-toolkit/devel-api/layouting/layout-parent-impl.h +++ b/dali-toolkit/devel-api/layouting/layout-parent-impl.h @@ -25,25 +25,52 @@ namespace Toolkit { namespace Internal { +class LayoutItem; /** - * Interface that allows a layout to determine its layout parent. - * - * Needed to prevent circular inheritance - most LayoutBases have a parent, - * but parenting is provided by LayoutGroup, which is a sub-class of LayoutBase. + * Interface that defines a layout Parent. Enables a layout child to access + * methods on its parent, e.g. Remove (during unparenting) */ class DALI_TOOLKIT_API LayoutParent { public: /** - * Set the parent of this layout. + * @brief Add a child to the parent + * @param[in] item The item to add to this layout parent + */ + virtual Toolkit::LayoutGroup::LayoutId Add( LayoutItem& item ) = 0; + + /** + * @brief Remove a layout child from this group. + * @param[in] childId The layout child id + */ + virtual void Remove( Toolkit::LayoutGroup::LayoutId childId ) = 0; + + /** + * @brief Remove a child from this parent + * @param[in] item The item to remove from this layout parent */ - virtual void SetParent( LayoutParent* parent ) = 0; + virtual void Remove( LayoutItem& item ) = 0; /** - * Get the parent of this layout. + * @brief Insert a child to the parent + * @param[in] target The target item + * @param[in] item The item to insert to this layout parent */ - virtual LayoutParent* GetParent() = 0; + virtual Toolkit::LayoutGroup::LayoutId Insert( LayoutItem& target, LayoutItem& item ) = 0; + + /** + * @brief Move a child to another position + * @param[in] target The target item + * @param[in] item The item to move + */ + virtual Toolkit::LayoutGroup::LayoutId Move( LayoutItem& target, LayoutItem& item ) = 0; + + /** + * @brief Move a child to back + * @param[in] item The item to move + */ + virtual Toolkit::LayoutGroup::LayoutId MoveBack( LayoutItem& item ) = 0; protected: virtual ~LayoutParent() @@ -52,6 +79,7 @@ protected: }; + } // namespace Internal } // namespace Toolkit } // namespace Dali