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=d6bc4a12992395356e6c2d579d41724a3f6090e6;hp=86c6d4c3e341c30bd26228a70adeea6ac82afd02;hb=a827febe27e8131e681c24c255472bbbf097905f;hpb=a8bc013df97fad9f1cc2d95c37248464ac553e6e diff --git a/dali-toolkit/internal/styling/style-manager-impl.h b/dali-toolkit/internal/styling/style-manager-impl.h index 86c6d4c..d6bc4a1 100644 --- a/dali-toolkit/internal/styling/style-manager-impl.h +++ b/dali-toolkit/internal/styling/style-manager-impl.h @@ -27,8 +27,9 @@ #include // INTERNAL INCLUDES -#include +#include #include +#include namespace Dali { @@ -47,7 +48,6 @@ class FeedbackStyle; class StyleManager : public Dali::BaseObject, public ConnectionTracker { public: - /** * Singleton access * @@ -60,25 +60,28 @@ public: */ StyleManager(); +protected: /** - * @copydoc Toolkit::StyleManager::SetOrientationValue + * @brief Destructor */ - void SetOrientationValue( int orientation ); + virtual ~StyleManager(); + +public: // Public API /** - * @copydoc Toolkit::StyleManager::GetOrientationValue + * @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 @@ -91,20 +94,9 @@ 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 + * @copydoc Toolkit::StyleManager::GetConfigurations */ - bool IsThemeRequestPending(); + const Property::Map GetConfigurations(); /** * @brief Apply the theme style to a control. @@ -125,32 +117,37 @@ public: */ void ApplyStyle( Toolkit::Control control, const std::string& jsonFileName, const std::string& styleName ); + /** + * Get the state/style information for the given control + * @param[in] control The control to get state information for + * @return The style information (or empty ptr if not found) + */ + const StylePtr GetRecordedStyle( Toolkit::Control control ); + public: // SIGNALS /** * @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. @@ -180,24 +177,6 @@ private: bool LoadJSON( Toolkit::Builder builder, const std::string& jsonFileName ); /** - * @brief Collect qualifiers (e.g. Landscape, portrait etc) for a given style - * - * @param[in,out] qualifiersOut The list to populate with qualifiers - */ - void CollectQualifiers( StringList& qualifiersOut ); - - /** - * @brief Construct a qualified style name out of qualifiers - * - * A qualifed style name will be in the format: style-qualifier0-qualifier1-qualifierN - * - * @param[in] styleName The root name of the style - * @param[in] qualifiers List of qualifier names - * @param[out] qualifiedStyleOut The qualified style name - */ - void BuildQualifiedStyleName( const std::string& styleName, const StringList& qualifiers, std::string& qualifiedStyleOut ); - - /** * @brief Apply a style to the control using the given builder * * @param[in] builder The builder to apply the style from @@ -206,13 +185,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 @@ -236,6 +208,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&); @@ -249,11 +227,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 @@ -264,7 +239,8 @@ private: 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 @@ -292,4 +268,3 @@ inline const Internal::StyleManager& GetImpl( const Dali::Toolkit::StyleManager& } // namespace Dali #endif // __DALI_TOOLKIT_INTERNAL_STYLE_MANAGER_H__ -