X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fmesh%2Fmesh-visual.h;h=75b4a868364d6b3d8401a845ba3f6288220aeaae;hb=574ce69b5c6abe40f245aa2dc7e36e55ca873995;hp=a07c02ba68dc6dfb46b9483b25a9b881ee068bc4;hpb=99e2ea03e6d6059f5803d700932df1ff1c848cd3;p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git diff --git a/dali-toolkit/internal/visuals/mesh/mesh-visual.h b/dali-toolkit/internal/visuals/mesh/mesh-visual.h index a07c02b..75b4a86 100644 --- a/dali-toolkit/internal/visuals/mesh/mesh-visual.h +++ b/dali-toolkit/internal/visuals/mesh/mesh-visual.h @@ -21,8 +21,10 @@ // EXTERNAL INCLUDES #include #include +#include // INTERNAL INCLUDES +#include #include #include @@ -35,6 +37,9 @@ namespace Toolkit namespace Internal { +class MeshVisual; +typedef IntrusivePtr< MeshVisual > MeshVisualPtr; + /** * The visual which renders a 3D object to the control's quad * @@ -45,7 +50,7 @@ namespace Internal * | objectUrl | STRING | A URL to the .obj file | * | materialUrl | STRING | A URL to the .mtl file | * | texturesPath | STRING | A URL of the path to the texture images | - * | shaderType | STRING | An enum of shader types | + * | shadingMode | STRING | An enum of shading modes | * | useMipmapping | BOOLEAN | If true, use mipmaps for textures. Default true. | * | useSoftNormals | BOOLEAN | If true, average normals at points for smooth textures. Default true. | * | lightPosition | VECTOR3 | The position (on stage) of the light | @@ -55,48 +60,56 @@ class MeshVisual: public Visual::Base public: /** - * @brief Constructor. + * @brief Create a new mesh visual. * * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object + * @return A smart-pointer to the newly allocated visual. */ - MeshVisual( VisualFactoryCache& factoryCache ); + static MeshVisualPtr New( VisualFactoryCache& factoryCache ); + +public: // from Visual /** - * @brief A reference counted object may only be deleted by calling Unreference(). + * @copydoc Visual::Base::CreatePropertyMap */ - virtual ~MeshVisual(); - -public: // from Visual + virtual void DoCreatePropertyMap( Property::Map& map ) const; /** - * @copydoc Visual::SetSize + * @copydoc Visual::Base::DoSetProperty */ - virtual void SetSize( const Vector2& size ); + virtual void DoSetProperty( Dali::Property::Index index, const Dali::Property::Value& propertyValue ); /** - * @copydoc Visual::SetClipRect + * @copydoc Visual::Base::DoGetProperty */ - virtual void SetClipRect( const Rect& clipRect ); + virtual Dali::Property::Value DoGetProperty( Dali::Property::Index index ); + +protected: /** - * @copydoc Visual::SetOffset + * @brief Constructor. + * + * @param[in] factoryCache A pointer pointing to the VisualFactoryCache object */ - virtual void SetOffset( const Vector2& offset ); + MeshVisual( VisualFactoryCache& factoryCache ); /** - * @copydoc Visual::CreatePropertyMap + * @brief A reference counted object may only be deleted by calling Unreference(). */ - virtual void DoCreatePropertyMap( Property::Map& map ) const; + virtual ~MeshVisual(); -protected: + /** + * @copydoc Visual::Base::DoSetProperties + */ + virtual void DoSetProperties( const Property::Map& propertyMap ); /** - * @copydoc Visual::DoInitialize + * @copydoc Visual::Base::OnSetTransform */ - virtual void DoInitialize( Actor& actor, const Property::Map& propertyMap ); + virtual void OnSetTransform(); /** - * @copydoc Visual::DoSetOnStage + * @copydoc Visual::Base::DoSetOnStage */ virtual void DoSetOnStage( Actor& actor ); @@ -116,14 +129,6 @@ public: private: - //Corresponds to the shader that will be used by the mesh visual. - enum ShaderType - { - TEXTURELESS, - DIFFUSE_TEXTURE, - ALL_TEXTURES - }; - /** * @brief Provide an empty geometry for the visual to use. * @details For use in error cases where the initialisation has failed for varying reasons. @@ -196,7 +201,7 @@ private: Vector3 mSceneSize; Vector3 mLightPosition; - ShaderType mShaderType; + Toolkit::MeshVisual::ShadingMode::Value mShadingMode; bool mUseTexture; bool mUseMipmapping;