/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: controlpropertyhdl.cxx,v $ * * $Revision: 1.20 $ * * last change: $Author: hr $ $Date: 2007-06-27 15:12:57 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_xmloff.hxx" #ifndef _XMLOFF_FORMS_CONTROLPROPERTYHDL_HXX_ #include #endif #ifndef _COM_SUN_STAR_AWT_TEXTALIGN_HPP_ #include #endif #ifndef _COM_SUN_STAR_AWT_FONTWIDTH_HPP_ #include #endif #ifndef _COM_SUN_STAR_AWT_FONTEMPHASISMARK_HPP_ #include #endif #ifndef _XMLOFF_XMLTYPES_HXX #include #endif #ifndef _XMLOFF_FORMENUMS_HXX_ #include "formenums.hxx" #endif #ifndef _XMLOFF_XMLUCONV_HXX #include #endif #ifndef _XMLOFF_XMLTOKEN_HXX #include #endif #ifndef _RTL_USTRBUF_HXX_ #include #endif #ifndef _OSL_DIAGNOSE_H_ #include #endif #ifndef _XMLOFF_FORMS_CALLBACKS_HXX_ #include "callbacks.hxx" #endif #ifndef _XMLOFF_XMLCONSTANTSPROPERTYHANDLER_HXX #include #endif //......................................................................... namespace xmloff { //......................................................................... using namespace ::com::sun::star::uno; using namespace ::com::sun::star::awt; using namespace ::com::sun::star::beans; using namespace ::xmloff::token; //===================================================================== //= OControlPropertyHandlerFactory //===================================================================== //--------------------------------------------------------------------- OControlPropertyHandlerFactory::OControlPropertyHandlerFactory() :m_pTextAlignHandler(NULL) ,m_pControlBorderStyleHandler(NULL) ,m_pControlBorderColorHandler(NULL) ,m_pRotationAngleHandler(NULL) ,m_pFontWidthHandler(NULL) ,m_pFontEmphasisHandler(NULL) ,m_pFontReliefHandler(NULL) { } //--------------------------------------------------------------------- OControlPropertyHandlerFactory::~OControlPropertyHandlerFactory() { delete m_pTextAlignHandler; delete m_pControlBorderStyleHandler; delete m_pControlBorderColorHandler; delete m_pRotationAngleHandler; delete m_pFontWidthHandler; delete m_pFontEmphasisHandler; delete m_pFontReliefHandler; } //--------------------------------------------------------------------- const XMLPropertyHandler* OControlPropertyHandlerFactory::GetPropertyHandler(sal_Int32 _nType) const { const XMLPropertyHandler* pHandler = NULL; switch (_nType) { case XML_TYPE_TEXT_ALIGN: if (!m_pTextAlignHandler) m_pTextAlignHandler = new XMLConstantsPropertyHandler(OEnumMapper::getEnumMap(OEnumMapper::epTextAlign), XML_TOKEN_INVALID ); pHandler = m_pTextAlignHandler; break; case XML_TYPE_CONTROL_BORDER: if (!m_pControlBorderStyleHandler) m_pControlBorderStyleHandler = new OControlBorderStyleHandler; pHandler = m_pControlBorderStyleHandler; break; case XML_TYPE_CONTROL_BORDER_COLOR: if ( !m_pControlBorderColorHandler ) m_pControlBorderColorHandler = new OControlBorderColorHandler; pHandler = m_pControlBorderColorHandler; break; case XML_TYPE_ROTATION_ANGLE: if (!m_pRotationAngleHandler) m_pRotationAngleHandler = new ORotationAngleHandler; pHandler = m_pRotationAngleHandler; break; case XML_TYPE_FONT_WIDTH: if (!m_pFontWidthHandler) m_pFontWidthHandler = new OFontWidthHandler; pHandler = m_pFontWidthHandler; break; case XML_TYPE_CONTROL_TEXT_EMPHASIZE: if (!m_pFontEmphasisHandler) m_pFontEmphasisHandler = new XMLConstantsPropertyHandler( OEnumMapper::getEnumMap(OEnumMapper::epFontEmphasis), XML_NONE ); pHandler = m_pFontEmphasisHandler; break; case XML_TYPE_TEXT_FONT_RELIEF: if (!m_pFontReliefHandler) m_pFontReliefHandler = new XMLConstantsPropertyHandler( OEnumMapper::getEnumMap(OEnumMapper::epFontRelief), XML_NONE ); pHandler = m_pFontReliefHandler; break; } if (!pHandler) pHandler = XMLPropertyHandlerFactory::GetPropertyHandler(_nType); return pHandler; } //===================================================================== //= OControlTextEmphasisHandler //===================================================================== OControlTextEmphasisHandler::OControlTextEmphasisHandler() { } //--------------------------------------------------------------------- sal_Bool OControlTextEmphasisHandler::exportXML( ::rtl::OUString& _rStrExpValue, const Any& _rValue, const SvXMLUnitConverter& ) const { ::rtl::OUStringBuffer aReturn; sal_Bool bSuccess = sal_False; sal_Int16 nFontEmphasis = sal_Int16(); if (_rValue >>= nFontEmphasis) { // the type sal_Int16 nType = nFontEmphasis & ~(FontEmphasisMark::ABOVE | FontEmphasisMark::BELOW); // the position of the mark sal_Bool bBelow = 0 != (nFontEmphasis & FontEmphasisMark::BELOW); // convert bSuccess = SvXMLUnitConverter::convertEnum(aReturn, nType, OEnumMapper::getEnumMap(OEnumMapper::epFontEmphasis), XML_NONE); if (bSuccess) { aReturn.append( (sal_Unicode)' ' ); aReturn.append( GetXMLToken(bBelow ? XML_BELOW : XML_ABOVE) ); _rStrExpValue = aReturn.makeStringAndClear(); } } return bSuccess; } //--------------------------------------------------------------------- sal_Bool OControlTextEmphasisHandler::importXML( const ::rtl::OUString& _rStrImpValue, Any& _rValue, const SvXMLUnitConverter& ) const { sal_Bool bSuccess = sal_True; sal_uInt16 nEmphasis = FontEmphasisMark::NONE; sal_Bool bBelow = sal_False; sal_Bool bHasPos = sal_False, bHasType = sal_False; ::rtl::OUString sToken; SvXMLTokenEnumerator aTokenEnum(_rStrImpValue); while (aTokenEnum.getNextToken(sToken)) { if (!bHasPos) { if (IsXMLToken(sToken, XML_ABOVE)) { bBelow = sal_False; bHasPos = sal_True; } else if (IsXMLToken(sToken, XML_BELOW)) { bBelow = sal_True; bHasPos = sal_True; } } if (!bHasType) { if (SvXMLUnitConverter::convertEnum(nEmphasis, sToken, OEnumMapper::getEnumMap(OEnumMapper::epFontEmphasis))) { bHasType = sal_True; } else { bSuccess = sal_False; break; } } } if (bSuccess) { nEmphasis |= bBelow ? FontEmphasisMark::BELOW : FontEmphasisMark::ABOVE; _rValue <<= (sal_Int16)nEmphasis; } return bSuccess; } //===================================================================== //= OControlBorderHandlerFactory //===================================================================== //--------------------------------------------------------------------- const XMLPropertyHandler* OControlBorderHandlerFactory::createBorderHandler() { return new OControlBorderStyleHandler; } //--------------------------------------------------------------------- const XMLPropertyHandler* OControlBorderHandlerFactory::createBorderColorHandler() { return new OControlBorderColorHandler; } //===================================================================== //= OControlBorderHandlerBase //===================================================================== //--------------------------------------------------------------------- OControlBorderHandlerBase::OControlBorderHandlerBase() { } //--------------------------------------------------------------------- sal_Bool OControlBorderHandlerBase::importXML( const ::rtl::OUString& _rStrImpValue, Any& _rValue, const SvXMLUnitConverter& ) const { ::rtl::OUString sToken; SvXMLTokenEnumerator aTokens(_rStrImpValue); sal_uInt16 nStyle = 1; Color aColor; sal_Bool bFoundStyle = sal_False; sal_Bool bFoundColor = sal_False; while ( !( bFoundStyle && bFoundColor ) // did not yet find both aspects && aTokens.getNextToken(sToken) // have a new token && (0 != sToken.getLength()) // really have a new token ) { // is it a valid enum value? if ( !bFoundStyle ) bFoundStyle = SvXMLUnitConverter::convertEnum(nStyle, sToken, OEnumMapper::getEnumMap(OEnumMapper::epBorderWidth)); // is it a color value? if ( !bFoundColor ) bFoundColor = SvXMLUnitConverter::convertColor( aColor, sToken ); } if ( !bFoundStyle && !bFoundColor ) return sal_False; // if we're here, the string could have had more or less than the requested 3 tokens, but we ignore this. // At least we have a valid style or a valid, which is everything we're interested in. pickOne( aColor, (sal_Int16)nStyle, _rValue ); return sal_True; } //===================================================================== //= OControlBorderStyleHandler //===================================================================== //--------------------------------------------------------------------- OControlBorderStyleHandler::OControlBorderStyleHandler() { } //--------------------------------------------------------------------- sal_Bool OControlBorderStyleHandler::exportXML( ::rtl::OUString& _rStrExpValue, const Any& _rValue, const SvXMLUnitConverter& ) const { sal_Bool bSuccess = sal_False; sal_Int16 nBorder = 0; ::rtl::OUStringBuffer aOut; bSuccess = (_rValue >>= nBorder) && SvXMLUnitConverter::convertEnum(aOut, nBorder, OEnumMapper::getEnumMap(OEnumMapper::epBorderWidth)); if ( _rStrExpValue.getLength() ) _rStrExpValue += ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( " " ) ); _rStrExpValue += aOut.makeStringAndClear(); return bSuccess; } //--------------------------------------------------------------------- void OControlBorderStyleHandler::pickOne( const Color&, sal_Int16 _nStyle, Any& _rValue ) const { _rValue <<= _nStyle; } //===================================================================== //= OControlBorderColorHandler //===================================================================== //--------------------------------------------------------------------- OControlBorderColorHandler::OControlBorderColorHandler() { } //--------------------------------------------------------------------- sal_Bool OControlBorderColorHandler::exportXML( ::rtl::OUString& _rStrExpValue, const Any& _rValue, const SvXMLUnitConverter& ) const { sal_Bool bSuccess = sal_False; sal_Int32 nBorderColor = 0; ::rtl::OUStringBuffer aOut; if ( _rValue >>= nBorderColor ) { SvXMLUnitConverter::convertColor( aOut, Color( nBorderColor ) ); bSuccess = sal_True; } if ( _rStrExpValue.getLength() ) _rStrExpValue += ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( " " ) ); _rStrExpValue += aOut.makeStringAndClear(); return bSuccess; } //--------------------------------------------------------------------- void OControlBorderColorHandler::pickOne( const Color& _rColor, sal_Int16 /*_nStyle*/, Any& _rValue ) const { _rValue <<= (sal_Int32)_rColor.GetColor(); } //===================================================================== //= OFontWidthHandler //===================================================================== //--------------------------------------------------------------------- OFontWidthHandler::OFontWidthHandler() { } //--------------------------------------------------------------------- sal_Bool OFontWidthHandler::importXML( const ::rtl::OUString& _rStrImpValue, Any& _rValue, const SvXMLUnitConverter& ) const { sal_Int32 nWidth = 0; sal_Bool bSuccess = SvXMLUnitConverter::convertMeasure(nWidth, _rStrImpValue, MAP_POINT); if (bSuccess) _rValue <<= (sal_Int16)nWidth; return bSuccess; } //--------------------------------------------------------------------- sal_Bool OFontWidthHandler::exportXML( ::rtl::OUString& _rStrExpValue, const Any& _rValue, const SvXMLUnitConverter& ) const { sal_Int16 nWidth = 0; ::rtl::OUStringBuffer aResult; if (_rValue >>= nWidth) SvXMLUnitConverter::convertMeasure(aResult, nWidth, MAP_POINT, MAP_POINT); _rStrExpValue = aResult.makeStringAndClear(); return _rStrExpValue.getLength() != 0; } //===================================================================== //= ORotationAngleHandler //===================================================================== //--------------------------------------------------------------------- ORotationAngleHandler::ORotationAngleHandler() { } //--------------------------------------------------------------------- sal_Bool ORotationAngleHandler::importXML( const ::rtl::OUString& _rStrImpValue, Any& _rValue, const SvXMLUnitConverter& ) const { double fValue; sal_Bool bSucces = SvXMLUnitConverter::convertDouble(fValue, _rStrImpValue); if (bSucces) { fValue *= 10; _rValue <<= (float)fValue; } return bSucces; } //--------------------------------------------------------------------- sal_Bool ORotationAngleHandler::exportXML( ::rtl::OUString& _rStrExpValue, const Any& _rValue, const SvXMLUnitConverter& ) const { float fAngle = 0; sal_Bool bSuccess = (_rValue >>= fAngle); if (bSuccess) { rtl::OUStringBuffer sValue; SvXMLUnitConverter::convertDouble(sValue, ((double)fAngle) / 10); _rStrExpValue = sValue.makeStringAndClear(); } return bSuccess; } //......................................................................... } // namespace xmloff //.........................................................................