1 #ifndef __DALI_DEMO_HELPER_VIEW_H__
2 #define __DALI_DEMO_HELPER_VIEW_H__
5 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
21 #include <dali-toolkit/dali-toolkit.h>
22 #include <dali-toolkit/devel-api/controls/tool-bar/tool-bar.h>
29 * Provide a style for the view and its tool bar.
33 ViewStyle( float toolBarButtonPercentage, float toolBarTitlePercentage, float toolBarHeight, float toolBarPadding )
34 : mToolBarButtonPercentage( toolBarButtonPercentage ),
35 mToolBarTitlePercentage( toolBarTitlePercentage ),
36 mToolBarHeight( toolBarHeight ),
37 mToolBarPadding( toolBarPadding )
40 float mToolBarButtonPercentage; ///< The tool bar button width is a percentage of the tool bar width.
41 float mToolBarTitlePercentage; ///< The tool bar title width is a percentage of the tool bar width.
42 float mToolBarHeight; ///< The tool bar height (in pixels).
43 float mToolBarPadding; ///< The tool bar padding (in pixels)..
46 const ViewStyle DEFAULT_VIEW_STYLE( 0.1f, 0.7f, 80.f, 4.f );
48 const char* DEFAULT_TEXT_STYLE_FONT_FAMILY("HelveticaNue");
49 const float DEFAULT_TEXT_STYLE_POINT_SIZE( 8.0f );
51 const Dali::Toolkit::Alignment::Padding DEFAULT_PLAY_PADDING(12.0f, 12.0f, 12.0f, 12.0f);
52 const Dali::Toolkit::Alignment::Padding DEFAULT_MODE_SWITCH_PADDING(8.0f, 8.0f, 8.0f, 8.0f);
54 float ScalePointSize(int pointSize)
56 Dali::Vector2 dpi = Dali::Stage::GetCurrent().GetDpi();
57 float meanDpi = (dpi.height + dpi.width) * 0.5f;
58 return pointSize * 220.0f / meanDpi; // 220 is the default horizontal DPI defined in adaptor Application
61 Dali::Layer CreateToolbar( Dali::Toolkit::ToolBar& toolBar,
62 const std::string& toolbarImagePath,
63 const std::string& title,
64 const ViewStyle& style )
66 Dali::Stage stage = Dali::Stage::GetCurrent();
68 Dali::Layer toolBarLayer = Dali::Layer::New();
69 toolBarLayer.SetName( "TOOLBAR_LAYER" );
70 toolBarLayer.SetAnchorPoint( Dali::AnchorPoint::TOP_CENTER );
71 toolBarLayer.SetParentOrigin( Dali::ParentOrigin::TOP_CENTER );
72 toolBarLayer.SetResizePolicy( Dali::ResizePolicy::FILL_TO_PARENT, Dali::Dimension::WIDTH );
73 toolBarLayer.SetSize( 0.0f, style.mToolBarHeight );
75 // Raise tool bar layer to the top.
76 toolBarLayer.RaiseToTop();
79 toolBar = Dali::Toolkit::ToolBar::New();
80 toolBar.SetName( "TOOLBAR" );
81 Dali::Property::Map background;
82 background["url"] = toolbarImagePath;
83 toolBar.SetProperty( Dali::Toolkit::Control::Property::BACKGROUND, background );
84 toolBar.SetParentOrigin( Dali::ParentOrigin::TOP_CENTER );
85 toolBar.SetAnchorPoint( Dali::AnchorPoint::TOP_CENTER );
86 toolBar.SetResizePolicy( Dali::ResizePolicy::FILL_TO_PARENT, Dali::Dimension::ALL_DIMENSIONS );
88 // Add the tool bar to the tool bar layer.
89 toolBarLayer.Add( toolBar );
94 Dali::Toolkit::TextLabel label = Dali::Toolkit::TextLabel::New();
95 label.SetAnchorPoint( Dali::AnchorPoint::TOP_LEFT );
96 label.SetStyleName( "ToolbarLabel" );
97 label.SetProperty( Dali::Toolkit::TextLabel::Property::TEXT, title );
98 label.SetProperty( Dali::Toolkit::TextLabel::Property::HORIZONTAL_ALIGNMENT, "CENTER" );
99 label.SetProperty( Dali::Toolkit::TextLabel::Property::VERTICAL_ALIGNMENT, "CENTER" );
100 label.SetResizePolicy( Dali::ResizePolicy::FILL_TO_PARENT, Dali::Dimension::HEIGHT );
102 // Add title to the tool bar.
103 const float padding( style.mToolBarPadding );
104 toolBar.AddControl( label, style.mToolBarTitlePercentage, Dali::Toolkit::Alignment::HorizontalCenter, Dali::Toolkit::Alignment::Padding( padding, padding, padding, padding ) );
110 Dali::Layer CreateView( Dali::Application& application,
111 Dali::Toolkit::Control& view,
112 Dali::Toolkit::ToolBar& toolBar,
113 const std::string& backgroundImagePath,
114 const std::string& toolbarImagePath,
115 const std::string& title,
116 const ViewStyle& style = DEFAULT_VIEW_STYLE )
118 Dali::Stage stage = Dali::Stage::GetCurrent();
120 // Hide the indicator bar
121 application.GetWindow().ShowIndicator( Dali::Window::INVISIBLE );
123 // Create default View.
124 view = Dali::Toolkit::Control::New();
125 view.SetAnchorPoint( Dali::AnchorPoint::CENTER );
126 view.SetParentOrigin( Dali::ParentOrigin::CENTER );
127 view.SetResizePolicy( Dali::ResizePolicy::FILL_TO_PARENT, Dali::Dimension::ALL_DIMENSIONS );
129 // Add the view to the stage before setting the background.
132 // Set background image, loading it at screen resolution:
133 if ( !backgroundImagePath.empty() )
135 Dali::Property::Map map;
136 map[Dali::Toolkit::Visual::Property::TYPE] = Dali::Toolkit::Visual::IMAGE;
137 map[Dali::Toolkit::ImageVisual::Property::URL] = backgroundImagePath;
138 map[Dali::Toolkit::ImageVisual::Property::DESIRED_WIDTH] = stage.GetSize().x;
139 map[Dali::Toolkit::ImageVisual::Property::DESIRED_HEIGHT] = stage.GetSize().y;
140 map[Dali::Toolkit::ImageVisual::Property::FITTING_MODE] = Dali::FittingMode::SCALE_TO_FILL;
141 map[Dali::Toolkit::ImageVisual::Property::SAMPLING_MODE] = Dali::SamplingMode::BOX_THEN_LINEAR;
142 map[Dali::Toolkit::ImageVisual::Property::SYNCHRONOUS_LOADING] = true;
143 view.SetProperty( Dali::Toolkit::Control::Property::BACKGROUND, map );
147 // Connects the orientation signal with the View::OrientationChanged method.
148 //application.GetOrientation().ChangedSignal().Connect( &view, &Dali::Toolkit::View::OrientationChanged );
150 // Create default ToolBar
151 Dali::Layer toolBarLayer = CreateToolbar( toolBar, toolbarImagePath, title, style );
153 // Add tool bar layer to the view.
154 view.Add( toolBarLayer );
156 // Create a content layer.
157 Dali::Layer contentLayer = Dali::Layer::New();
158 contentLayer.SetAnchorPoint( Dali::AnchorPoint::CENTER );
159 contentLayer.SetParentOrigin( Dali::ParentOrigin::CENTER );
160 contentLayer.SetResizePolicy( Dali::ResizePolicy::FILL_TO_PARENT, Dali::Dimension::ALL_DIMENSIONS );
161 view.Add( contentLayer );
162 contentLayer.LowerBelow( toolBarLayer );
167 Dali::Toolkit::TextLabel CreateToolBarLabel( const std::string& text )
169 Dali::Toolkit::TextLabel label = Dali::Toolkit::TextLabel::New( text );
170 label.SetStyleName( "ToolbarLabel" );
171 label.SetProperty( Dali::Toolkit::TextLabel::Property::HORIZONTAL_ALIGNMENT, "CENTER" );
172 label.SetProperty( Dali::Toolkit::TextLabel::Property::VERTICAL_ALIGNMENT, "CENTER" );
173 label.SetResizePolicy( Dali::ResizePolicy::FILL_TO_PARENT, Dali::Dimension::HEIGHT );
180 #endif // __DALI_DEMO_HELPER_VIEW_H__