diff options
Diffstat (limited to 'svtools')
-rw-r--r-- | svtools/source/config/miscopt.cxx | 215 |
1 files changed, 189 insertions, 26 deletions
diff --git a/svtools/source/config/miscopt.cxx b/svtools/source/config/miscopt.cxx index 653ecda866a4..491eda8859e5 100644 --- a/svtools/source/config/miscopt.cxx +++ b/svtools/source/config/miscopt.cxx @@ -4,9 +4,9 @@ * * $RCSfile: miscopt.cxx,v $ * - * $Revision: 1.14 $ + * $Revision: 1.15 $ * - * last change: $Author: rt $ $Date: 2005-11-11 13:51:22 $ + * last change: $Author: kz $ $Date: 2006-01-05 18:12:59 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. @@ -78,6 +78,9 @@ #include <rtl/logfile.hxx> #include "itemholder1.hxx" +#include <imgdef.hxx> +#include <vcl/svapp.hxx> + //_________________________________________________________________________________________________________________ // namespaces //_________________________________________________________________________________________________________________ @@ -104,8 +107,10 @@ using namespace ::com::sun::star; #define PROPERTYHANDLE_TOOLBOXSTYLE 2 #define PROPERTYNAME_USESYSTEMFILEDIALOG ASCII_STR("UseSystemFileDialog") #define PROPERTYHANDLE_USESYSTEMFILEDIALOG 3 +#define PROPERTYNAME_SYMBOLSSTYLE ASCII_STR("SymbolsStyle") +#define PROPERTYHANDLE_SYMBOLSSTYLE 4 -#define PROPERTYCOUNT 4 +#define PROPERTYCOUNT 5 #define VCL_TOOLBOX_STYLE_FLAT ((USHORT)0x0004) // from <vcl/toolbox.hxx> @@ -127,8 +132,9 @@ class SvtMiscOptions_Impl : public ConfigItem sal_Bool m_bIsUseSystemFileDialogRO; sal_Bool m_bPluginsEnabled; sal_Bool m_bIsPluginsEnabledRO; - sal_Int16 m_nSymbolSet; - sal_Bool m_bIsSymbolSetRO; + sal_Int16 m_nSymbolsSize; + sal_Bool m_bIsSymbolsSizeRO; + sal_Bool m_bIsSymbolsStyleRO; sal_Int16 m_nToolboxStyle; sal_Bool m_bIsToolboxStyleRO; @@ -207,13 +213,26 @@ class SvtMiscOptions_Impl : public ConfigItem inline sal_Bool IsPluginsEnabledReadOnly() const { return m_bIsPluginsEnabledRO; } - inline sal_Int16 GetSymbolSet() - { return m_nSymbolSet; } + inline sal_Int16 GetSymbolsSize() + { return m_nSymbolsSize; } + + void SetSymbolsSize( sal_Int16 nSet ); + + inline sal_Bool IsGetSymbolsSizeReadOnly() + { return m_bIsSymbolsSizeRO; } + + sal_Int16 GetSymbolsStyle() const; + ::rtl::OUString GetSymbolsStyleName() const; + sal_Int16 GetCurrentSymbolsStyle() const; + + inline void SetSymbolsStyle( sal_Int16 nSet ) + { ImplSetSymbolsStyle( true, nSet, ::rtl::OUString() ); } - void SetSymbolSet( sal_Int16 nSet ); + inline void SetSymbolsStyleName( ::rtl::OUString &rName ) + { ImplSetSymbolsStyle( false, 0, rName ); } - inline sal_Bool IsGetSymbolSetReadOnly() - { return m_bIsSymbolSetRO; } + inline sal_Bool IsGetSymbolsStyleReadOnly() + { return m_bIsSymbolsStyleRO; } // translate to VCL settings ( "0" = 3D, "1" = FLAT ) inline sal_Int16 GetToolboxStyle() @@ -249,12 +268,43 @@ class SvtMiscOptions_Impl : public ConfigItem *//*-*****************************************************************************************************/ static Sequence< OUString > GetPropertyNames(); + + protected: + void ImplSetSymbolsStyle( bool bValue, sal_Int16 nSet, const ::rtl::OUString &rName ); }; //_________________________________________________________________________________________________________________ // definitions //_________________________________________________________________________________________________________________ +static sal_Int16 implSymbolsStyleFromVCL( ULONG nStyle ) +{ + switch ( nStyle ) + { + case STYLE_SYMBOLS_AUTO: return SFX_SYMBOLS_STYLE_AUTO; + case STYLE_SYMBOLS_DEFAULT: return SFX_SYMBOLS_STYLE_DEFAULT; + case STYLE_SYMBOLS_HICONTRAST: return SFX_SYMBOLS_STYLE_HICONTRAST; + case STYLE_SYMBOLS_INDUSTRIAL: return SFX_SYMBOLS_STYLE_INDUSTRIAL; +// case STYLE_SYMBOLS_CRYSTAL: return SFX_SYMBOLS_STYLE_CRYSTAL; + } + + return SFX_SYMBOLS_STYLE_AUTO; +} + +static ULONG implSymbolsStyleToVCL( sal_Int16 nStyle ) +{ + switch ( nStyle ) + { + case SFX_SYMBOLS_STYLE_AUTO: return STYLE_SYMBOLS_AUTO; + case SFX_SYMBOLS_STYLE_DEFAULT: return STYLE_SYMBOLS_DEFAULT; + case SFX_SYMBOLS_STYLE_HICONTRAST: return STYLE_SYMBOLS_HICONTRAST; + case SFX_SYMBOLS_STYLE_INDUSTRIAL: return STYLE_SYMBOLS_INDUSTRIAL; +// case SFX_SYMBOLS_STYLE_CRYSTAL: return STYLE_SYMBOLS_CRYSTAL; + } + + return STYLE_SYMBOLS_AUTO; +} + //***************************************************************************************************************** // constructor //***************************************************************************************************************** @@ -266,8 +316,9 @@ SvtMiscOptions_Impl::SvtMiscOptions_Impl() , m_bIsUseSystemFileDialogRO( sal_False ) , m_bPluginsEnabled( sal_False ) , m_bIsPluginsEnabledRO( sal_False ) - , m_nSymbolSet( 0 ) - , m_bIsSymbolSetRO( sal_False ) + , m_nSymbolsSize( 0 ) + , m_bIsSymbolsSizeRO( sal_False ) + , m_bIsSymbolsStyleRO( sal_False ) , m_nToolboxStyle( 1 ) , m_bIsToolboxStyleRO( sal_False ) @@ -302,9 +353,9 @@ SvtMiscOptions_Impl::SvtMiscOptions_Impl() case PROPERTYHANDLE_SYMBOLSET : { - if( !(seqValues[nProperty] >>= m_nSymbolSet) ) + if( !(seqValues[nProperty] >>= m_nSymbolsSize) ) DBG_ERROR("Wrong type of \"Misc\\SymbolSet\"!" ); - m_bIsSymbolSetRO = seqRO[nProperty]; + m_bIsSymbolsSizeRO = seqRO[nProperty]; break; } @@ -323,6 +374,17 @@ SvtMiscOptions_Impl::SvtMiscOptions_Impl() m_bIsUseSystemFileDialogRO = seqRO[nProperty]; break; } + + case PROPERTYHANDLE_SYMBOLSSTYLE : + { + ::rtl::OUString aSymbolsStyle; + if( seqValues[nProperty] >>= aSymbolsStyle ) + SetSymbolsStyleName( aSymbolsStyle ); + else + DBG_ERROR("Wrong type of \"Misc\\SymbolsStyle\"!" ); + m_bIsSymbolsStyleRO = seqRO[nProperty]; + break; + } } } @@ -385,7 +447,7 @@ void SvtMiscOptions_Impl::Load( const Sequence< OUString >& rPropertyNames ) } break; case PROPERTYHANDLE_SYMBOLSET : { - if( !(seqValues[nProperty] >>= m_nSymbolSet) ) + if( !(seqValues[nProperty] >>= m_nSymbolsSize) ) DBG_ERROR("Wrong type of \"Misc\\SymbolSet\"!" ); } break; @@ -399,6 +461,14 @@ void SvtMiscOptions_Impl::Load( const Sequence< OUString >& rPropertyNames ) DBG_ERROR("Wrong type of \"Misc\\PluginsEnabled\"!" ); } break; + case PROPERTYHANDLE_SYMBOLSSTYLE : { + ::rtl::OUString aSymbolsStyle; + if( seqValues[nProperty] >>= aSymbolsStyle ) + SetSymbolsStyleName( aSymbolsStyle ); + else + DBG_ERROR("Wrong type of \"Misc\\SymbolsStyle\"!" ); + } + break; } } } @@ -434,13 +504,50 @@ void SvtMiscOptions_Impl::SetToolboxStyle( sal_Int16 nStyle, bool _bSetModified CallListeners(); } -void SvtMiscOptions_Impl::SetSymbolSet( sal_Int16 nSet ) +void SvtMiscOptions_Impl::SetSymbolsSize( sal_Int16 nSet ) { - m_nSymbolSet = nSet; + m_nSymbolsSize = nSet; SetModified(); CallListeners(); } +sal_Int16 SvtMiscOptions_Impl::GetSymbolsStyle() const +{ + return implSymbolsStyleFromVCL( Application::GetSettings().GetStyleSettings().GetSymbolsStyle() ); +} + +::rtl::OUString SvtMiscOptions_Impl::GetSymbolsStyleName() const +{ + return Application::GetSettings().GetStyleSettings().GetSymbolsStyleName(); +} + +sal_Int16 SvtMiscOptions_Impl::GetCurrentSymbolsStyle() const +{ + return implSymbolsStyleFromVCL( Application::GetSettings().GetStyleSettings().GetCurrentSymbolsStyle() ); +} + +void SvtMiscOptions_Impl::ImplSetSymbolsStyle( bool bValue, sal_Int16 nSet, const ::rtl::OUString &rName ) +{ + if ( ( bValue && ( nSet != GetSymbolsStyle() ) ) || + ( !bValue && ( rName != GetSymbolsStyleName() ) ) ) + { + AllSettings aAllSettings = Application::GetSettings(); + StyleSettings aStyleSettings = aAllSettings.GetStyleSettings(); + + if ( bValue ) + aStyleSettings.SetSymbolsStyle( implSymbolsStyleToVCL( nSet ) ); + else + aStyleSettings.SetSymbolsStyleName( rName ); + + aAllSettings.SetStyleSettings(aStyleSettings); + Application::MergeSystemSettings( aAllSettings ); + Application::SetSettings(aAllSettings); + + SetModified(); + CallListeners(); + } +} + void SvtMiscOptions_Impl::SetPluginsEnabled( sal_Bool bEnable ) { m_bPluginsEnabled = bEnable; @@ -479,8 +586,8 @@ void SvtMiscOptions_Impl::Commit() case PROPERTYHANDLE_SYMBOLSET : { - if ( !m_bIsSymbolSetRO ) - seqValues[nProperty] <<= m_nSymbolSet; + if ( !m_bIsSymbolsSizeRO ) + seqValues[nProperty] <<= m_nSymbolsSize; break; } @@ -497,6 +604,13 @@ void SvtMiscOptions_Impl::Commit() seqValues[nProperty] <<= m_bUseSystemFileDialog; break; } + + case PROPERTYHANDLE_SYMBOLSSTYLE : + { + if ( !m_bIsSymbolsStyleRO ) + seqValues[nProperty] <<= GetSymbolsStyleName(); + break; + } } } // Set properties in configuration. @@ -514,7 +628,8 @@ Sequence< OUString > SvtMiscOptions_Impl::GetPropertyNames() PROPERTYNAME_PLUGINSENABLED, PROPERTYNAME_SYMBOLSET, PROPERTYNAME_TOOLBOXSTYLE, - PROPERTYNAME_USESYSTEMFILEDIALOG + PROPERTYNAME_USESYSTEMFILEDIALOG, + PROPERTYNAME_SYMBOLSSTYLE }; // Initialize return sequence with these list ... @@ -597,19 +712,67 @@ sal_Bool SvtMiscOptions::IsPluginsEnabledReadOnly() const return m_pDataContainer->IsPluginsEnabledReadOnly(); } -sal_Int16 SvtMiscOptions::GetSymbolSet() const +sal_Int16 SvtMiscOptions::GetSymbolsSize() const +{ + return m_pDataContainer->GetSymbolsSize(); +} + +void SvtMiscOptions::SetSymbolsSize( sal_Int16 nSet ) +{ + m_pDataContainer->SetSymbolsSize( nSet ); +} + +sal_Int16 SvtMiscOptions::GetCurrentSymbolsSize() const +{ + sal_Int16 eOptSymbolsSize = m_pDataContainer->GetSymbolsSize(); + + if ( eOptSymbolsSize == SFX_SYMBOLS_SIZE_AUTO ) + { + // Use system settings, we have to retrieve the toolbar icon size from the + // Application class + ULONG nStyleIconSize = Application::GetSettings().GetStyleSettings().GetToolbarIconSize(); + if ( nStyleIconSize == STYLE_TOOLBAR_ICONSIZE_LARGE ) + eOptSymbolsSize = SFX_SYMBOLS_SIZE_LARGE; + else + eOptSymbolsSize = SFX_SYMBOLS_SIZE_SMALL; + } + + return eOptSymbolsSize; +} + +bool SvtMiscOptions::AreCurrentSymbolsLarge() const +{ + return ( GetCurrentSymbolsSize() == SFX_SYMBOLS_SIZE_LARGE ); +} + +sal_Bool SvtMiscOptions::IsGetSymbolsSizeReadOnly() const +{ + return m_pDataContainer->IsGetSymbolsSizeReadOnly(); +} + +sal_Int16 SvtMiscOptions::GetSymbolsStyle() const +{ + return m_pDataContainer->GetSymbolsStyle(); +} + +sal_Int16 SvtMiscOptions::GetCurrentSymbolsStyle() const +{ + return m_pDataContainer->GetCurrentSymbolsStyle(); +} + +OUString SvtMiscOptions::GetCurrentSymbolsStyleName() const { - return m_pDataContainer->GetSymbolSet(); + return Application::GetSettings().GetStyleSettings().GetCurrentSymbolsStyleName(); } -void SvtMiscOptions::SetSymbolSet( sal_Int16 nSet ) +void SvtMiscOptions::SetSymbolsStyle( sal_Int16 nSet ) { - m_pDataContainer->SetSymbolSet( nSet ); + m_pDataContainer->SetSymbolsStyle( nSet ); } -sal_Bool SvtMiscOptions::IsGetSymbolSetReadOnly() const +sal_Bool SvtMiscOptions::IsGetSymbolsStyleReadOnly() const { - return m_pDataContainer->IsGetSymbolSetReadOnly(); + return m_pDataContainer->IsGetSymbolsStyleReadOnly(); } sal_Int16 SvtMiscOptions::GetToolboxStyle() const |