X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Fdevel-api%2Flayouting%2Flayout-parent-impl.h;h=677a8ff5db62bfcce8d43ba800a06003bd962476;hp=a6d76c3a08bc85826f016caa8e613737536d3096;hb=48f47cc7a6cad034d14f571e8b5839d678cde799;hpb=ec9a688fa39b6831eef9584dfa33a5b08b6c28a7 diff --git a/dali-toolkit/devel-api/layouting/layout-parent-impl.h b/dali-toolkit/devel-api/layouting/layout-parent-impl.h index a6d76c3..677a8ff 100644 --- a/dali-toolkit/devel-api/layouting/layout-parent-impl.h +++ b/dali-toolkit/devel-api/layouting/layout-parent-impl.h @@ -25,20 +25,32 @@ 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: /** - * Get 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 LayoutParent* GetParent() = 0; + 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 Remove( LayoutItem& item ) = 0; protected: virtual ~LayoutParent() @@ -47,6 +59,7 @@ protected: }; + } // namespace Internal } // namespace Toolkit } // namespace Dali