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 "grid-example.h"
20 #include "layout-utilities.h"
21 #include <dali-toolkit/devel-api/visuals/image-visual-properties-devel.h>
22 #include <dali-toolkit/devel-api/visual-factory/visual-factory.h>
23 #include <dali-toolkit/devel-api/controls/control-devel.h>
24 #include <dali-toolkit/devel-api/layouting/absolute-layout.h>
25 #include <dali-toolkit/devel-api/layouting/grid.h>
28 using namespace Dali::Toolkit;
32 const char* const TITLE = "Grid Example";
34 // Helper function to create ImageViews with given filename and size.
35 void CreateChildImageView( ImageView& imageView, const char* filename, Size size )
37 imageView = ImageView::New();
38 Property::Map imagePropertyMap;
39 imagePropertyMap[ Toolkit::Visual::Property::TYPE ] = Toolkit::Visual::IMAGE;
40 imagePropertyMap[ Toolkit::ImageVisual::Property::URL ] = filename;
41 imagePropertyMap[ ImageVisual::Property::DESIRED_WIDTH ] = size.width;
42 imagePropertyMap[ ImageVisual::Property::DESIRED_HEIGHT ] = size.height;
43 imageView.SetProperty(Toolkit::ImageView::Property::IMAGE , imagePropertyMap );
44 imageView.SetName("ImageView");
45 imageView.SetAnchorPoint( AnchorPoint::TOP_LEFT );
46 imageView.SetResizePolicy( ResizePolicy::FIXED, Dimension::ALL_DIMENSIONS );
64 GridExample::GridExample()
66 mToggleStatus( GRID_EXACT_WIDTH )
70 void GridExample::Create()
72 // The Init signal is received once (only) during the Application lifetime
74 auto stage = Stage::GetCurrent();
76 // This layout will be the size of the stage but allow the Grid layout to be any size.
77 mRootLayoutControl = LayoutUtilities::CreateRootContainer();
78 stage.Add( mRootLayoutControl );
80 // Create a table view to show a pair of buttons above each image.
81 mGridContainer = Control::New();
83 // Create LinearLayout for this control.
84 auto gridLayout = Grid::New();
85 gridLayout.SetAnimateLayout(true);
86 gridLayout.SetNumberOfColumns( 2 );
87 DevelControl::SetLayout( mGridContainer, gridLayout );
88 mGridContainer.SetName("GridContainer");
89 mGridContainer.SetBackgroundColor( Color::WHITE );
90 mGridContainer.SetProperty( LayoutItem::ChildProperty::WIDTH_SPECIFICATION, ChildLayoutData::WRAP_CONTENT );
91 mGridContainer.SetProperty( LayoutItem::ChildProperty::HEIGHT_SPECIFICATION, ChildLayoutData::WRAP_CONTENT );
92 mGridContainer.SetProperty( Toolkit::Control::Property::PADDING, Extents( 20,20,20,20 ) );
93 mGridContainer.SetParentOrigin( ParentOrigin::CENTER );
95 mRootLayoutControl.Add( mGridContainer );
97 for( unsigned int x = 0; x < INITIAL_NUMBER_OF_IMAGE_VIEWS; x++ )
100 CreateChildImageView( imageView, DEMO_IMAGE_DIR "gallery-small-23.jpg" , Size(100.0f, 100.0f) );
101 mImageViews.push_back( imageView );
102 mGridContainer.Add( mImageViews[x] );
105 // Button toggles the size of the layout
106 mToggleButton = PushButton::New();
107 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, "Set Width 300" );
108 mToggleButton.SetParentOrigin( ParentOrigin::BOTTOM_CENTER );
109 mToggleButton.SetAnchorPoint( AnchorPoint::BOTTOM_CENTER );
110 mToggleButton.ClickedSignal().Connect( this, &Demo::GridExample::ToggleButtonClicked );
111 mToggleButton.SetResizePolicy( ResizePolicy::FILL_TO_PARENT, Dimension::WIDTH );
112 mToggleButton.SetResizePolicy( ResizePolicy::USE_NATURAL_SIZE, Dimension::HEIGHT );
114 stage.Add( mToggleButton );
117 void GridExample::Remove()
120 UnparentAndReset( mGridContainer );
121 UnparentAndReset( mRootLayoutControl );
122 UnparentAndReset( mToggleButton );
125 void GridExample::ChangeTo3Columns()
127 Grid gridLayout = Grid::DownCast( DevelControl::GetLayout(mGridContainer) );
130 gridLayout.SetNumberOfColumns( 3 );
134 void GridExample::AddItemsInteractively()
136 if( mImageViews.size() < MAX_NUMBER_OF_IMAGE_VIEWS )
139 CreateChildImageView( imageView, DEMO_IMAGE_DIR "gallery-small-23.jpg" , Size(100.0f, 100.0f) );
140 mImageViews.push_back( imageView );
141 mGridContainer.Add( imageView);
143 // Add item button shows how many items left to add.
144 unsigned int numberOfAdditonalImageViews = MAX_NUMBER_OF_IMAGE_VIEWS-INITIAL_NUMBER_OF_IMAGE_VIEWS;
145 unsigned int remainingImageViews = numberOfAdditonalImageViews - ( ( mImageViews.size() - INITIAL_NUMBER_OF_IMAGE_VIEWS) );
146 std::string buttonLabel( "Add item["+ std::to_string( numberOfAdditonalImageViews-remainingImageViews ) +"/"+
147 std::to_string( numberOfAdditonalImageViews)+"]" );
148 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, buttonLabel );
152 void GridExample::AddMarginToItems()
154 for( unsigned int x = 0; x < INITIAL_NUMBER_OF_IMAGE_VIEWS; x++ )
156 mImageViews[x].SetProperty(Toolkit::Control::Property::MARGIN, Extents( 20,20,20,10));
160 void GridExample::RemoveMarginsFromItems()
162 for( unsigned int x = 0; x < INITIAL_NUMBER_OF_IMAGE_VIEWS; x++ )
164 mImageViews[x].SetProperty(Toolkit::Control::Property::MARGIN, Extents());
168 void GridExample::MatchParentOnWidth()
170 mGridContainer.SetProperty( LayoutItem::ChildProperty::WIDTH_SPECIFICATION,ChildLayoutData::MATCH_PARENT );
173 void GridExample::WrapContentOnWidth()
175 mGridContainer.SetProperty( LayoutItem::ChildProperty::WIDTH_SPECIFICATION, ChildLayoutData::WRAP_CONTENT );
178 void GridExample::SetExactWidth()
180 mGridContainer.SetProperty( LayoutItem::ChildProperty::WIDTH_SPECIFICATION, 300 );
183 bool GridExample::ToggleButtonClicked( Toolkit::Button button )
185 switch( mToggleStatus )
187 case GRID_EXACT_WIDTH :
190 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, "Set Child Margin" );
191 mToggleStatus = ITEMS_WITH_MARGINS;
194 case ITEMS_WITH_MARGINS :
197 mToggleStatus = GRID_MATCH_PARENT;
198 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, "Set width MATCH_PARENT" );
201 case GRID_MATCH_PARENT :
203 RemoveMarginsFromItems();
204 MatchParentOnWidth();
205 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, "Set width WRAP_CONTENT" );
206 mToggleStatus = GRID_WRAP_CONTENT;
209 case GRID_WRAP_CONTENT :
211 WrapContentOnWidth();
212 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, "Add item" );
213 mToggleStatus = ADD_ITEMS;
218 if( mGridContainer.GetChildCount() < MAX_NUMBER_OF_IMAGE_VIEWS )
220 AddItemsInteractively();
223 if( mGridContainer.GetChildCount() == MAX_NUMBER_OF_IMAGE_VIEWS )
225 // Remove button when no more items to add
226 mToggleStatus= CHANGE_TO_3_COLUMNS;
227 mToggleButton.SetProperty( Toolkit::Button::Property::LABEL, "Change Columns" );
231 case CHANGE_TO_3_COLUMNS :
234 mToggleStatus = GRID_EXACT_WIDTH;
235 UnparentAndReset( mToggleButton );
240 mToggleStatus = GRID_EXACT_WIDTH;