Files
libreoffice/xmloff/source/chart/PropertyMaps.cxx

479 lines
18 KiB
C++
Raw Normal View History

2000-09-18 16:07:07 +00:00
/*************************************************************************
*
* $RCSfile: PropertyMaps.cxx,v $
*
* $Revision: 1.17 $
2000-09-18 16:07:07 +00:00
*
* last change: $Author: aw $ $Date: 2001-02-26 10:24:47 $
2000-09-18 16:07:07 +00:00
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
*
* - GNU Lesser General Public License Version 2.1
* - Sun Industry Standards Source License Version 1.1
*
* Sun Microsystems Inc., October, 2000
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2000 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
*
*
* Sun Industry Standards Source License Version 1.1
* =================================================
* The contents of this file are subject to the Sun Industry Standards
* Source License Version 1.1 (the "License"); You may not use this file
* except in compliance with the License. You may obtain a copy of the
* License at http://www.openoffice.org/license.html.
*
* Software provided under this License is provided on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING,
* WITHOUT LIMITATION, WARRANTIES THAT THE SOFTWARE IS FREE OF DEFECTS,
* MERCHANTABLE, FIT FOR A PARTICULAR PURPOSE, OR NON-INFRINGING.
* See the License for the specific provisions governing your rights and
* obligations concerning the Software.
*
* The Initial Developer of the Original Code is: Sun Microsystems, Inc.
*
* Copyright: 2000 by Sun Microsystems, Inc.
*
* All Rights Reserved.
*
* Contributor(s): _______________________________________
*
*
************************************************************************/
2001-02-14 16:16:39 +00:00
// include PropertyMap.hxx with this define
// to create the maps
#ifndef _PROPERTYMAP_HXX_
#define XML_SCH_CREATE_GLOBAL_MAPS
#include "PropertyMap.hxx"
#undef XML_SCH_CREATE_GLOBAL_MAPS
#endif
2000-09-18 16:07:07 +00:00
#include "XMLChartPropertySetMapper.hxx"
#ifndef _XMLOFF_ENUMPROPERTYHANDLER_HXX
#include "EnumPropertyHdl.hxx"
#endif
#ifndef _XMLOFF_XMLCONSTANTSPROPERTYHANDLER_HXX
#include "XMLConstantsPropertyHandler.hxx"
#endif
2000-09-18 16:07:07 +00:00
#ifndef _XMLOFF_ATTRLIST_HXX
#include "attrlist.hxx"
#endif
#ifndef _XMLOFF_NMSPMAP_HXX
#include "nmspmap.hxx"
#endif
#ifndef _XMLOFF_XMLUCONV_HXX
#include "xmluconv.hxx"
#endif
#ifndef _XMLOFF_SHAPEIMPORT_HXX_
#include "shapeimport.hxx"
#endif
#ifndef _XMLOFF_NAMEDBOOLPROPERTYHANDLER_HXX
#include "NamedBoolPropertyHdl.hxx"
#endif
2000-09-18 16:07:07 +00:00
#ifndef _XMLERRORINDICATORPROPERTYHDL_HXX_
#include "XMLErrorIndicatorPropertyHdl.hxx"
#endif
2000-09-18 16:07:07 +00:00
#ifndef _COM_SUN_STAR_CHART_CHARTAXISMARKS_HPP_
#include <com/sun/star/chart/ChartAxisMarks.hpp>
#endif
#ifndef _COM_SUN_STAR_CHART_CHARTDATACAPTION_HPP_
#include <com/sun/star/chart/ChartDataCaption.hpp>
#endif
#ifndef _COM_SUN_STAR_CHART_CHARTSYMBOLTYPE_HPP_
#include <com/sun/star/chart/ChartSymbolType.hpp>
#endif
#ifndef _COM_SUN_STAR_DRAWING_LINESTYLE_HPP_
#include <com/sun/star/drawing/LineStyle.hpp>
#endif
#ifndef _COM_SUN_STAR_DRAWING_FILLSTYLE_HPP_
#include <com/sun/star/drawing/FillStyle.hpp>
#endif
#ifndef _COM_SUN_STAR_DRAWING_LINEJOINT_HPP_
#include <com/sun/star/drawing/LineJoint.hpp>
#endif
2000-09-18 16:07:07 +00:00
#ifndef _RTL_USTRBUF_HXX_
#include <rtl/ustrbuf.hxx>
#endif
#define SCH_XML_SETFLAG( status, flag ) (status)|= (flag)
#define SCH_XML_UNSETFLAG( status, flag ) (status) = ((status) | (flag)) - (flag)
2000-09-18 16:07:07 +00:00
using namespace com::sun::star;
2001-02-14 16:16:39 +00:00
// the following class implementations are in this file:
//
// * XMLChartPropHdlFactory
// * XMLChartPropertySetMapper
// * XMLChartExportPropertyMapper
// * XMLChartImportPropertyMapper
// * SchXMLStyleExport
2000-09-18 16:07:07 +00:00
// ----------------------------------------
XMLChartPropHdlFactory::~XMLChartPropHdlFactory()
{
}
const XMLPropertyHandler* XMLChartPropHdlFactory::GetPropertyHandler( sal_Int32 nType ) const
{
const XMLPropertyHandler* pHdl = XMLPropertyHandlerFactory::GetPropertyHandler( nType );
if( ! pHdl )
{
switch( nType )
{
case XML_SCH_TYPE_AXIS_ARRANGEMENT:
pHdl = new XMLEnumPropertyHdl( aXMLChartAxisArrangementEnumMap,
::getCppuType((const chart::ChartAxisArrangeOrderType*)0) );
break;
case XML_SCH_TYPE_ERROR_CATEGORY:
pHdl = new XMLEnumPropertyHdl( aXMLChartErrorCategoryEnumMap,
::getCppuType((const chart::ChartErrorCategory*)0) );
break;
case XML_SCH_TYPE_REGRESSION_TYPE:
pHdl = new XMLEnumPropertyHdl( aXMLChartRegressionCurveTypeEnumMap,
::getCppuType((const chart::ChartRegressionCurveType*)0) );
break;
case XML_SCH_TYPE_ERROR_INDICATOR_LOWER:
pHdl = new XMLErrorIndicatorPropertyHdl( sal_False );
break;
case XML_SCH_TYPE_ERROR_INDICATOR_UPPER:
pHdl = new XMLErrorIndicatorPropertyHdl( sal_True );
break;
2000-09-18 16:07:07 +00:00
case XML_SCH_TYPE_SOLID_TYPE:
// here we have a constant rather than an enum
pHdl = new XMLConstantsPropertyHandler( aXMLChartSolidTypeEnumMap, sXML_cuboid );
2000-09-18 16:07:07 +00:00
break;
2000-09-18 16:07:07 +00:00
}
if( pHdl )
PutHdlCache( nType, pHdl );
}
return pHdl;
}
// ----------------------------------------
XMLChartPropertySetMapper::XMLChartPropertySetMapper() :
XMLPropertySetMapper( aXMLChartPropMap, new XMLChartPropHdlFactory )
{
}
XMLChartPropertySetMapper::~XMLChartPropertySetMapper()
{
}
// ----------------------------------------
XMLChartExportPropertyMapper::XMLChartExportPropertyMapper( const UniReference< XMLPropertySetMapper >& rMapper ) :
SvXMLExportPropertyMapper( rMapper ),
msCDATA( rtl::OUString::createFromAscii( sXML_CDATA )),
msTrue( rtl::OUString::createFromAscii( sXML_true )),
msFalse( rtl::OUString::createFromAscii( sXML_false ))
{
}
XMLChartExportPropertyMapper::~XMLChartExportPropertyMapper()
{
}
void XMLChartExportPropertyMapper::ContextFilter(
2000-09-18 16:07:07 +00:00
std::vector< XMLPropertyState >& rProperties,
uno::Reference< beans::XPropertySet > rPropSet ) const
{
::rtl::OUString aAutoPropName;
sal_Bool bCheckAuto = sal_False;
2000-09-18 16:07:07 +00:00
// filter properties
for( std::vector< XMLPropertyState >::iterator property = rProperties.begin();
property != rProperties.end();
property++ )
{
// find properties with context
// to prevent writing this property set mnIndex member to -1
switch( getPropertySetMapper()->GetEntryContextId( property->mnIndex ))
2000-09-18 16:07:07 +00:00
{
case XML_SCH_CONTEXT_USER_SYMBOL:
2000-09-18 16:07:07 +00:00
{
sal_Int32 nIndex = chart::ChartSymbolType::AUTO;
property->maValue >>= nIndex;
if( nIndex == chart::ChartSymbolType::AUTO )
property->mnIndex = -1;
}
break;
// if Auto... is set the corresponding properties mustn't be exported
case XML_SCH_CONTEXT_MIN:
bCheckAuto = sal_True;
aAutoPropName = ::rtl::OUString::createFromAscii( "AutoMin" );
break;
case XML_SCH_CONTEXT_MAX:
bCheckAuto = sal_True;
aAutoPropName = ::rtl::OUString::createFromAscii( "AutoMax" );
break;
case XML_SCH_CONTEXT_STEP_MAIN:
bCheckAuto = sal_True;
aAutoPropName = ::rtl::OUString::createFromAscii( "AutoStepMain" );
break;
case XML_SCH_CONTEXT_STEP_HELP:
bCheckAuto = sal_True;
aAutoPropName = ::rtl::OUString::createFromAscii( "AutoStepHelp" );
break;
case XML_SCH_CONTEXT_ORIGIN:
bCheckAuto = sal_True;
aAutoPropName = ::rtl::OUString::createFromAscii( "AutoOrigin" );
break;
}
if( bCheckAuto )
{
if( rPropSet.is())
{
try
{
sal_Bool bAuto;
uno::Any aAny = rPropSet->getPropertyValue( aAutoPropName );
aAny >>= bAuto;
if( bAuto )
property->mnIndex = -1;
}
catch( beans::UnknownPropertyException )
{
}
}
bCheckAuto = sal_False;
2000-09-18 16:07:07 +00:00
}
}
SvXMLExportPropertyMapper::ContextFilter(rProperties, rPropSet);
2000-09-18 16:07:07 +00:00
}
void XMLChartExportPropertyMapper::handleElementItem(
const uno::Reference< xml::sax::XDocumentHandler > & rHandler,
const XMLPropertyState& rProperty, const SvXMLUnitConverter& rUnitConverter,
2000-10-19 13:25:20 +00:00
const SvXMLNamespaceMap& rNamespaceMap, sal_uInt16 nFlags,
const ::std::vector< XMLPropertyState > *pProperties,
sal_uInt32 nIdx ) const
2000-09-18 16:07:07 +00:00
{
// call parent
2000-10-19 13:25:20 +00:00
SvXMLExportPropertyMapper::handleElementItem( rHandler, rProperty,
rUnitConverter, rNamespaceMap, nFlags, pProperties, nIdx );
2000-09-18 16:07:07 +00:00
}
void XMLChartExportPropertyMapper::handleSpecialItem(
SvXMLAttributeList& rAttrList, const XMLPropertyState& rProperty,
2000-10-19 13:25:20 +00:00
const SvXMLUnitConverter& rUnitConverter,
const SvXMLNamespaceMap& rNamespaceMap,
const ::std::vector< XMLPropertyState > *pProperties,
sal_uInt32 nIdx ) const
2000-09-18 16:07:07 +00:00
{
sal_Int32 nContextId = maPropMapper->GetEntryContextId( rProperty.mnIndex );
if( nContextId )
{
rtl::OUString sAttrName = maPropMapper->GetEntryXMLName( rProperty.mnIndex );
2001-02-14 16:16:39 +00:00
sal_uInt16 nNameSpace = maPropMapper->GetEntryNameSpace( rProperty.mnIndex );
2000-09-18 16:07:07 +00:00
rtl::OUStringBuffer sValueBuffer;
rtl::OUString sValue;
sal_Int32 nValue = 0;
sal_Bool bValue = sal_False;
switch( nContextId )
{
case XML_SCH_CONTEXT_SPECIAL_TICKS_MAJ_INNER:
case XML_SCH_CONTEXT_SPECIAL_TICKS_MIN_INNER:
2000-09-18 16:07:07 +00:00
rProperty.maValue >>= nValue;
bValue = (( nValue & chart::ChartAxisMarks::INNER ) == chart::ChartAxisMarks::INNER );
SvXMLUnitConverter::convertBool( sValueBuffer, bValue );
break;
case XML_SCH_CONTEXT_SPECIAL_TICKS_MAJ_OUTER:
case XML_SCH_CONTEXT_SPECIAL_TICKS_MIN_OUTER:
2000-09-18 16:07:07 +00:00
rProperty.maValue >>= nValue;
bValue = (( nValue & chart::ChartAxisMarks::OUTER ) == chart::ChartAxisMarks::OUTER );
SvXMLUnitConverter::convertBool( sValueBuffer, bValue );
break;
case XML_SCH_CONTEXT_SPECIAL_TEXT_ROTATION:
2000-09-18 16:07:07 +00:00
{
// convert from 100th degrees to degrees (double)
rProperty.maValue >>= nValue;
double fVal = (double)(nValue) / 100.0;
SvXMLUnitConverter::convertDouble( sValueBuffer, fVal );
2000-09-18 16:07:07 +00:00
}
break;
case XML_SCH_CONTEXT_SPECIAL_DATA_LABEL_NUMBER:
2000-09-18 16:07:07 +00:00
{
rProperty.maValue >>= nValue;
if((( nValue & chart::ChartDataCaption::VALUE ) == chart::ChartDataCaption::VALUE ))
sValueBuffer.appendAscii( RTL_CONSTASCII_STRINGPARAM( sXML_value ));
else if(( nValue & chart::ChartDataCaption::PERCENT ) == chart::ChartDataCaption::PERCENT )
sValueBuffer.appendAscii( RTL_CONSTASCII_STRINGPARAM( sXML_percentage ));
else
sValueBuffer.appendAscii( RTL_CONSTASCII_STRINGPARAM( sXML_none ));
}
break;
case XML_SCH_CONTEXT_SPECIAL_DATA_LABEL_TEXT:
2000-09-18 16:07:07 +00:00
rProperty.maValue >>= nValue;
bValue = (( nValue & chart::ChartDataCaption::TEXT ) == chart::ChartDataCaption::TEXT );
SvXMLUnitConverter::convertBool( sValueBuffer, bValue );
break;
case XML_SCH_CONTEXT_SPECIAL_DATA_LABEL_SYMBOL:
2000-09-18 16:07:07 +00:00
rProperty.maValue >>= nValue;
bValue = (( nValue & chart::ChartDataCaption::SYMBOL ) == chart::ChartDataCaption::SYMBOL );
SvXMLUnitConverter::convertBool( sValueBuffer, bValue );
break;
}
if( sValueBuffer.getLength())
{
sValue = sValueBuffer.makeStringAndClear();
sAttrName = rNamespaceMap.GetQNameByKey( nNameSpace, sAttrName );
rAttrList.AddAttribute( sAttrName, msCDATA, sValue );
}
2000-09-18 16:07:07 +00:00
}
else
{
// call parent
2000-10-19 13:25:20 +00:00
SvXMLExportPropertyMapper::handleSpecialItem( rAttrList, rProperty, rUnitConverter, rNamespaceMap, pProperties, nIdx );
2000-09-18 16:07:07 +00:00
}
}
// ----------------------------------------
XMLChartImportPropertyMapper::XMLChartImportPropertyMapper( const UniReference< XMLPropertySetMapper >& rMapper ) :
SvXMLImportPropertyMapper( rMapper )
{
// chain shape mapper for drawing properties
// give an empty model. It is only used for numbering rules that don't exist in chart
uno::Reference< frame::XModel > xEmptyModel;
ChainImportMapper( XMLShapeImportHelper::CreateShapePropMapper( xEmptyModel ));
2000-09-18 16:07:07 +00:00
}
XMLChartImportPropertyMapper::~XMLChartImportPropertyMapper()
{
}
sal_Bool XMLChartImportPropertyMapper::handleSpecialItem(
XMLPropertyState& rProperty,
::std::vector< XMLPropertyState >& rProperties,
const ::rtl::OUString& rValue,
const SvXMLUnitConverter& rUnitConverter,
const SvXMLNamespaceMap& rNamespaceMap ) const
{
sal_Int32 nContextId = maPropMapper->GetEntryContextId( rProperty.mnIndex );
sal_Bool bRet = (nContextId != 0);
if( nContextId )
{
sal_Int32 nValue = 0;
sal_Bool bValue = sal_False;
switch( nContextId )
{
case XML_SCH_CONTEXT_SPECIAL_TICKS_MAJ_INNER:
case XML_SCH_CONTEXT_SPECIAL_TICKS_MIN_INNER:
SvXMLUnitConverter::convertBool( bValue, rValue );
// modify old value
rProperty.maValue >>= nValue;
if( bValue )
SCH_XML_SETFLAG( nValue, chart::ChartAxisMarks::INNER );
else
SCH_XML_UNSETFLAG( nValue, chart::ChartAxisMarks::INNER );
rProperty.maValue <<= nValue;
break;
case XML_SCH_CONTEXT_SPECIAL_TICKS_MAJ_OUTER:
case XML_SCH_CONTEXT_SPECIAL_TICKS_MIN_OUTER:
SvXMLUnitConverter::convertBool( bValue, rValue );
// modify old value
rProperty.maValue >>= nValue;
if( bValue )
SCH_XML_SETFLAG( nValue, chart::ChartAxisMarks::OUTER );
else
SCH_XML_UNSETFLAG( nValue, chart::ChartAxisMarks::OUTER );
rProperty.maValue <<= nValue;
break;
case XML_SCH_CONTEXT_SPECIAL_TEXT_ROTATION:
{
// convert from degrees (double) to 100th degrees (integer)
double fVal;
SvXMLUnitConverter::convertDouble( fVal, rValue );
nValue = (sal_Int32)( fVal * 100.0 );
rProperty.maValue <<= nValue;
}
break;
case XML_SCH_CONTEXT_SPECIAL_DATA_LABEL_NUMBER:
{
// modify old value
rProperty.maValue >>= nValue;
if( rValue.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sXML_none )))
SCH_XML_UNSETFLAG( nValue, chart::ChartDataCaption::VALUE | chart::ChartDataCaption::PERCENT );
else if( rValue.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( sXML_value )))
SCH_XML_SETFLAG( nValue, chart::ChartDataCaption::VALUE );
else // must be sXML_percentage
SCH_XML_SETFLAG( nValue, chart::ChartDataCaption::PERCENT );
rProperty.maValue <<= nValue;
}
break;
case XML_SCH_CONTEXT_SPECIAL_DATA_LABEL_TEXT:
rProperty.maValue >>= nValue;
SvXMLUnitConverter::convertBool( bValue, rValue );
if( bValue )
SCH_XML_SETFLAG( nValue, chart::ChartDataCaption::TEXT );
else
SCH_XML_UNSETFLAG( nValue, chart::ChartDataCaption::TEXT );
rProperty.maValue <<= nValue;
break;
case XML_SCH_CONTEXT_SPECIAL_DATA_LABEL_SYMBOL:
rProperty.maValue >>= nValue;
SvXMLUnitConverter::convertBool( bValue, rValue );
if( bValue )
SCH_XML_SETFLAG( nValue, chart::ChartDataCaption::SYMBOL );
else
SCH_XML_UNSETFLAG( nValue, chart::ChartDataCaption::SYMBOL );
rProperty.maValue <<= nValue;
break;
default:
bRet = sal_False;
break;
}
}
else
{
// call parent
bRet = SvXMLImportPropertyMapper::handleSpecialItem( rProperty, rProperties, rValue, rUnitConverter, rNamespaceMap );
}
return bRet;
2000-09-18 16:07:07 +00:00
}
void XMLChartImportPropertyMapper::finished( ::std::vector< XMLPropertyState >& rProperties, sal_Int32 nStartIndex, sal_Int32 nEndIndex ) const
2000-09-18 16:07:07 +00:00
{
}