[dali_1.4.20] Merge branch 'devel/master'
[platform/core/uifw/dali-toolkit.git] / automated-tests / src / dali-toolkit-internal / dali-toolkit-test-utils / toolkit-text-utils.h
1 #ifndef __DALI_TOOLKIT_TEXT_UTILS_H__
2 #define __DALI_TOOLKIT_TEXT_UTILS_H__
3
4 /*
5  * Copyright (c) 2016 Samsung Electronics Co., Ltd.
6  *
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
10  *
11  * http://www.apache.org/licenses/LICENSE-2.0
12  *
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.
18  *
19  */
20
21 // INTERNAL INCLUDES
22 #include <dali-toolkit/internal/text/logical-model-impl.h>
23 #include <dali-toolkit/internal/text/metrics.h>
24 #include <dali-toolkit/internal/text/visual-model-impl.h>
25 #include <dali-toolkit/internal/text/text-controller.h>
26
27 namespace Dali
28 {
29
30 namespace Toolkit
31 {
32
33 namespace Text
34 {
35
36 /**
37  * @brief Some layout options.
38  */
39 struct LayoutOptions
40 {
41   LayoutOptions()
42   : reorder( true ),
43     align( true )
44   {}
45
46   bool reorder : 1; ///< Whether to reorder the bidirectional lines.
47   bool align   : 1; ///< Whether to align the lines.
48 };
49
50 /**
51  * @brief Creates and fills all the vectors of a text model: characters in utf32, segmentation info,
52  * scripts, fonts, bidi info, glyphs, conversion tables, etc.
53  *
54  * @param[in] text The given text.
55  * @param[in] textArea The area where to layout the text.
56  * @param[in] fontDescriptions The fonts to be used.
57  * @param[in] options Layout options.
58  * @param[out] layoutSize The laid-out size.
59  * @param[out] logicalModel Pointer to a logical text model instance.
60  * @param[out] visualModel Pointer to a visual text model instance.
61  * @param[out] metrics Pointer to a wrapper around FontClient used to get metrics.
62  * @param[in] markupProcessorEnabled Enable markup processor to use markup text.
63  */
64 void CreateTextModel( const std::string& text,
65                       const Size& textArea,
66                       const Vector<FontDescriptionRun>& fontDescriptions,
67                       const LayoutOptions& options,
68                       Size& layoutSize,
69                       LogicalModelPtr& logicalModel,
70                       VisualModelPtr& visualModel,
71                       MetricsPtr& metrics,
72                       bool markupProcessorEnabled );
73
74 /**
75  * @brief Configures the text @p controller similarly to the one configured by the text-label.
76  *
77  * @param[in,out] The text controller to configure.
78  */
79 void ConfigureTextLabel( ControllerPtr controller );
80
81 /**
82  * @brief Configures the text @p controller similarly to the one configured by the text-field.
83  *
84  * @param[in,out] The text controller to configure.
85  */
86 void ConfigureTextField( ControllerPtr controller );
87
88 /**
89  * @brief Configures the text @p controller similarly to the one configured by the text-editor.
90  *
91  * @param[in,out] The text controller to configure.
92  */
93 void ConfigureTextEditor( ControllerPtr controller );
94
95 } // namespace Text
96
97 } // namespace Toolkit
98
99 } // namespace Dali
100
101 #endif // __DALI_TOOLKIT_TEXT_UTILS_H__