#include "vbafont.hxx" #include #include #include #include using namespace ::ooo::vba; using namespace ::com::sun::star; const uno::Any aLongAnyTrue( sal_Int16(-1) ); const uno::Any aLongAnyFalse( sal_Int16( 0 ) ); struct MapPair { sal_Int32 nMSOConst; sal_Int32 nOOOConst; }; static MapPair UnderLineTable[] = { { word::WdUnderline::wdUnderlineNone, com::sun::star::awt::FontUnderline::NONE }, { word::WdUnderline::wdUnderlineSingle, com::sun::star::awt::FontUnderline::SINGLE }, { word::WdUnderline::wdUnderlineWords, com::sun::star::awt::FontUnderline::SINGLE }, { word::WdUnderline::wdUnderlineDouble, com::sun::star::awt::FontUnderline::DOUBLE }, { word::WdUnderline::wdUnderlineDotted, com::sun::star::awt::FontUnderline::DOTTED }, { word::WdUnderline::wdUnderlineThick, com::sun::star::awt::FontUnderline::BOLDDASH }, { word::WdUnderline::wdUnderlineDash, com::sun::star::awt::FontUnderline::DASH }, { word::WdUnderline::wdUnderlineDotDash, com::sun::star::awt::FontUnderline::DASHDOT }, { word::WdUnderline::wdUnderlineDotDotDash, com::sun::star::awt::FontUnderline::DASHDOTDOT }, { word::WdUnderline::wdUnderlineWavy, com::sun::star::awt::FontUnderline::WAVE }, { word::WdUnderline::wdUnderlineDottedHeavy, com::sun::star::awt::FontUnderline::BOLDDOTTED }, { word::WdUnderline::wdUnderlineDashHeavy, com::sun::star::awt::FontUnderline::BOLDDASH }, { word::WdUnderline::wdUnderlineDotDashHeavy, com::sun::star::awt::FontUnderline::BOLDDASHDOT }, { word::WdUnderline::wdUnderlineDotDotDashHeavy, com::sun::star::awt::FontUnderline::BOLDDASHDOTDOT }, { word::WdUnderline::wdUnderlineWavyHeavy, com::sun::star::awt::FontUnderline::BOLDWAVE }, { word::WdUnderline::wdUnderlineDashLong, com::sun::star::awt::FontUnderline::LONGDASH }, { word::WdUnderline::wdUnderlineWavyDouble, com::sun::star::awt::FontUnderline::DOUBLEWAVE }, { word::WdUnderline::wdUnderlineDashLongHeavy, com::sun::star::awt::FontUnderline::BOLDLONGDASH }, }; typedef std::hash_map< sal_Int32, sal_Int32 > ConstToConst; class UnderLineMapper { ConstToConst MSO2OOO; ConstToConst OOO2MSO; private: UnderLineMapper() { sal_Int32 nLen = sizeof( UnderLineTable )/ sizeof( UnderLineTable[0] ); for ( sal_Int32 index=0; indexsecond; } sal_Int32 getMSOFromOOO( sal_Int32 nOOOConst ) throw( lang::IllegalArgumentException ) { ConstToConst::iterator it = OOO2MSO.find( nOOOConst ); if ( it == OOO2MSO.end() ) throw lang::IllegalArgumentException(); return it->second; } }; SwVbaFont::SwVbaFont( const uno::Reference< XHelperInterface >& xParent, const uno::Reference< uno::XComponentContext >& xContext, const uno::Reference< container::XIndexAccess >& xPalette, uno::Reference< css::beans::XPropertySet > xPropertySet ) throw ( css::uno::RuntimeException ) : SwVbaFont_BASE( xParent, xContext, xPalette, xPropertySet ) { } uno::Any SAL_CALL SwVbaFont::getUnderline() throw (uno::RuntimeException) { sal_Int32 nOOVal = 0; mxFont->getPropertyValue( UnderLineMapper::propName() ) >>= nOOVal; return uno::makeAny( UnderLineMapper::instance().getMSOFromOOO( nOOVal ) ); } void SAL_CALL SwVbaFont::setUnderline( const uno::Any& _underline ) throw (uno::RuntimeException) { sal_Int32 nMSOVal = 0; if ( _underline >>= nMSOVal ) { sal_Int32 nOOVal = UnderLineMapper::instance().getOOOFromMSO( nMSOVal ); mxFont->setPropertyValue( UnderLineMapper::propName(), uno::makeAny( nOOVal ) ); } } rtl::OUString& SwVbaFont::getServiceImplName() { static rtl::OUString sImplName( RTL_CONSTASCII_USTRINGPARAM("SwVbaFont") ); return sImplName; } void SAL_CALL SwVbaFont::setColorIndex( const uno::Any& _colorindex ) throw( uno::RuntimeException ) { sal_Int32 nIndex = 0; _colorindex >>= nIndex; return setColor( OORGBToXLRGB(mxPalette->getByIndex( nIndex )) ); } uno::Any SAL_CALL SwVbaFont::getColorIndex() throw ( uno::RuntimeException ) { sal_Int32 nColor = 0; XLRGBToOORGB( getColor() ) >>= nColor; sal_Int32 nElems = mxPalette->getCount(); sal_Int32 nIndex = 0; for ( sal_Int32 count=0; countgetByIndex( count ) >>= nPaletteColor; if ( nPaletteColor == nColor ) { nIndex = count; break; } } return uno::makeAny( nIndex ); } uno::Any SAL_CALL SwVbaFont::getSubscript() throw ( uno::RuntimeException ) { sal_Bool bRes = sal_False; SwVbaFont_BASE::getSubscript() >>= bRes; if ( bRes ) return aLongAnyTrue; return aLongAnyFalse; } uno::Any SAL_CALL SwVbaFont::getSuperscript() throw ( uno::RuntimeException ) { sal_Bool bRes = sal_False; SwVbaFont_BASE::getSuperscript() >>= bRes; if ( bRes ) return aLongAnyTrue; return aLongAnyFalse; } uno::Any SAL_CALL SwVbaFont::getBold() throw (uno::RuntimeException) { sal_Bool bRes = sal_False; SwVbaFont_BASE::getBold() >>= bRes; if ( bRes ) return aLongAnyTrue; return aLongAnyFalse; } uno::Any SAL_CALL SwVbaFont::getItalic() throw (uno::RuntimeException) { sal_Bool bRes = sal_False; SwVbaFont_BASE::getItalic() >>= bRes; if ( bRes ) return aLongAnyTrue; return aLongAnyFalse; } uno::Any SAL_CALL SwVbaFont::getStrikethrough() throw (css::uno::RuntimeException) { sal_Bool bRes = sal_False; SwVbaFont_BASE::getStrikethrough() >>= bRes; if ( bRes ) return aLongAnyTrue; return aLongAnyFalse; } uno::Any SAL_CALL SwVbaFont::getShadow() throw (uno::RuntimeException) { sal_Bool bRes = sal_False; SwVbaFont_BASE::getShadow() >>= bRes; if ( bRes ) return aLongAnyTrue; return aLongAnyFalse; } uno::Sequence< rtl::OUString > SwVbaFont::getServiceNames() { static uno::Sequence< rtl::OUString > aServiceNames; if ( aServiceNames.getLength() == 0 ) { aServiceNames.realloc( 1 ); aServiceNames[ 0 ] = rtl::OUString( RTL_CONSTASCII_USTRINGPARAM("ooo.vba.word.Font" ) ); } return aServiceNames; }