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

702 lines
27 KiB
C++
Raw Normal View History

2000-09-18 16:07:07 +00:00
/*************************************************************************
*
* OpenOffice.org - a multi-platform office productivity suite
2000-09-18 16:07:07 +00:00
*
* $RCSfile: PropertyMaps.cxx,v $
2000-09-18 16:07:07 +00:00
*
* $Revision: 1.48 $
2000-09-18 16:07:07 +00:00
*
* last change: $Author: vg $ $Date: 2007-05-22 16:05:25 $
2000-09-18 16:07:07 +00:00
*
* The Contents of this file are made available subject to
* the terms of GNU Lesser General Public License Version 2.1.
2000-09-18 16:07:07 +00:00
*
*
* GNU Lesser General Public License Version 2.1
* =============================================
* Copyright 2005 by Sun Microsystems, Inc.
* 901 San Antonio Road, Palo Alto, CA 94303, USA
2000-09-18 16:07:07 +00:00
*
* 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.
2000-09-18 16:07:07 +00:00
*
* 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.
2000-09-18 16:07:07 +00:00
*
* 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
2000-09-18 16:07:07 +00:00
*
************************************************************************/
// MARKER(update_precomp.py): autogen include statement, do not remove
#include "precompiled_xmloff.hxx"
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
2001-05-11 17:17:56 +00:00
#ifndef _XMLOFF_XMLEXP_HXX
#include "xmlexp.hxx"
#endif
#ifndef _XMLOFF_XMLTOKEN_HXX
#include "xmltoken.hxx"
#endif
2000-09-18 16:07:07 +00:00
#ifndef _XMLERRORINDICATORPROPERTYHDL_HXX_
#include "XMLErrorIndicatorPropertyHdl.hxx"
#endif
#ifndef _XMLTEXTORIENTATIONHDL_HXX_
#include "XMLTextOrientationHdl.hxx"
#endif
#ifndef _XMLSYMBOLTYPEPROPERTYHDL_HXX_
#include "XMLSymbolTypePropertyHdl.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
2001-04-25 15:36:55 +00:00
#ifndef _COM_SUN_STAR_CHART_CHARTDATAROWSOURCE_HPP_
#include <com/sun/star/chart/ChartDataRowSource.hpp>
#endif
2000-09-18 16:07:07 +00:00
2001-04-25 15:36:55 +00:00
// header for any2enum
#ifndef _COMPHELPER_EXTRACT_HXX_
#include <comphelper/extract.hxx>
#endif
2000-09-18 16:07:07 +00:00
#ifndef _RTL_USTRBUF_HXX_
#include <rtl/ustrbuf.hxx>
#endif
#ifndef INCLUDED_RTL_MATH_HXX
#include <rtl/math.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;
using namespace ::xmloff::token;
2000-09-18 16:07:07 +00:00
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 XMLEnumPropertyHdl( aXMLChartSolidTypeEnumMap,
::getCppuType((const sal_Int32*)0) );
2000-09-18 16:07:07 +00:00
break;
2001-05-11 17:17:56 +00:00
case XML_SCH_TYPE_DATAROWSOURCE:
pHdl = new XMLEnumPropertyHdl( aXMLChartDataRowSourceTypeEnumMap,
::getCppuType((const chart::ChartDataRowSource*)0) );
break;
case XML_SCH_TYPE_TEXT_ORIENTATION:
pHdl = new XMLTextOrientationHdl();
break;
case XML_SCH_TYPE_INTERPOLATION:
pHdl = new XMLEnumPropertyHdl( aXMLChartInterpolationTypeEnumMap,
::getCppuType((const sal_Int32*)0) );
break;
case XML_SCH_TYPE_SYMBOL_TYPE:
pHdl = new XMLSymbolTypePropertyHdl( false );
break;
case XML_SCH_TYPE_NAMED_SYMBOL:
pHdl = new XMLSymbolTypePropertyHdl( true );
break;
}
2000-09-18 16:07:07 +00:00
if( pHdl )
PutHdlCache( nType, pHdl );
}
return pHdl;
}
// ----------------------------------------
XMLChartPropertySetMapper::XMLChartPropertySetMapper() :
XMLPropertySetMapper( aXMLChartPropMap, new XMLChartPropHdlFactory )
{
}
XMLChartPropertySetMapper::~XMLChartPropertySetMapper()
{
}
// ----------------------------------------
2001-05-11 17:17:56 +00:00
XMLChartExportPropertyMapper::XMLChartExportPropertyMapper( const UniReference< XMLPropertySetMapper >& rMapper,
SvXMLExport& rExport) :
SvXMLExportPropertyMapper( rMapper ),
msTrue( GetXMLToken( XML_TRUE )),
msFalse( GetXMLToken( XML_FALSE )),
2001-05-11 17:17:56 +00:00
mrExport( rExport )
{
// chain draw properties
ChainExportMapper( XMLShapeExport::CreateShapePropMapper( rExport ));
// chain text properties
ChainExportMapper( XMLTextParagraphExport::CreateParaExtPropMapper( rExport ));
}
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
{
// 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_ORIGIN:
bCheckAuto = sal_True;
aAutoPropName = ::rtl::OUString::createFromAscii( "AutoOrigin" );
break;
// the following property is deprecated
// elemet-item symbol-image is used now
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_IMAGE_NAME:
property->mnIndex = -1;
break;
case XML_SCH_CONTEXT_STOCK_WITH_VOLUME:
case XML_SCH_CONTEXT_LINES_USED:
// note this avoids export of the properties in OASIS format,
// but also for the OOo XML Flat format (used by binfilter),
// because there, the transformation to OOo is done after the
// complete export of the chart in OASIS format.
if( mrExport.getExportFlags() & EXPORT_OASIS )
property->mnIndex = -1;
break;
case XML_SCH_CONTEXT_SPECIAL_STEP_HELP:
{
// do auto-check directly
sal_Bool bAuto = false;
uno::Any aAny = rPropSet->getPropertyValue( ::rtl::OUString::createFromAscii( "AutoStepHelp" ) );
aAny >>= bAuto;
if( bAuto )
property->mnIndex = -1;
else
{
double fValue = 0.0, fMainStep = 0.0;
sal_Bool bIsLogarithmic = sal_False;
(*property).maValue >>= fValue;
sal_Int32 nDivisor = static_cast< sal_Int32 >( fValue );
if( (rPropSet->getPropertyValue(
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Logarithmic" ))) >>= bIsLogarithmic) &&
(rPropSet->getPropertyValue(
::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "StepMain" ))) >>= fMainStep) )
{
// for logarithmic scaling the help steps are already divisors
if( ! bIsLogarithmic &&
(fValue <= fMainStep) &&
(fValue != 0.0) )
{
nDivisor = static_cast< sal_Int32 >(
::rtl::math::round( fMainStep / fValue ));
}
}
(*property).maValue <<= nDivisor;
}
}
break;
}
if( bCheckAuto )
{
if( rPropSet.is())
{
try
{
sal_Bool bAuto = false;
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(
SvXMLExport& rExport,
const XMLPropertyState& rProperty, sal_uInt16 nFlags,
2000-10-19 13:25:20 +00:00
const ::std::vector< XMLPropertyState > *pProperties,
sal_uInt32 nIdx ) const
2000-09-18 16:07:07 +00:00
{
switch( getPropertySetMapper()->GetEntryContextId( rProperty.mnIndex ))
{
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_IMAGE:
{
::rtl::OUString aURLStr;
rProperty.maValue >>= aURLStr;
// export as XLink reference into the package
// if embedding is off
::rtl::OUString sTempURL( mrExport.AddEmbeddedGraphicObject( aURLStr ));
if( sTempURL.getLength() )
{
mrExport.AddAttribute( XML_NAMESPACE_XLINK, XML_HREF, sTempURL );
mrExport.AddAttribute( XML_NAMESPACE_XLINK, XML_TYPE,
XML_SIMPLE );
mrExport.AddAttribute( XML_NAMESPACE_XLINK, XML_ACTUATE,
XML_ONLOAD );
}
{
sal_uInt32 nPropIndex = rProperty.mnIndex;
// this is the element that has to live until the next statement
SvXMLElementExport aElem( mrExport,
getPropertySetMapper()->GetEntryNameSpace( nPropIndex ),
getPropertySetMapper()->GetEntryXMLName( nPropIndex ),
sal_True, sal_True );
// export as Base64 embedded graphic
// if embedding is on
if( aURLStr.getLength())
mrExport.AddEmbeddedGraphicObjectAsBase64( aURLStr );
}
}
break;
default:
// call parent
SvXMLExportPropertyMapper::handleElementItem( rExport, rProperty,
nFlags, pProperties, nIdx );
break;
}
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_Bool bHandled = sal_False;
2000-09-18 16:07:07 +00:00
sal_Int32 nContextId = maPropMapper->GetEntryContextId( rProperty.mnIndex );
if( nContextId )
{
bHandled = sal_True;
2000-09-18 16:07:07 +00:00
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.append( GetXMLToken( XML_VALUE ));
2000-09-18 16:07:07 +00:00
else if(( nValue & chart::ChartDataCaption::PERCENT ) == chart::ChartDataCaption::PERCENT )
sValueBuffer.append( GetXMLToken( XML_PERCENTAGE ));
2000-09-18 16:07:07 +00:00
else
sValueBuffer.append( GetXMLToken( XML_NONE ));
2000-09-18 16:07:07 +00:00
}
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;
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_WIDTH:
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_HEIGHT:
{
awt::Size aSize;
rProperty.maValue >>= aSize;
rUnitConverter.convertMeasure( sValueBuffer,
nContextId == XML_SCH_CONTEXT_SPECIAL_SYMBOL_WIDTH
? aSize.Width
: aSize.Height );
}
break;
case XML_SCH_CONTEXT_SPECIAL_NUMBER_FORMAT:
{
// just for import
break;
}
case XML_SCH_CONTEXT_SPECIAL_STEP_HELP:
{
OSL_ENSURE( false, "Should not get here" );
// handled in ContextFilter
break;
}
default:
bHandled = sal_False;
break;
2000-09-18 16:07:07 +00:00
}
if( sValueBuffer.getLength())
{
sValue = sValueBuffer.makeStringAndClear();
sAttrName = rNamespaceMap.GetQNameByKey( nNameSpace, sAttrName );
rAttrList.AddAttribute( sAttrName, sValue );
}
2000-09-18 16:07:07 +00:00
}
if( !bHandled )
2000-09-18 16:07:07 +00:00
{
// 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
}
}
// ----------------------------------------
2001-05-11 17:17:56 +00:00
XMLChartImportPropertyMapper::XMLChartImportPropertyMapper( const UniReference< XMLPropertySetMapper >& rMapper,
const SvXMLImport& _rImport ) :
SvXMLImportPropertyMapper( rMapper, const_cast< SvXMLImport & >( _rImport )),
mrImport( const_cast< SvXMLImport & > ( _rImport ))
2000-09-18 16:07:07 +00:00
{
// 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, mrImport ));
// do not chain text properties: on import this is done by shape mapper
// to import old documents
// ChainImportMapper( XMLTextImportHelper::CreateParaExtPropMapper());
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
{
2001-05-11 17:17:56 +00:00
static const ::rtl::OUString sPackageProtocol( RTL_CONSTASCII_USTRINGPARAM( "vnd.sun.star.Package:" ) );
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( IsXMLToken( rValue, XML_NONE ))
SCH_XML_UNSETFLAG( nValue, chart::ChartDataCaption::VALUE | chart::ChartDataCaption::PERCENT );
else if( IsXMLToken( rValue, XML_VALUE ) )
SCH_XML_SETFLAG( nValue, chart::ChartDataCaption::VALUE );
else // must be XML_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;
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_WIDTH:
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_HEIGHT:
{
awt::Size aSize;
rProperty.maValue >>= aSize;
rUnitConverter.convertMeasure( nContextId == XML_SCH_CONTEXT_SPECIAL_SYMBOL_WIDTH
? aSize.Width
: aSize.Height,
rValue );
rProperty.maValue <<= aSize;
}
break;
// deprecated from 6.0 beta on
2001-05-11 17:17:56 +00:00
case XML_SCH_CONTEXT_SPECIAL_SYMBOL_IMAGE_NAME:
rProperty.maValue <<= mrImport.ResolveGraphicObjectURL( rValue, sal_False );
break;
case XML_SCH_CONTEXT_SPECIAL_STEP_HELP:
{
double fStepHelp = 0.0;
double fStepMain = 0.0;
sal_Bool bIsLogarithmic = sal_False;
bool bHelpStepValid = false;
bool bAutoMainStep = true;
sal_Int32 nDivisor = 0;
SvXMLUnitConverter::convertNumber( nDivisor, rValue );
if( nDivisor != 0 )
{
for( ::std::vector< XMLPropertyState >::const_iterator aIt = rProperties.begin();
aIt != rProperties.end();
aIt++ )
{
if( (*aIt).mnIndex != -1 )
{
switch( getPropertySetMapper()->GetEntryContextId( (*aIt).mnIndex ))
{
case XML_SCH_CONTEXT_STEP_MAIN:
(*aIt).maValue >>= fStepMain;
bAutoMainStep = false;
break;
case XML_SCH_CONTEXT_LOGARITHMIC:
(*aIt).maValue >>= bIsLogarithmic;
break;
}
}
}
if( bIsLogarithmic )
{
fStepHelp = static_cast< double >( nDivisor );
bHelpStepValid = true;
}
else if( !bAutoMainStep && nDivisor != 0 )
{
fStepHelp = fStepMain / static_cast< double >( nDivisor );
bHelpStepValid = true;
}
else
{
// no logarithmic scaling, the divisor is 0 (which
// doesn't make sense) or we have an auto main step,
// where the concrete value cannot be determined unless
// the data is attached to the cahrt. This is some more
// or less unspecific point of time in the
// future. Therefore we fall back to auto help step here
bHelpStepValid = false;
}
}
if( bHelpStepValid )
rProperty.maValue <<= fStepHelp;
else
rProperty.mnIndex = -1;
}
break;
default:
bRet = sal_False;
break;
}
}
// if we didn't handle it, the parent should
if( !bRet )
{
// 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
{
}