2 * Copyright (c) 2018 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 "linear-example.h"
20 #include <dali-toolkit/devel-api/visuals/image-visual-properties-devel.h>
21 #include <dali-toolkit/devel-api/visual-factory/visual-factory.h>
22 #include <dali-toolkit/devel-api/controls/control-devel.h>
23 #include <dali-toolkit/devel-api/layouting/linear-layout.h>
26 using namespace Dali::Toolkit;
30 const char* const TITLE = "Linear Example";
33 const char* LTR_IMAGE( DEMO_IMAGE_DIR "icon-play.png" );
34 const char* LTR_SELECTED_IMAGE( DEMO_IMAGE_DIR "icon-play-selected.png" );
36 const char* RTL_IMAGE( DEMO_IMAGE_DIR "icon-reverse.png" );
37 const char* RTL_SELECTED_IMAGE( DEMO_IMAGE_DIR "icon-reverse-selected.png" );
39 const char* ROTATE_CLOCKWISE_IMAGE( DEMO_IMAGE_DIR "icon-reset.png" );
40 const char* ROTATE_CLOCKWISE_SELECTED_IMAGE( DEMO_IMAGE_DIR "icon-reset-selected.png" );
42 const char* ALIGN_IMAGE( DEMO_IMAGE_DIR "icon-replace.png" );
43 const char* ALIGN_SELECTED_IMAGE( DEMO_IMAGE_DIR "icon-replace-selected.png" );
45 const char* WEIGHT_IMAGE( DEMO_IMAGE_DIR "icon-item-view-layout-grid.png" );
46 const char* WEIGHT_SELECTED_IMAGE( DEMO_IMAGE_DIR "icon-item-view-layout-grid-selected.png" );
48 // Child image filenames
49 const char* IMAGE_PATH[] = {
50 DEMO_IMAGE_DIR "application-icon-101.png",
51 DEMO_IMAGE_DIR "application-icon-102.png",
52 DEMO_IMAGE_DIR "application-icon-103.png",
53 DEMO_IMAGE_DIR "application-icon-104.png"
56 const unsigned int NUMBER_OF_RESOURCES = sizeof(IMAGE_PATH) / sizeof(char*);
58 // Helper function to create ImageViews with given filename and size.
59 void CreateChildImageView( ImageView& imageView, const char* filename, Size size )
61 imageView = ImageView::New();
62 Property::Map imagePropertyMap;
63 imagePropertyMap[ Toolkit::Visual::Property::TYPE ] = Toolkit::Visual::IMAGE;
64 imagePropertyMap[ Toolkit::ImageVisual::Property::URL ] = filename;
65 imagePropertyMap[ ImageVisual::Property::DESIRED_WIDTH ] = size.width;
66 imagePropertyMap[ ImageVisual::Property::DESIRED_HEIGHT ] = size.height;
67 imageView.SetProperty( Toolkit::ImageView::Property::IMAGE, imagePropertyMap );
68 imageView.SetName( "ImageView" );
69 imageView.SetAnchorPoint( AnchorPoint::TOP_LEFT );
70 imageView.SetResizePolicy( ResizePolicy::FIXED, Dimension::ALL_DIMENSIONS );
78 LinearExample::LinearExample()
81 mImagesWeighted (false )
85 void LinearExample::Create()
87 auto stage = Stage::GetCurrent();
89 mDirectionButton = PushButton::New();
90 mDirectionButton.SetProperty( PushButton::Property::UNSELECTED_ICON, RTL_IMAGE );
91 mDirectionButton.SetProperty( PushButton::Property::SELECTED_ICON, RTL_SELECTED_IMAGE );
92 mDirectionButton.ClickedSignal().Connect( this, &LinearExample::OnDirectionClicked );
93 mDirectionButton.SetParentOrigin( Vector3( 0.2f, 1.0f, 0.5f ) );
94 mDirectionButton.SetAnchorPoint( AnchorPoint::BOTTOM_CENTER );
95 mDirectionButton.SetSize( 75, 75 );
96 stage.Add( mDirectionButton );
98 mAlignmentButton = PushButton::New();
99 mAlignmentButton.SetProperty( PushButton::Property::UNSELECTED_ICON, ALIGN_IMAGE );
100 mAlignmentButton.SetProperty( PushButton::Property::SELECTED_ICON, ALIGN_SELECTED_IMAGE );
101 mAlignmentButton.ClickedSignal().Connect( this, &LinearExample::OnAlignmentClicked );
102 mAlignmentButton.SetParentOrigin( Vector3( 0.4f, 1.0f, 0.5f ) );
103 mAlignmentButton.SetAnchorPoint( AnchorPoint::BOTTOM_CENTER );
104 mAlignmentButton.SetSize( 75, 75 );
105 stage.Add( mAlignmentButton );
107 mWeightButton = Toolkit::PushButton::New();
108 mWeightButton.SetProperty( PushButton::Property::UNSELECTED_ICON, WEIGHT_IMAGE );
109 mWeightButton.SetProperty( PushButton::Property::SELECTED_ICON, WEIGHT_SELECTED_IMAGE );
110 mWeightButton.ClickedSignal().Connect( this, &LinearExample::OnWeightClicked );
111 mWeightButton.SetParentOrigin( Vector3( 0.6f, 1.0f, 0.5f ) );
112 mWeightButton.SetAnchorPoint( AnchorPoint::BOTTOM_CENTER );
113 mWeightButton.SetSize( 75, 75 );
114 stage.Add( mWeightButton );
116 mRotateButton = PushButton::New();
117 mRotateButton.SetProperty( PushButton::Property::UNSELECTED_ICON, ROTATE_CLOCKWISE_IMAGE );
118 mRotateButton.SetProperty( PushButton::Property::SELECTED_ICON, ROTATE_CLOCKWISE_SELECTED_IMAGE );
119 mRotateButton.ClickedSignal().Connect( this, &LinearExample::OnRotateClicked );
120 mRotateButton.SetParentOrigin( Vector3( 0.8f, 1.0f, 0.5f ) );
121 mRotateButton.SetAnchorPoint( AnchorPoint::BOTTOM_CENTER );
122 mRotateButton.SetSize( 75, 75 );
123 stage.Add( mRotateButton );
125 // Create a linear layout
126 mLinearContainer = Control::New();
127 auto layout = LinearLayout::New();
128 layout.SetAnimateLayout(true);
129 layout.SetOrientation( LinearLayout::Orientation::HORIZONTAL );
130 layout.SetAlignment( LinearLayout::Alignment::CENTER_VERTICAL );
131 DevelControl::SetLayout( mLinearContainer, layout );
133 mLinearContainer.SetParentOrigin( ParentOrigin::CENTER );
134 mLinearContainer.SetAnchorPoint( AnchorPoint::CENTER );
135 mLinearContainer.SetName( "LinearExample" );
136 stage.Add( mLinearContainer );
137 mLinearContainer.SetProperty( Toolkit::LayoutItem::ChildProperty::WIDTH_SPECIFICATION, ChildLayoutData::MATCH_PARENT );
138 mLinearContainer.SetProperty( Toolkit::LayoutItem::ChildProperty::HEIGHT_SPECIFICATION, ChildLayoutData::MATCH_PARENT );
139 mLinearContainer.SetProperty( Actor::Property::LAYOUT_DIRECTION, LayoutDirection::LEFT_TO_RIGHT );
141 for( unsigned int x = 0; x < NUMBER_OF_RESOURCES; ++x )
143 Toolkit::ImageView imageView;
144 CreateChildImageView( imageView, IMAGE_PATH[ x ], Size( 100.0f, 100.0f ) );
145 mLinearContainer.Add( imageView );
146 mImages.push_back( imageView );
150 // Remove controls added by this example from stage
151 void LinearExample::Remove()
153 if ( mLinearContainer )
155 UnparentAndReset( mDirectionButton );
156 UnparentAndReset( mAlignmentButton );
157 UnparentAndReset( mWeightButton );
158 UnparentAndReset( mRotateButton );
159 UnparentAndReset( mLinearContainer);
163 // Mirror items in layout
164 bool LinearExample::OnDirectionClicked( Button button )
166 auto layout = LinearLayout::DownCast( DevelControl::GetLayout( mLinearContainer ) );
167 layout.SetOrientation( LinearLayout::Orientation::HORIZONTAL );
170 mDirectionButton.SetProperty( PushButton::Property::UNSELECTED_ICON, LTR_IMAGE );
171 mDirectionButton.SetProperty( PushButton::Property::SELECTED_ICON, LTR_SELECTED_IMAGE );
172 mLinearContainer.SetProperty( Actor::Property::LAYOUT_DIRECTION, LayoutDirection::LEFT_TO_RIGHT );
176 mDirectionButton.SetProperty( PushButton::Property::UNSELECTED_ICON, RTL_IMAGE );
177 mDirectionButton.SetProperty( PushButton::Property::SELECTED_ICON, RTL_SELECTED_IMAGE );
178 mLinearContainer.SetProperty( Actor::Property::LAYOUT_DIRECTION, LayoutDirection::RIGHT_TO_LEFT );
180 mLTRDirection = !mLTRDirection;
184 // Rotate layout by changing layout
185 bool LinearExample::OnRotateClicked( Button button )
187 auto layout = LinearLayout::DownCast( DevelControl::GetLayout( mLinearContainer ) );
188 if( layout.GetOrientation() == LinearLayout::Orientation::VERTICAL )
190 layout.SetOrientation( LinearLayout::Orientation::HORIZONTAL );
191 layout.SetAlignment(LinearLayout::Alignment::CENTER_VERTICAL );
195 layout.SetOrientation( LinearLayout::Orientation::VERTICAL );
196 layout.SetAlignment( LinearLayout::Alignment::CENTER_HORIZONTAL );
201 bool LinearExample::OnAlignmentClicked( Button button )
203 auto layout = LinearLayout::DownCast( DevelControl::GetLayout( mLinearContainer ) );
204 if ( layout.GetAlignment() == LinearLayout::Alignment::CENTER_VERTICAL ) {
205 layout.SetAlignment( LinearLayout::Alignment::BEGIN );
207 else if ( layout.GetAlignment() == LinearLayout::Alignment::BEGIN )
209 layout.SetAlignment( LinearLayout::Alignment::END );
211 else if ( layout.GetAlignment() == LinearLayout::Alignment::END )
213 layout.SetAlignment( LinearLayout::Alignment::CENTER_HORIZONTAL);
215 else if ( layout.GetAlignment() == LinearLayout::Alignment::CENTER_HORIZONTAL )
217 layout.SetAlignment( LinearLayout::Alignment::TOP );
219 else if ( layout.GetAlignment() == LinearLayout::Alignment::TOP )
221 layout.SetAlignment( LinearLayout::Alignment::BOTTOM );
223 else if ( layout.GetAlignment() == LinearLayout::Alignment::BOTTOM )
225 layout.SetAlignment( LinearLayout::Alignment::CENTER_VERTICAL );
230 bool LinearExample::OnWeightClicked( Button button )
232 if( !mImagesWeighted )
234 for( auto&& iter : mImages )
236 iter.SetProperty( Toolkit::LinearLayout::ChildProperty::WEIGHT, 0.25f );
241 for( auto&& iter : mImages )
243 iter.SetProperty( Toolkit::LinearLayout::ChildProperty::WEIGHT, 0.0f );
247 mImagesWeighted = !mImagesWeighted;