/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */ /************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org 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 version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #include "VLegendSymbolFactory.hxx" #include "macros.hxx" #include "PropertyMapper.hxx" #include "ShapeFactory.hxx" #include "ObjectIdentifier.hxx" #include #include using namespace ::com::sun::star; using ::com::sun::star::uno::Reference; using ::com::sun::star::uno::Sequence; using ::rtl::OUString; namespace { void lcl_setPropetiesToShape( const Reference< beans::XPropertySet > & xProp, const Reference< drawing::XShape > & xShape, ::chart::VLegendSymbolFactory::tPropertyType ePropertyType, const awt::Size& aMaxSymbolExtent = awt::Size(0,0)) { const ::chart::tPropertyNameMap & aFilledSeriesNameMap( ::chart::PropertyMapper::getPropertyNameMapForFilledSeriesProperties()); const ::chart::tPropertyNameMap & aLineSeriesNameMap( ::chart::PropertyMapper::getPropertyNameMapForLineSeriesProperties()); const ::chart::tPropertyNameMap & aLineNameMap( ::chart::PropertyMapper::getPropertyNameMapForLineProperties()); const ::chart::tPropertyNameMap & aFillNameMap( ::chart::PropertyMapper::getPropertyNameMapForFillProperties()); const ::chart::tPropertyNameMap & aFillLineNameMap( ::chart::PropertyMapper::getPropertyNameMapForFillAndLineProperties()); Reference< beans::XPropertySet > xShapeProp( xShape, uno::UNO_QUERY ); if( xProp.is() && xShapeProp.is() ) { ::chart::tPropertyNameValueMap aValueMap; switch( ePropertyType ) { case ::chart::VLegendSymbolFactory::PROP_TYPE_FILLED_SERIES: ::chart::PropertyMapper::getValueMap( aValueMap, aFilledSeriesNameMap, xProp ); break; case ::chart::VLegendSymbolFactory::PROP_TYPE_LINE_SERIES: ::chart::PropertyMapper::getValueMap( aValueMap, aLineSeriesNameMap, xProp ); break; case ::chart::VLegendSymbolFactory::PROP_TYPE_LINE: ::chart::PropertyMapper::getValueMap( aValueMap, aLineNameMap, xProp ); break; case ::chart::VLegendSymbolFactory::PROP_TYPE_FILL: ::chart::PropertyMapper::getValueMap( aValueMap, aFillNameMap, xProp ); break; case ::chart::VLegendSymbolFactory::PROP_TYPE_FILL_AND_LINE: ::chart::PropertyMapper::getValueMap( aValueMap, aFillLineNameMap, xProp ); break; } ::chart::tNameSequence aPropNames; ::chart::tAnySequence aPropValues; ::chart::PropertyMapper::getMultiPropertyListsFromValueMap( aPropNames, aPropValues, aValueMap ); uno::Any* pLineWidthAny = ::chart::PropertyMapper::getValuePointer(aPropValues,aPropNames,C2U("LineWidth")); sal_Int32 nLineWidth = 0; if( pLineWidthAny && (*pLineWidthAny>>=nLineWidth) ) { // use legend entry height as upper limit for line width sal_Int32 nMaxLineWidthForLegend = aMaxSymbolExtent.Height; if( nLineWidth>nMaxLineWidthForLegend ) *pLineWidthAny = uno::makeAny( nMaxLineWidthForLegend ); } ::chart::PropertyMapper::setMultiProperties( aPropNames, aPropValues, xShapeProp ); } } } // anonymous namespace namespace chart { Reference< drawing::XShape > VLegendSymbolFactory::createSymbol( const awt::Size& rEntryKeyAspectRatio, const Reference< drawing::XShapes > xSymbolContainer, LegendSymbolStyle eStyle, const Reference< lang::XMultiServiceFactory > & xShapeFactory, const Reference< beans::XPropertySet > & xLegendEntryProperties, tPropertyType ePropertyType, const uno::Any& rExplicitSymbol ) { Reference< drawing::XShape > xResult; if( ! (xSymbolContainer.is() && xShapeFactory.is())) return xResult; xResult.set( xShapeFactory->createInstance( C2U( "com.sun.star.drawing.GroupShape" )), uno::UNO_QUERY ); xSymbolContainer->add( xResult ); Reference< drawing::XShapes > xResultGroup( xResult, uno::UNO_QUERY ); if( ! xResultGroup.is()) return xResult; // add an invisible square box to maintain aspect ratio Reference< drawing::XShape > xBound( ShapeFactory(xShapeFactory).createInvisibleRectangle( xResultGroup, rEntryKeyAspectRatio )); // create symbol try { if( eStyle == LegendSymbolStyle_LINE ) { Reference< drawing::XShape > xLine( xShapeFactory->createInstance( C2U( "com.sun.star.drawing.LineShape" )), uno::UNO_QUERY ); if( xLine.is()) { xResultGroup->add( xLine ); xLine->setSize( awt::Size( rEntryKeyAspectRatio.Width, 0 )); xLine->setPosition( awt::Point( 0, rEntryKeyAspectRatio.Height/2 )); lcl_setPropetiesToShape( xLegendEntryProperties, xLine, ePropertyType, rEntryKeyAspectRatio ); } Reference< drawing::XShape > xSymbol; const sal_Int32 nSize = std::min(rEntryKeyAspectRatio.Width,rEntryKeyAspectRatio.Height); chart2::Symbol aSymbol; if( rExplicitSymbol >>= aSymbol ) { drawing::Direction3D aSymbolSize( nSize, nSize, 0 ); drawing::Position3D aPos( rEntryKeyAspectRatio.Width/2, rEntryKeyAspectRatio.Height/2, 0 ); ShapeFactory aFactory( xShapeFactory ); if( aSymbol.Style == chart2::SymbolStyle_STANDARD ) { // take series color as fill color xLegendEntryProperties->getPropertyValue( C2U("Color")) >>= aSymbol.FillColor; // border of symbols always same as fill color aSymbol.BorderColor = aSymbol.FillColor; xSymbol.set( aFactory.createSymbol2D( xResultGroup, aPos, aSymbolSize, aSymbol.StandardSymbol, aSymbol.BorderColor, aSymbol.FillColor )); } else if( aSymbol.Style == chart2::SymbolStyle_GRAPHIC ) { xSymbol.set( aFactory.createGraphic2D( xResultGroup, aPos, aSymbolSize, aSymbol.Graphic )); } else if( aSymbol.Style == chart2::SymbolStyle_AUTO ) { OSL_TRACE("the given parameter is not allowed to contain an automatic symbol style"); } } } else if( eStyle == LegendSymbolStyle_CIRCLE ) { Reference< drawing::XShape > xShape( xShapeFactory->createInstance( C2U( "com.sun.star.drawing.EllipseShape" )), uno::UNO_QUERY ); if( xShape.is() ) { xResultGroup->add( xShape ); sal_Int32 nSize = std::min( rEntryKeyAspectRatio.Width, rEntryKeyAspectRatio.Height ); xShape->setSize( awt::Size( nSize, nSize ) ); xShape->setPosition( awt::Point( rEntryKeyAspectRatio.Width/2-nSize/2, rEntryKeyAspectRatio.Height/2-nSize/2 ) ); lcl_setPropetiesToShape( xLegendEntryProperties, xShape, ePropertyType ); // PROP_TYPE_FILLED_SERIES ); } } else // eStyle == LegendSymbolStyle_BOX { Reference< drawing::XShape > xShape( xShapeFactory->createInstance( C2U( "com.sun.star.drawing.RectangleShape" )), uno::UNO_QUERY ); if( xShape.is() ) { xResultGroup->add( xShape ); xShape->setSize( rEntryKeyAspectRatio ); xShape->setPosition( awt::Point( 0, 0 ) ); lcl_setPropetiesToShape( xLegendEntryProperties, xShape, ePropertyType ); // PROP_TYPE_FILLED_SERIES ); } } } catch( const uno::Exception & ex ) { ASSERT_EXCEPTION( ex ); } return xResult; } } // namespace chart /* vim:set shiftwidth=4 softtabstop=4 expandtab: */