Merge remote-tracking branch 'origin/tizen' into devel/new_mesh
[platform/core/uifw/dali-adaptor.git] / adaptors / common / style-monitor-impl.h
1 #ifndef __DALI_INTERNAL_STYLE_MONITOR_H__
2 #define __DALI_INTERNAL_STYLE_MONITOR_H__
3
4 /*
5  * Copyright (c) 2014 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 // EXTERNAL INCLUDES
22 #include <dali/public-api/object/ref-object.h>
23 #include <dali/public-api/object/base-object.h>
24 #include <dali/integration-api/platform-abstraction.h>
25
26 // INTERNAL INCLUDES
27 #include <style-monitor.h>
28
29 namespace Dali
30 {
31
32 namespace Internal
33 {
34
35 namespace Adaptor
36 {
37
38 /**
39  * This holds the platform's style information.
40  * It provides a signal when any aspect of the default style changes on the device.
41  */
42 class StyleMonitor : public BaseObject
43 {
44 public:
45
46   // Creation & Destruction
47
48   /**
49    * Constructor.
50    * @param[in]  platformAbstraction  The platform abstraction.
51    */
52   StyleMonitor(Integration::PlatformAbstraction& platformAbstraction);
53
54   /**
55    * Retrieve the initialized instance of the StyleMonitor.
56    * @return Handle to StyleMonitor.
57    */
58   static Dali::StyleMonitor Get();
59
60   // Style Change Notifications
61
62   /**
63    * Informs the Style Monitor that the style has changed.
64    * @param[in]  styleChange  The details of the change.
65    */
66   void StyleChanged(StyleChange styleChange);
67
68   // Style Information
69
70   /**
71    * @copydoc Dali::StyleMonitor::GetDefaultFontFamily() const
72    */
73   std::string GetDefaultFontFamily() const;
74
75   /**
76    * @copydoc Dali::StyleMonitor::GetDefaultFontStyle() const
77    */
78   std::string GetDefaultFontStyle() const;
79
80   /**
81    * @copydoc Dali::StyleMonitor::GetDefaultFontSize() const
82    */
83   int GetDefaultFontSize() const;
84
85   /**
86    * @copydoc Dali::StyleMonitor::GetTheme() const
87    */
88   const std::string& GetTheme() const;
89
90   /**
91    * @copydoc Dali::StyleMonitor::SetTheme()
92    */
93   void SetTheme(const std::string& themeFilePath);
94
95   // Signals
96
97   /**
98    * @copydoc Dali::StyleMonitor::StyleChangeSignal()
99    */
100   Dali::StyleMonitor::StyleChangeSignalType& StyleChangeSignal();
101
102 protected:
103
104   /**
105    * Virtual Destructor.
106    */
107   virtual ~StyleMonitor();
108
109 private:
110
111   /**
112    * Emit the style change signal.
113    * @param[in]  styleChange  The details of the style change
114    */
115   inline void EmitStyleChangeSignal(StyleChange styleChange);
116
117 private:
118
119   Dali::StyleMonitor::StyleChangeSignalType mStyleChangeSignal; ///< Emitted when the style changes
120
121   Integration::PlatformAbstraction& mPlatformAbstraction; ///< Reference to the PlatformAbstraction (for retrieving defaults)
122
123   std::string mDefaultFontFamily;        ///< The default font family
124   std::string mDefaultFontStyle;         ///< The default font style
125   std::string mUserDefinedThemeFilePath; ///< String containing the user defined theme file path
126   int mDefaultFontSize;                  ///< The default accessibility font size e.g. 0 is smallest
127 };
128
129 } // namespace Adaptor
130
131 } // namespace Internal
132
133 // Additional Helpers for public-api forwarding methods
134
135 inline Internal::Adaptor::StyleMonitor& GetImplementation(Dali::StyleMonitor& monitor)
136 {
137   DALI_ASSERT_ALWAYS(monitor && "Monitor handle is empty");
138   BaseObject& handle = monitor.GetBaseObject();
139   return static_cast<Internal::Adaptor::StyleMonitor&>(handle);
140 }
141
142 inline const Internal::Adaptor::StyleMonitor& GetImplementation(const Dali::StyleMonitor& monitor)
143 {
144   DALI_ASSERT_ALWAYS(monitor && "Monitor handle is empty");
145   const BaseObject& handle = monitor.GetBaseObject();
146   return static_cast<const Internal::Adaptor::StyleMonitor&>(handle);
147 }
148
149 } // namespace Dali
150
151 #endif // __DALI_INTERNAL_STYLE_MONITOR_H__