Add Text input style changed signal.
[platform/core/uifw/dali-toolkit.git] / dali-toolkit / internal / text / text-control-interface.h
1 #ifndef __DALI_TOOLKIT_TEXT_CONTROL_INTERFACE_H__
2 #define __DALI_TOOLKIT_TEXT_CONTROL_INTERFACE_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/input-style.h>
23
24 namespace Dali
25 {
26
27 class Actor;
28
29 namespace Toolkit
30 {
31
32 namespace Text
33 {
34
35 /**
36  * @brief An interface that the Text::Controller uses to request a text relayout.
37  */
38 class ControlInterface
39 {
40 public:
41
42   /**
43    * @brief Constructor.
44    */
45   ControlInterface();
46
47   /**
48    * @brief Virtual destructor.
49    */
50   virtual ~ControlInterface();
51
52   /**
53    * @brief Add a decoration.
54    *
55    * @param[in] decoration The actor displaying a decoration.
56    * @param[in] needsClipping Whether the actor needs clipping.
57    */
58   virtual void AddDecoration( Actor& actor, bool needsClipping ) = 0;
59
60   /**
61    * @brief Called to request a text relayout.
62    */
63   virtual void RequestTextRelayout() = 0;
64
65   /**
66    * @brief Called to signal that text has been inserted or deleted.
67    */
68   virtual void TextChanged() = 0;
69
70   /**
71    * @brief Called when the number of characters to be inserted exceeds the maximum limit
72    */
73   virtual void MaxLengthReached() = 0;
74
75   /**
76    * @brief Called to signal that input style has been changed.
77    *
78    * @param[in] inputStyleMask Mask with the bits of the input style that has changed.
79    */
80   virtual void InputStyleChanged( InputStyle::Mask inputStyleMask ) = 0;
81 };
82
83 } // namespace Text
84
85 } // namespace Toolkit
86
87 } // namespace Dali
88
89 #endif // __DALI_TOOLKIT_TEXT_CONTROL_INTERFACE_H__