5fffbbed86167eeb0179d79f7c42437f52d62b71
[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/devel-api/text-abstraction/font-client.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    */
51   StyleMonitor();
52
53   /**
54    * Retrieve the initialized instance of the StyleMonitor.
55    * @return Handle to StyleMonitor.
56    */
57   static Dali::StyleMonitor Get();
58
59   // Style Change Notifications
60
61   /**
62    * Informs the Style Monitor that the style has changed.
63    * @param[in]  styleChange  The details of the change.
64    */
65   void StyleChanged( StyleChange::Type styleChange );
66
67   // Style Information
68
69   /**
70    * @copydoc Dali::StyleMonitor::GetDefaultFontFamily() const
71    */
72   std::string GetDefaultFontFamily() const;
73
74   /**
75    * @copydoc Dali::StyleMonitor::GetDefaultFontStyle() const
76    */
77   std::string GetDefaultFontStyle() const;
78
79   /**
80    * @copydoc Dali::StyleMonitor::GetDefaultFontSize() const
81    */
82   int GetDefaultFontSize() const;
83
84   /**
85    * @copydoc Dali::StyleMonitor::GetTheme() const
86    */
87   const std::string& GetTheme() const;
88
89   /**
90    * @copydoc Dali::StyleMonitor::SetTheme()
91    */
92   void SetTheme(const std::string& themeFilePath);
93
94   /**
95    * @copydoc Dali::StyleMonitor::LoadThemeFile()
96    */
97   bool LoadThemeFile( const std::string& filename, std::string& output );
98
99   // Signals
100
101   /**
102    * @copydoc Dali::StyleMonitor::StyleChangeSignal()
103    */
104   Dali::StyleMonitor::StyleChangeSignalType& StyleChangeSignal();
105
106 protected:
107
108   /**
109    * Virtual Destructor.
110    */
111   virtual ~StyleMonitor();
112
113 private:
114
115   /**
116    * Emit the style change signal.
117    * @param[in]  styleChange  The details of the style change
118    */
119   inline void EmitStyleChangeSignal( StyleChange::Type styleChange );
120
121 private:
122
123   Dali::StyleMonitor::StyleChangeSignalType mStyleChangeSignal; ///< Emitted when the style changes
124
125   TextAbstraction::FontClient mFontClient;
126   std::string mDefaultFontFamily;        ///< The system default font family
127   std::string mDefaultFontStyle;         ///< The default font style
128   std::string mUserDefinedThemeFilePath; ///< String containing the user defined theme file path
129   int mDefaultFontSize;                  ///< The default accessibility font size e.g. 0 is smallest
130 };
131
132 } // namespace Adaptor
133
134 } // namespace Internal
135
136 // Additional Helpers for public-api forwarding methods
137
138 inline Internal::Adaptor::StyleMonitor& GetImplementation(Dali::StyleMonitor& monitor)
139 {
140   DALI_ASSERT_ALWAYS(monitor && "Monitor handle is empty");
141   BaseObject& handle = monitor.GetBaseObject();
142   return static_cast<Internal::Adaptor::StyleMonitor&>(handle);
143 }
144
145 inline const Internal::Adaptor::StyleMonitor& GetImplementation(const Dali::StyleMonitor& monitor)
146 {
147   DALI_ASSERT_ALWAYS(monitor && "Monitor handle is empty");
148   const BaseObject& handle = monitor.GetBaseObject();
149   return static_cast<const Internal::Adaptor::StyleMonitor&>(handle);
150 }
151
152 } // namespace Dali
153
154 #endif // __DALI_INTERNAL_STYLE_MONITOR_H__