2 * Copyright (c) 2021 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.
18 #include <dali-toolkit/dali-toolkit.h>
19 #include <dali-toolkit/devel-api/controls/control-devel.h>
20 #include <dali-toolkit/devel-api/visuals/color-visual-properties-devel.h>
21 #include <dali-toolkit/devel-api/visuals/visual-properties-devel.h>
24 using namespace Dali::Toolkit;
28 const char* IMAGE_FILE(DEMO_IMAGE_DIR "gallery-medium-1.jpg");
30 const float BLUR_RADIUS_VALUE(15.0f);
31 const Vector2 BLUR_OFFSET_VALUE(0.05f, 0.05f);
32 const Vector2 BLUR_SIZE_VALUE(1.1f, 1.1f);
33 const Vector2 NO_BLUR_SIZE_VALUE(1.05f, 1.05f);
34 const float ANIMATION_DURATION(2.0f);
36 constexpr Vector4 CORNER_RADIUS_VALUE(30.0f, 30.0f, 30.0f, 30.0f);
37 constexpr Vector4 SHADOW_CORNER_RADIUS_VALUE(33.0f, 33.0f, 33.0f, 33.0f);
39 const Property::Value SHADOW{
40 {Visual::Property::TYPE, Visual::COLOR},
41 {Visual::Property::MIX_COLOR, Vector4(0.0f, 0.0f, 0.0f, 0.5f)},
42 {Visual::Property::TRANSFORM,
43 Property::Map{{Visual::Transform::Property::SIZE, NO_BLUR_SIZE_VALUE},
44 {Visual::Transform::Property::ORIGIN, Align::CENTER},
45 {Visual::Transform::Property::ANCHOR_POINT, Align::CENTER}}}};
49 // This example shows the blur radius property of the color visual and animates it.
51 class ColorVisualExample : public ConnectionTracker
54 ColorVisualExample(Application& application)
55 : mApplication(application),
58 // Connect to the Application's Init signal
59 mApplication.InitSignal().Connect(this, &ColorVisualExample::Create);
64 // Nothing to do here;
67 // The Init signal is received once (only) during the Application lifetime
68 void Create(Application& application)
70 // Get a handle to the window
71 Window window = application.GetWindow();
72 window.SetBackgroundColor(Color::WHITE);
74 mImageView = ImageView::New(IMAGE_FILE);
75 mImageView.SetProperty(Actor::Property::PARENT_ORIGIN, ParentOrigin::CENTER);
76 mImageView.SetProperty(Actor::Property::SIZE, Vector2(200.0f, 200.0f));
77 mImageView.SetProperty(DevelControl::Property::SHADOW, SHADOW);
79 window.Add(mImageView);
81 // Respond to a click anywhere on the window
82 window.GetRootLayer().TouchedSignal().Connect(this, &ColorVisualExample::OnTouch);
84 // Respond to key events
85 window.KeyEventSignal().Connect(this, &ColorVisualExample::OnKeyEvent);
88 bool OnTouch(Actor actor, const TouchEvent& touch)
90 if(touch.GetState(0) == PointState::UP)
92 Animation animation = Animation::New(ANIMATION_DURATION);
96 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, ImageView::Property::IMAGE, Visual::Property::MIX_COLOR), Vector3(1.0f, 0.0f, 0.0f));
97 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, ImageView::Property::IMAGE, Visual::Property::OPACITY), 0.5f);
98 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, ImageView::Property::IMAGE, DevelVisual::Property::CORNER_RADIUS), CORNER_RADIUS_VALUE);
99 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, ColorVisual::Property::MIX_COLOR), Vector3(0.0f, 0.0f, 1.0f));
100 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, DevelVisual::Property::CORNER_RADIUS), SHADOW_CORNER_RADIUS_VALUE);
101 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, DevelColorVisual::Property::BLUR_RADIUS), BLUR_RADIUS_VALUE);
102 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, Visual::Transform::Property::OFFSET), BLUR_OFFSET_VALUE);
103 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, Visual::Transform::Property::SIZE), BLUR_SIZE_VALUE);
107 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, ImageView::Property::IMAGE, Visual::Property::MIX_COLOR), Vector3(1.0f, 1.0f, 1.0f));
108 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, ImageView::Property::IMAGE, Visual::Property::OPACITY), 1.0f);
109 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, ImageView::Property::IMAGE, DevelVisual::Property::CORNER_RADIUS), Vector4::ZERO);
110 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, ColorVisual::Property::MIX_COLOR), Vector3(0.0f, 0.0f, 0.0f));
111 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, DevelVisual::Property::CORNER_RADIUS), Vector4::ZERO);
112 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, DevelColorVisual::Property::BLUR_RADIUS), 0.0f);
113 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, Visual::Transform::Property::OFFSET), Vector2::ZERO);
114 animation.AnimateTo(DevelControl::GetVisualProperty(mImageView, DevelControl::Property::SHADOW, Visual::Transform::Property::SIZE), NO_BLUR_SIZE_VALUE);
118 mBlurEnabled = !mBlurEnabled;
123 void OnKeyEvent(const KeyEvent& event)
125 if(event.GetState() == KeyEvent::DOWN)
127 if(IsKey(event, Dali::DALI_KEY_ESCAPE) || IsKey(event, Dali::DALI_KEY_BACK))
135 Application& mApplication;
136 ImageView mImageView;
140 int DALI_EXPORT_API main(int argc, char** argv)
142 Application application = Application::New(&argc, &argv);
143 ColorVisualExample test(application);
144 application.MainLoop();