2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
19 #include <dali/devel-api/rendering/renderer.h>
20 #include <dali-toolkit/dali-toolkit.h>
23 #include "shared/view.h"
29 const char* MATERIAL_SAMPLE( DALI_IMAGE_DIR "gallery-small-48.jpg" );
30 const char* MATERIAL_SAMPLE2( DALI_IMAGE_DIR "gallery-medium-19.jpg" );
32 #define MAKE_SHADER(A)#A
34 const char* VERTEX_SHADER = MAKE_SHADER(
35 attribute mediump vec2 aPosition;
36 attribute highp vec2 aTexCoord;
37 varying mediump vec2 vTexCoord;
38 uniform mediump mat4 uMvpMatrix;
39 uniform mediump vec3 uSize;
40 uniform lowp vec4 uFadeColor;
44 mediump vec4 vertexPosition = vec4(aPosition, 0.0, 1.0);
45 vertexPosition.xyz *= uSize;
46 vertexPosition = uMvpMatrix * vertexPosition;
47 vTexCoord = aTexCoord;
48 gl_Position = vertexPosition;
52 const char* FRAGMENT_SHADER = MAKE_SHADER(
53 varying mediump vec2 vTexCoord;
54 uniform lowp vec4 uColor;
55 uniform sampler2D sTexture;
56 uniform lowp vec4 uFadeColor;
60 gl_FragColor = texture2D( sTexture, vTexCoord ) * uColor * uFadeColor;
64 Geometry CreateGeometry()
67 const float halfQuadSize = .5f;
68 struct TexturedQuadVertex { Vector2 position; Vector2 textureCoordinates; };
69 TexturedQuadVertex texturedQuadVertexData[4] = {
70 { Vector2(-halfQuadSize, -halfQuadSize), Vector2(0.f, 0.f) },
71 { Vector2( halfQuadSize, -halfQuadSize), Vector2(1.f, 0.f) },
72 { Vector2(-halfQuadSize, halfQuadSize), Vector2(0.f, 1.f) },
73 { Vector2( halfQuadSize, halfQuadSize), Vector2(1.f, 1.f) } };
75 Property::Map texturedQuadVertexFormat;
76 texturedQuadVertexFormat["aPosition"] = Property::VECTOR2;
77 texturedQuadVertexFormat["aTexCoord"] = Property::VECTOR2;
78 PropertyBuffer texturedQuadVertices = PropertyBuffer::New( texturedQuadVertexFormat, 4 );
79 texturedQuadVertices.SetData(texturedQuadVertexData);
82 unsigned int indexData[6] = { 0, 3, 1, 0, 2, 3 };
83 Property::Map indexFormat;
84 indexFormat["indices"] = Property::UNSIGNED_INTEGER;
85 PropertyBuffer indices = PropertyBuffer::New( indexFormat, sizeof(indexData)/sizeof(indexData[0]) );
86 indices.SetData(indexData);
88 // Create the geometry object
89 Geometry texturedQuadGeometry = Geometry::New();
90 texturedQuadGeometry.AddVertexBuffer( texturedQuadVertices );
91 texturedQuadGeometry.SetIndexBuffer( indices );
93 return texturedQuadGeometry;
97 * Sinusoidal curve starting at zero with 2 cycles
99 float AlphaFunctionSineX2(float progress)
101 return 0.5f - cosf(progress * 4.0f * Math::PI) * 0.5f;
104 } // anonymous namespace
106 // This example shows how to use a simple mesh
108 class ExampleController : public ConnectionTracker
113 * The example controller constructor.
114 * @param[in] application The application instance
116 ExampleController( Application& application )
117 : mApplication( application )
119 // Connect to the Application's Init signal
120 mApplication.InitSignal().Connect( this, &ExampleController::Create );
124 * The example controller destructor
128 // Nothing to do here;
132 * Invoked upon creation of application
133 * @param[in] application The application instance
135 void Create( Application& application )
137 // The Init signal is received once (only) during the Application lifetime
139 Stage stage = Stage::GetCurrent();
140 stage.KeyEventSignal().Connect(this, &ExampleController::OnKeyEvent);
142 mStageSize = stage.GetSize();
144 // Hide the indicator bar
145 application.GetWindow().ShowIndicator( Dali::Window::INVISIBLE );
147 mImage = ResourceImage::New( MATERIAL_SAMPLE, ResourceImage::ON_DEMAND, Image::NEVER );
148 mSampler1 = Sampler::New(mImage, "sTexture");
150 Image image = ResourceImage::New( MATERIAL_SAMPLE2 );
151 mSampler2 = Sampler::New(image, "sTexture");
153 mShader = Shader::New( VERTEX_SHADER, FRAGMENT_SHADER );
154 mMaterial1 = Material::New( mShader );
155 mMaterial1.AddSampler( mSampler1 );
157 mMaterial2 = Material::New( mShader );
158 mMaterial2.AddSampler( mSampler2 );
160 mGeometry = CreateGeometry();
162 mRenderer = Renderer::New( mGeometry, mMaterial1 );
164 mMeshActor = Actor::New();
165 mMeshActor.AddRenderer( mRenderer );
166 mMeshActor.SetSize(400, 400);
168 Property::Index fadeColorIndex = mMeshActor.RegisterProperty( "uFadeColor", Color::GREEN );
170 fadeColorIndex = mRenderer.RegisterProperty( "uFadeColor", Color::MAGENTA );
171 mRenderer.SetDepthIndex(0);
173 mMeshActor.SetParentOrigin( ParentOrigin::TOP_CENTER );
174 mMeshActor.SetAnchorPoint( AnchorPoint::TOP_CENTER );
175 stage.Add( mMeshActor );
177 mRenderer2 = Renderer::New( mGeometry, mMaterial2 );
179 mMeshActor2 = Actor::New();
180 mMeshActor2.AddRenderer( mRenderer2 );
181 mMeshActor2.SetSize(400, 400);
183 mMeshActor2.RegisterProperty( "a-n-other-property", Color::GREEN );
184 Property::Index fadeColorIndex2 = mMeshActor2.RegisterProperty( "uFadeColor", Color::GREEN );
186 mRenderer2.RegisterProperty( "a-n-other-property", Vector3::ZERO );
187 mRenderer2.RegisterProperty( "a-coefficient", 0.008f );
188 fadeColorIndex2 = mRenderer2.RegisterProperty( "uFadeColor", Color::BLUE );
189 mRenderer2.SetDepthIndex(0);
191 mMeshActor2.SetParentOrigin( ParentOrigin::BOTTOM_CENTER );
192 mMeshActor2.SetAnchorPoint( AnchorPoint::BOTTOM_CENTER );
193 stage.Add( mMeshActor2 );
195 Animation animation = Animation::New(5);
196 KeyFrames keyFrames = KeyFrames::New();
197 keyFrames.Add(0.0f, Vector4::ZERO);
198 keyFrames.Add(1.0f, Vector4( Color::GREEN ));
200 KeyFrames keyFrames2 = KeyFrames::New();
201 keyFrames2.Add(0.0f, Vector4::ZERO);
202 keyFrames2.Add(1.0f, Color::MAGENTA);
204 animation.AnimateBetween( Property( mRenderer, fadeColorIndex ), keyFrames, AlphaFunction(AlphaFunction::SIN) );
205 animation.AnimateBetween( Property( mRenderer2, fadeColorIndex2 ), keyFrames2, AlphaFunction(AlphaFunctionSineX2) );
206 animation.SetLooping(true);
209 stage.SetBackgroundColor(Vector4(0.0f, 0.2f, 0.2f, 1.0f));;
212 BufferImage CreateBufferImage()
214 BufferImage image = BufferImage::New( 200, 200, Pixel::RGB888 );
215 PixelBuffer* pixelBuffer = image.GetBuffer();
216 unsigned int stride = image.GetBufferStride();
217 for( unsigned int x=0; x<200; x++ )
219 for( unsigned int y=0; y<200; y++ )
221 PixelBuffer* pixel = pixelBuffer + y*stride + x*3;
222 if( ((int)(x/20.0f))%2 + ((int)(y/20.0f)%2) == 1 )
243 * Invoked whenever the quit button is clicked
244 * @param[in] button the quit button
246 bool OnQuitButtonClicked( Toolkit::Button button )
248 // quit the application
253 void OnKeyEvent(const KeyEvent& event)
255 if(event.state == KeyEvent::Down)
257 if( IsKey( event, Dali::DALI_KEY_ESCAPE) || IsKey( event, Dali::DALI_KEY_BACK) )
266 Application& mApplication; ///< Application instance
267 Vector3 mStageSize; ///< The size of the stage
280 Timer mChangeImageTimer;
283 void RunTest( Application& application )
285 ExampleController test( application );
287 application.MainLoop();
290 // Entry point for Linux & SLP applications
292 int main( int argc, char **argv )
294 Application application = Application::New( &argc, &argv );
296 RunTest( application );