X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fvisuals%2Fwireframe%2Fwireframe-visual.cpp;h=396f13b2e340223540e63176a2f76d7680ba898e;hp=b65f67c90c8f7c21c8efe2a54cae5debd6eeb6de;hb=05d20c62d7d3ac7e6256ff1823e041f4b209f808;hpb=6ccaa1ddf53d121a0d8427ae6959137279be18fc diff --git a/dali-toolkit/internal/visuals/wireframe/wireframe-visual.cpp b/dali-toolkit/internal/visuals/wireframe/wireframe-visual.cpp index b65f67c..396f13b 100644 --- a/dali-toolkit/internal/visuals/wireframe/wireframe-visual.cpp +++ b/dali-toolkit/internal/visuals/wireframe/wireframe-visual.cpp @@ -20,7 +20,7 @@ #include "wireframe-visual.h" // INTERNAL INCLUDES -#include +#include #include #include #include @@ -45,11 +45,24 @@ attribute mediump vec2 aPosition;\n uniform mediump mat4 uMvpMatrix;\n uniform mediump vec3 uSize;\n \n + +//Visual size and offset +uniform mediump vec2 offset;\n +uniform mediump vec2 size;\n +uniform mediump vec4 offsetSizeMode;\n +uniform mediump vec2 origin;\n +uniform mediump vec2 anchorPoint;\n + +vec4 ComputeVertexPosition()\n +{\n + vec2 visualSize = mix(uSize.xy*size, size, offsetSizeMode.zw );\n + vec2 visualOffset = mix( offset, offset/uSize.xy, offsetSizeMode.xy);\n + return vec4( (aPosition + anchorPoint)*visualSize + (visualOffset + origin)*uSize.xy, 0.0, 1.0 );\n +}\n + void main()\n {\n - mediump vec4 vertexPosition = vec4(aPosition, 0.0, 1.0);\n - vertexPosition.xyz *= uSize;\n - gl_Position = uMvpMatrix * vertexPosition;\n + gl_Position = uMvpMatrix * ComputeVertexPosition();\n }\n ); @@ -93,7 +106,7 @@ void WireframeVisual::DoSetOnStage( Actor& actor ) void WireframeVisual::DoCreatePropertyMap( Property::Map& map ) const { map.Clear(); - map.Insert( Toolkit::Visual::Property::TYPE, Toolkit::Visual::WIREFRAME ); + map.Insert( Toolkit::VisualProperty::TYPE, Toolkit::Visual::WIREFRAME ); } void WireframeVisual::DoSetProperty( Dali::Property::Index index, const Dali::Property::Value& propertyValue ) @@ -109,15 +122,25 @@ Dali::Property::Value WireframeVisual::DoGetProperty( Dali::Property::Index inde void WireframeVisual::InitializeRenderer() { - mImpl->mRenderer = mFactoryCache.GetWireframeRenderer(); - if( !mImpl->mRenderer ) + Shader shader = mFactoryCache.GetShader( VisualFactoryCache::WIREFRAME_SHADER ); + if( !shader ) { - Geometry geometry = CreateQuadWireframeGeometry(); - Shader shader = Shader::New( VERTEX_SHADER, FRAGMENT_SHADER ); + shader = Shader::New( VERTEX_SHADER, FRAGMENT_SHADER ); + mFactoryCache.SaveShader( VisualFactoryCache::WIREFRAME_SHADER, shader ); + } - mImpl->mRenderer = Renderer::New( geometry, shader); - mFactoryCache.CacheWireframeRenderer( mImpl->mRenderer ); + Geometry geometry = mFactoryCache.GetGeometry( VisualFactoryCache::WIREFRAME_GEOMETRY ); + if( !geometry ) + { + geometry = CreateQuadWireframeGeometry(); + mFactoryCache.SaveGeometry( VisualFactoryCache::WIREFRAME_GEOMETRY, geometry ); } + + //Create the renderer + mImpl->mRenderer = Renderer::New( geometry, shader); + + //Register transform properties + mImpl->mTransform.RegisterUniforms( mImpl->mRenderer, Direction::LEFT_TO_RIGHT ); } Geometry WireframeVisual::CreateQuadWireframeGeometry() @@ -150,6 +173,15 @@ Geometry WireframeVisual::CreateQuadWireframeGeometry() return geometry; } +void WireframeVisual::OnSetTransform() +{ + if( mImpl->mRenderer ) + { + //Register transform properties + mImpl->mTransform.RegisterUniforms( mImpl->mRenderer, Direction::LEFT_TO_RIGHT ); + } +} + } // namespace Internal } // namespace Toolkit