X-Git-Url: http://review.tizen.org/git/?p=platform%2Fcore%2Fuifw%2Fdali-toolkit.git;a=blobdiff_plain;f=dali-toolkit%2Finternal%2Fstyling%2Fstyle-manager-impl.h;h=f0c217c1d2ea51d17ea88366432b93694105bbe1;hp=c612f7d32800cb2f718a3e46c21c63886b166c34;hb=a303f9aeedf6c41514ab474e0cb7f52cd692deec;hpb=c3f7ea6cb0c0b75c2276193aff88b5c7a679a2d5 diff --git a/dali-toolkit/internal/styling/style-manager-impl.h b/dali-toolkit/internal/styling/style-manager-impl.h index c612f7d..f0c217c 100644 --- a/dali-toolkit/internal/styling/style-manager-impl.h +++ b/dali-toolkit/internal/styling/style-manager-impl.h @@ -27,7 +27,7 @@ #include // INTERNAL INCLUDES -#include +#include #include namespace Dali @@ -38,13 +38,15 @@ namespace Toolkit namespace Internal { + +class FeedbackStyle; + /** * @copydoc Toolkit::StyleManager */ class StyleManager : public Dali::BaseObject, public ConnectionTracker { public: - /** * Singleton access * @@ -57,25 +59,28 @@ public: */ StyleManager(); +protected: /** - * @copydoc Toolkit::StyleManager::SetOrientationValue + * @brief Destructor */ - void SetOrientationValue( int orientation ); + virtual ~StyleManager(); - /** - * @copydoc Toolkit::StyleManager::GetOrientationValue +public: // Public API + +/** + * @copydoc Toolkit::StyleManager::ApplyTheme */ - int GetOrientationValue(); + void ApplyTheme( const std::string& themeFile ); /** - * @copydoc Toolkit::StyleManager::SetOrientation( Orientation orientation ) + * @copydoc Toolkit::StyleManager::ApplyDefaultTheme */ - void SetOrientation( Orientation orientation ); + void ApplyDefaultTheme(); /** - * @copydoc Toolkit::StyleManager::GetOrientation + * @copydoc Toolkit::StyleManager::GetDefaultFontFamily */ - Orientation GetOrientation(); + const std::string& GetDefaultFontFamily() const; /** * @copydoc Toolkit::StyleManager::SetStyleConstant @@ -88,27 +93,18 @@ public: bool GetStyleConstant( const std::string& key, Property::Value& valueOut ); /** - * @copydoc Toolkit::StyleManager::RequestThemeChange - */ - void RequestThemeChange( const std::string& themeFile ); - - /** - * @copydoc Toolkit::StyleManager::RequestDefaultTheme - */ - void RequestDefaultTheme(); - - /** - * Determine if a theme change has been requested - * @return Whether a theme request is pending + * @brief Apply the theme style to a control. + * + * @param[in] control The control to apply style. */ - bool IsThemeRequestPending(); + void ApplyThemeStyle( Toolkit::Control control ); /** - * @brief Apply the theme style to a control. + * @brief Apply the theme style to a control at initialization. * * @param[in] control The control to apply style. */ - void ApplyThemeStyle( Toolkit::Control control ); + void ApplyThemeStyleAtInit( Toolkit::Control control ); /** * @copydoc Toolkit::StyleManager::ApplyStyle @@ -120,27 +116,25 @@ public: /** * @copydoc Toolkit::StyleManager::StyleChangeSignal + * This signal is sent after all the controls have been updated + * due to style change */ - Toolkit::StyleManager::StyleChangeSignalType& StyleChangeSignal(); - -protected: + Toolkit::StyleManager::StyleChangedSignalType& StyleChangedSignal(); /** - * @brief Destructor + * This signal is sent to the controls following a style change. + * It should not be exposed in the public API */ - virtual ~StyleManager(); - + Toolkit::StyleManager::StyleChangedSignalType& ControlStyleChangeSignal(); -public: +private: + typedef std::vector StringList; /** * @brief Set the current theme. Called only once per event processing cycle. + * @param[in] themeFile The name of the theme file to read. */ - void SetTheme(); - -private: - - typedef std::vector StringList; + void SetTheme( const std::string& themeFile ); /** * @brief Internal helper method to read a file from file system. @@ -196,13 +190,6 @@ private: void ApplyStyle( Toolkit::Builder builder, Toolkit::Control control ); /** - * @brief Callback for orientation changes - * - * @param[in] orientation The orientation object - */ - void OnOrientationChanged( Orientation orientation ); - - /** * Search for a builder in the cache * * @param[in] key The key the builder was cached under @@ -226,6 +213,12 @@ private: */ void StyleMonitorChange( StyleMonitor styleMonitor, StyleChange::Type styleChange ); + /** + * Emit signals to controls first, app second + */ + void EmitStyleChangeSignals( StyleChange::Type styleChange ); + + // Undefined StyleManager(const StyleManager&); @@ -239,11 +232,8 @@ private: Toolkit::Builder mThemeBuilder; ///< Builder for all default theme properties StyleMonitor mStyleMonitor; ///< Style monitor handle - Orientation mOrientation; ///< Handle to application orientation object - int mOrientationDegrees; ///< Directly set value of orientation - int mDefaultFontSize; ///< Logical size, not a point-size - + std::string mDefaultFontFamily; std::string mThemeFile; ///< The full path of the current theme file Property::Map mThemeBuilderConstants; ///< Contants to give the theme builder @@ -251,8 +241,11 @@ private: BuilderMap mBuilderCache; ///< Cache of builders keyed by JSON file name + Toolkit::Internal::FeedbackStyle* mFeedbackStyle; ///< Feedback style + // Signals - Toolkit::StyleManager::StyleChangeSignalType mStyleChangeSignal; ///< Emitted when the style( theme/font ) changes + Toolkit::StyleManager::StyleChangedSignalType mControlStyleChangeSignal; ///< Emitted when the style( theme/font ) changes for the controls to style themselves + Toolkit::StyleManager::StyleChangedSignalType mStyleChangedSignal; ///< Emitted after the controls have been styled }; } // namespace Internal @@ -280,4 +273,3 @@ inline const Internal::StyleManager& GetImpl( const Dali::Toolkit::StyleManager& } // namespace Dali #endif // __DALI_TOOLKIT_INTERNAL_STYLE_MANAGER_H__ -