1 #ifndef DALI_TOOLKIT_TEXT_LAYOUT_ENGINE_H
2 #define DALI_TOOLKIT_TEXT_LAYOUT_ENGINE_H
5 * Copyright (c) 2016 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.
22 #include <dali/public-api/common/dali-vector.h>
23 #include <dali/public-api/math/vector2.h>
24 #include <dali/public-api/actors/actor-enumerations.h>
27 #include <dali-toolkit/public-api/text/text-enumerations.h>
28 #include <dali-toolkit/internal/text/line-run.h>
29 #include <dali-toolkit/internal/text/metrics.h>
46 * @brief LayoutEngine is responsible for calculating the visual position of glyphs in layout.
59 * @brief Create a new instance of a LayoutEngine.
64 * @brief Virtual destructor.
69 * @brief Provide the wrapper around FontClient used to get metrics
71 * @param[in] metrics Used to get metrics
73 void SetMetrics( MetricsPtr& metrics );
76 * @brief Choose the required layout.
78 * @param[in] layout The required layout.
80 void SetLayout( Type layout );
83 * @brief Query the required layout.
85 * @return The required layout.
87 Type GetLayout() const;
90 * @brief Sets the width of the cursor.
92 * @param[in] width The width of the cursor in pixels.
94 void SetCursorWidth( int width );
97 * @brief Retrieves the width of the cursor.
99 * @return The width of the cursor in pixels.
101 int GetCursorWidth() const;
104 * @brief Store the visual position of glyphs in the VisualModel.
106 * Builds the bidirectional info and reorders RTL lines.
108 * @param[in,out] layoutParameters The parameters needed to layout the text.
109 * @param[out] layoutSize The size of the text after it has been laid-out.
110 * @param[in] elideTextEnabled Whether the text elide is enabled.
111 * @param[in,out] isAutoScrollEnabled If the isAutoScrollEnabled is true and the height of the text exceeds the boundaries of the control the text is elided and the isAutoScrollEnabled is set to false to disable the autoscroll
113 * @return \e true if the text has been re-laid-out. \e false means the given width is too small to layout even a single character.
115 bool LayoutText( Parameters& layoutParameters,
117 bool elideTextEnabled,
118 bool& isAutoScrollEnabled );
121 * @brief Aligns the laid out lines.
123 * @param[in] size The size of the container where the text is laid-out.
124 * @param[in] startIndex Character index of the line from where the lines are aligned.
125 * @param[in] numberOfCharacters The number of characters.
126 * @param[in] horizontalAlignment The horizontal alignment.
127 * @param[in,out] lines The laid-out lines.
128 * @param[out] alignmentOffset The alignment offset.
129 * @param[in] layoutDirection The direction of the system language.
130 * @param[in] matchSystemLanguageDirection Whether match align for system language direction or not.
132 void Align( const Size& size,
133 CharacterIndex startIndex,
134 Length numberOfCharacters,
135 Text::HorizontalAlignment::Type horizontalAlignment,
136 Vector<LineRun>& lines,
137 float& alignmentOffset,
138 Dali::LayoutDirection::Type layoutDirection,
139 bool matchSystemLanguageDirection );
142 * @brief Sets the default line spacing.
144 * @param[in] lineSpacing The line spacing.
146 void SetDefaultLineSpacing( float lineSpacing );
149 * @brief Retrieves the default line spacing.
151 * @return The line spacing.
153 float GetDefaultLineSpacing() const;
158 Engine( const Engine& handle );
161 Engine& operator=( const Engine& handle );
169 } // namespace Layout
173 } // namespace Toolkit
177 #endif // DALI_TOOLKIT_TEXT_LAYOUT_ENGINE_H