X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fcontrols%2Frenderers%2Fnpatch%2Fnpatch-renderer.h;h=b6c22e83bcdaf6b02ab01f9619e498e9e1232ff1;hp=bbb069c0e0c4d9f9b1221b754acb959427c88cca;hb=f3da11c2818c6d17706fbb2417f21b602b3190f5;hpb=b1d3acc2fd5e456d7a65a962e6fa4e1d2b71cdaf diff --git a/dali-toolkit/internal/controls/renderers/npatch/npatch-renderer.h b/dali-toolkit/internal/controls/renderers/npatch/npatch-renderer.h index bbb069c..b6c22e8 100644 --- a/dali-toolkit/internal/controls/renderers/npatch/npatch-renderer.h +++ b/dali-toolkit/internal/controls/renderers/npatch/npatch-renderer.h @@ -43,10 +43,10 @@ namespace Internal * * The following properties are optional * - * | %Property Name | Type | - * |---------------------------|------------------| - * | image-url | STRING | - * | border-only | BOOLEAN + * | %Property Name | Type | + * |--------------------------|------------------| + * | imageUrl | STRING | + * | borderOnly | BOOLEAN * */ class NPatchRenderer: public ControlRenderer @@ -92,12 +92,7 @@ protected: /** * @copydoc ControlRenderer::DoInitialize */ - virtual void DoInitialize( const Property::Map& propertyMap ); - - /** - * @copydoc ControlRenderer::InitializeRenderer - */ - virtual void InitializeRenderer( Renderer& renderer ); + virtual void DoInitialize( Actor& actor, const Property::Map& propertyMap ); /** * @copydoc ControlRenderer::DoSetOnStage @@ -131,9 +126,28 @@ public: private: /** + * @brief Initialize the renderer with the geometry and shader from the cache, if not available, create and save to the cache for sharing. + */ + void InitializeRenderer(); + + /** + * @brief Creates a geometry for this renderer's grid size + * + * @return Returns the created geometry for this renderer's grid size + */ + Geometry CreateGeometry(); + + /** + * @brief Creates a shader for this renderer's grid size + * + * @return Returns the created shader for this renderer's grid size + */ + Shader CreateShader(); + + /** * @brief Creates a geometry for the grid size to be used by this renderers' shaders * - * @param gridSize The grid size of the solid geometry to create + * @param[in] gridSize The grid size of the solid geometry to create * @return Returns the created geometry for the grid size */ Geometry CreateGeometry( Uint16Pair gridSize ); @@ -156,7 +170,7 @@ private: * |/ |/ |/ |/ |/ | * --------------------- * - * @param gridSize The grid size of the solid geometry to create + * @param[in] gridSize The grid size of the solid geometry to create * @return Returns the created geometry for the grid size */ Geometry CreateGeometryBorder( Uint16Pair gridSize ); @@ -164,21 +178,30 @@ private: /** * @brief Creates Image from the image url and parses the image for the stretch borders. Will create a error image if the n patch image is invalid * - * @param nPatchImage The NinePatchImage to base our cropped images and stretch borders from + * @param[in] nPatchImage The NinePatchImage to base our cropped images and stretch borders from */ - void InitialiseFromImage( NinePatchImage nPatchImage ); + void InitializeFromImage( NinePatchImage nPatchImage ); /** - * @brief Creates a black Image to indicate that there was an error in either the image url or the parsing of the image + * @brief Creates an error Image to indicate that there was an error in either the image url or the parsing of the image * */ - void CreateErrorImage(); + void InitializeFromBrokenImage(); /** * @brief Applies this renderer's image to the sampler to the material used for this renderer */ void ApplyImageToSampler(); + /** + * @brief Changes the current renderer if the n-patch meta data has changed + * + * @param[in] oldBorderOnly The old flag indicating if the image should omit the centre of the n-patch and only render the border + * @param[in] oldGridX The old horizontal grid size of the solid geometry + * @param[in] oldGridY The old vertical grid size of the solid geometry + */ + void ChangeRenderer( bool oldBorderOnly, size_t oldGridX, size_t oldGridY ); + private: NinePatchImage mImage; ///< The image to render if the renderer was set from an NinePatchImage, empty otherwise