1*cdf0e10cSrcweir /************************************************************************* 2*cdf0e10cSrcweir * 3*cdf0e10cSrcweir * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4*cdf0e10cSrcweir * 5*cdf0e10cSrcweir * Copyright 2000, 2010 Oracle and/or its affiliates. 6*cdf0e10cSrcweir * 7*cdf0e10cSrcweir * OpenOffice.org - a multi-platform office productivity suite 8*cdf0e10cSrcweir * 9*cdf0e10cSrcweir * This file is part of OpenOffice.org. 10*cdf0e10cSrcweir * 11*cdf0e10cSrcweir * OpenOffice.org is free software: you can redistribute it and/or modify 12*cdf0e10cSrcweir * it under the terms of the GNU Lesser General Public License version 3 13*cdf0e10cSrcweir * only, as published by the Free Software Foundation. 14*cdf0e10cSrcweir * 15*cdf0e10cSrcweir * OpenOffice.org is distributed in the hope that it will be useful, 16*cdf0e10cSrcweir * but WITHOUT ANY WARRANTY; without even the implied warranty of 17*cdf0e10cSrcweir * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 18*cdf0e10cSrcweir * GNU Lesser General Public License version 3 for more details 19*cdf0e10cSrcweir * (a copy is included in the LICENSE file that accompanied this code). 20*cdf0e10cSrcweir * 21*cdf0e10cSrcweir * You should have received a copy of the GNU Lesser General Public License 22*cdf0e10cSrcweir * version 3 along with OpenOffice.org. If not, see 23*cdf0e10cSrcweir * <http://www.openoffice.org/license.html> 24*cdf0e10cSrcweir * for a copy of the LGPLv3 License. 25*cdf0e10cSrcweir * 26*cdf0e10cSrcweir ************************************************************************/ 27*cdf0e10cSrcweir 28*cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove 29*cdf0e10cSrcweir #include "precompiled_chart2.hxx" 30*cdf0e10cSrcweir #include "ChartModelHelper.hxx" 31*cdf0e10cSrcweir #include "macros.hxx" 32*cdf0e10cSrcweir #include "DiagramHelper.hxx" 33*cdf0e10cSrcweir #include "DataSourceHelper.hxx" 34*cdf0e10cSrcweir #include "ControllerLockGuard.hxx" 35*cdf0e10cSrcweir #include "RangeHighlighter.hxx" 36*cdf0e10cSrcweir #include "InternalDataProvider.hxx" 37*cdf0e10cSrcweir 38*cdf0e10cSrcweir #include <com/sun/star/chart2/data/XDataReceiver.hpp> 39*cdf0e10cSrcweir #include <com/sun/star/chart2/XChartDocument.hpp> 40*cdf0e10cSrcweir #include <com/sun/star/chart2/XChartTypeContainer.hpp> 41*cdf0e10cSrcweir #include <com/sun/star/chart2/XCoordinateSystemContainer.hpp> 42*cdf0e10cSrcweir #include <com/sun/star/chart2/XDataSeriesContainer.hpp> 43*cdf0e10cSrcweir #include <com/sun/star/embed/Aspects.hpp> 44*cdf0e10cSrcweir #include <com/sun/star/embed/XVisualObject.hpp> 45*cdf0e10cSrcweir #include <com/sun/star/view/XSelectionChangeListener.hpp> 46*cdf0e10cSrcweir 47*cdf0e10cSrcweir // header for define DBG_ASSERT 48*cdf0e10cSrcweir #include <tools/debug.hxx> 49*cdf0e10cSrcweir 50*cdf0e10cSrcweir //............................................................................. 51*cdf0e10cSrcweir namespace chart 52*cdf0e10cSrcweir { 53*cdf0e10cSrcweir //............................................................................. 54*cdf0e10cSrcweir using namespace ::com::sun::star; 55*cdf0e10cSrcweir using namespace ::com::sun::star::chart2; 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir uno::Reference< chart2::data::XRangeHighlighter > ChartModelHelper::createRangeHighlighter( 58*cdf0e10cSrcweir const uno::Reference< view::XSelectionSupplier > & xSelectionSupplier ) 59*cdf0e10cSrcweir { 60*cdf0e10cSrcweir return new RangeHighlighter( xSelectionSupplier ); 61*cdf0e10cSrcweir } 62*cdf0e10cSrcweir 63*cdf0e10cSrcweir uno::Reference< chart2::data::XDataProvider > ChartModelHelper::createInternalDataProvider( 64*cdf0e10cSrcweir const uno::Reference< ::com::sun::star::chart2::XChartDocument >& xChartDoc, bool bConnectToModel ) 65*cdf0e10cSrcweir { 66*cdf0e10cSrcweir return new InternalDataProvider( xChartDoc, bConnectToModel ); 67*cdf0e10cSrcweir } 68*cdf0e10cSrcweir 69*cdf0e10cSrcweir uno::Reference< XDiagram > ChartModelHelper::findDiagram( const uno::Reference< frame::XModel >& xModel ) 70*cdf0e10cSrcweir { 71*cdf0e10cSrcweir uno::Reference< XChartDocument > xChartDoc( xModel, uno::UNO_QUERY ); 72*cdf0e10cSrcweir if( xChartDoc.is()) 73*cdf0e10cSrcweir return ChartModelHelper::findDiagram( xChartDoc ); 74*cdf0e10cSrcweir return NULL; 75*cdf0e10cSrcweir } 76*cdf0e10cSrcweir 77*cdf0e10cSrcweir uno::Reference< XDiagram > ChartModelHelper::findDiagram( const uno::Reference< chart2::XChartDocument >& xChartDoc ) 78*cdf0e10cSrcweir { 79*cdf0e10cSrcweir try 80*cdf0e10cSrcweir { 81*cdf0e10cSrcweir if( xChartDoc.is()) 82*cdf0e10cSrcweir return xChartDoc->getFirstDiagram(); 83*cdf0e10cSrcweir } 84*cdf0e10cSrcweir catch( uno::Exception & ex ) 85*cdf0e10cSrcweir { 86*cdf0e10cSrcweir ASSERT_EXCEPTION( ex ); 87*cdf0e10cSrcweir } 88*cdf0e10cSrcweir return NULL; 89*cdf0e10cSrcweir } 90*cdf0e10cSrcweir 91*cdf0e10cSrcweir uno::Reference< XCoordinateSystem > ChartModelHelper::getFirstCoordinateSystem( const uno::Reference< frame::XModel >& xModel ) 92*cdf0e10cSrcweir { 93*cdf0e10cSrcweir uno::Reference< XCoordinateSystem > XCooSys; 94*cdf0e10cSrcweir uno::Reference< XCoordinateSystemContainer > xCooSysCnt( ChartModelHelper::findDiagram( xModel ), uno::UNO_QUERY ); 95*cdf0e10cSrcweir if( xCooSysCnt.is() ) 96*cdf0e10cSrcweir { 97*cdf0e10cSrcweir uno::Sequence< uno::Reference< XCoordinateSystem > > aCooSysSeq( xCooSysCnt->getCoordinateSystems() ); 98*cdf0e10cSrcweir if( aCooSysSeq.getLength() ) 99*cdf0e10cSrcweir XCooSys = aCooSysSeq[0]; 100*cdf0e10cSrcweir } 101*cdf0e10cSrcweir return XCooSys; 102*cdf0e10cSrcweir } 103*cdf0e10cSrcweir 104*cdf0e10cSrcweir ::std::vector< uno::Reference< XDataSeries > > ChartModelHelper::getDataSeries( 105*cdf0e10cSrcweir const uno::Reference< XChartDocument > & xChartDoc ) 106*cdf0e10cSrcweir { 107*cdf0e10cSrcweir ::std::vector< uno::Reference< XDataSeries > > aResult; 108*cdf0e10cSrcweir 109*cdf0e10cSrcweir uno::Reference< XDiagram > xDiagram = ChartModelHelper::findDiagram( xChartDoc ); 110*cdf0e10cSrcweir if( xDiagram.is()) 111*cdf0e10cSrcweir aResult = DiagramHelper::getDataSeriesFromDiagram( xDiagram ); 112*cdf0e10cSrcweir 113*cdf0e10cSrcweir return aResult; 114*cdf0e10cSrcweir } 115*cdf0e10cSrcweir 116*cdf0e10cSrcweir ::std::vector< uno::Reference< XDataSeries > > ChartModelHelper::getDataSeries( 117*cdf0e10cSrcweir const uno::Reference< frame::XModel > & xModel ) 118*cdf0e10cSrcweir { 119*cdf0e10cSrcweir return getDataSeries( uno::Reference< chart2::XChartDocument >( xModel, uno::UNO_QUERY )); 120*cdf0e10cSrcweir } 121*cdf0e10cSrcweir 122*cdf0e10cSrcweir 123*cdf0e10cSrcweir uno::Reference< XChartType > ChartModelHelper::getChartTypeOfSeries( 124*cdf0e10cSrcweir const uno::Reference< frame::XModel >& xModel 125*cdf0e10cSrcweir , const uno::Reference< XDataSeries >& xGivenDataSeries ) 126*cdf0e10cSrcweir { 127*cdf0e10cSrcweir return DiagramHelper::getChartTypeOfSeries( ChartModelHelper::findDiagram( xModel ), xGivenDataSeries ); 128*cdf0e10cSrcweir } 129*cdf0e10cSrcweir 130*cdf0e10cSrcweir awt::Size ChartModelHelper::getDefaultPageSize() 131*cdf0e10cSrcweir { 132*cdf0e10cSrcweir return awt::Size( 16000, 9000 ); 133*cdf0e10cSrcweir } 134*cdf0e10cSrcweir 135*cdf0e10cSrcweir awt::Size ChartModelHelper::getPageSize( const uno::Reference< frame::XModel >& xModel ) 136*cdf0e10cSrcweir { 137*cdf0e10cSrcweir awt::Size aPageSize( ChartModelHelper::getDefaultPageSize() ); 138*cdf0e10cSrcweir uno::Reference< embed::XVisualObject > xVisualObject(xModel,uno::UNO_QUERY); 139*cdf0e10cSrcweir DBG_ASSERT(xVisualObject.is(),"need xVisualObject for page size"); 140*cdf0e10cSrcweir if( xVisualObject.is() ) 141*cdf0e10cSrcweir aPageSize = xVisualObject->getVisualAreaSize( embed::Aspects::MSOLE_CONTENT ); 142*cdf0e10cSrcweir return aPageSize; 143*cdf0e10cSrcweir } 144*cdf0e10cSrcweir 145*cdf0e10cSrcweir void ChartModelHelper::setPageSize( const awt::Size& rSize, const uno::Reference< frame::XModel >& xModel ) 146*cdf0e10cSrcweir { 147*cdf0e10cSrcweir uno::Reference< embed::XVisualObject > xVisualObject(xModel,uno::UNO_QUERY); 148*cdf0e10cSrcweir DBG_ASSERT(xVisualObject.is(),"need xVisualObject for page size"); 149*cdf0e10cSrcweir if( xVisualObject.is() ) 150*cdf0e10cSrcweir xVisualObject->setVisualAreaSize( embed::Aspects::MSOLE_CONTENT, rSize ); 151*cdf0e10cSrcweir } 152*cdf0e10cSrcweir 153*cdf0e10cSrcweir void ChartModelHelper::triggerRangeHighlighting( const uno::Reference< frame::XModel >& xModel ) 154*cdf0e10cSrcweir { 155*cdf0e10cSrcweir uno::Reference< chart2::data::XDataReceiver > xDataReceiver( xModel, uno::UNO_QUERY ); 156*cdf0e10cSrcweir if( xDataReceiver.is() ) 157*cdf0e10cSrcweir { 158*cdf0e10cSrcweir uno::Reference< view::XSelectionChangeListener > xSelectionChangeListener( xDataReceiver->getRangeHighlighter(), uno::UNO_QUERY ); 159*cdf0e10cSrcweir //trigger selection of cell range 160*cdf0e10cSrcweir if( xSelectionChangeListener.is() ) 161*cdf0e10cSrcweir { 162*cdf0e10cSrcweir lang::EventObject aEvent( xSelectionChangeListener ); 163*cdf0e10cSrcweir xSelectionChangeListener->selectionChanged( aEvent ); 164*cdf0e10cSrcweir } 165*cdf0e10cSrcweir } 166*cdf0e10cSrcweir } 167*cdf0e10cSrcweir 168*cdf0e10cSrcweir bool ChartModelHelper::isIncludeHiddenCells( const uno::Reference< frame::XModel >& xChartModel ) 169*cdf0e10cSrcweir { 170*cdf0e10cSrcweir bool bIncluded = true; // hidden cells are included by default. 171*cdf0e10cSrcweir 172*cdf0e10cSrcweir uno::Reference< chart2::XDiagram > xDiagram( ChartModelHelper::findDiagram(xChartModel) ); 173*cdf0e10cSrcweir if (!xDiagram.is()) 174*cdf0e10cSrcweir return bIncluded; 175*cdf0e10cSrcweir 176*cdf0e10cSrcweir uno::Reference< beans::XPropertySet > xProp( xDiagram, uno::UNO_QUERY ); 177*cdf0e10cSrcweir if (!xProp.is()) 178*cdf0e10cSrcweir return bIncluded; 179*cdf0e10cSrcweir 180*cdf0e10cSrcweir try 181*cdf0e10cSrcweir { 182*cdf0e10cSrcweir xProp->getPropertyValue(C2U("IncludeHiddenCells")) >>= bIncluded; 183*cdf0e10cSrcweir } 184*cdf0e10cSrcweir catch( const beans::UnknownPropertyException& ) 185*cdf0e10cSrcweir { 186*cdf0e10cSrcweir } 187*cdf0e10cSrcweir 188*cdf0e10cSrcweir return bIncluded; 189*cdf0e10cSrcweir } 190*cdf0e10cSrcweir 191*cdf0e10cSrcweir bool ChartModelHelper::setIncludeHiddenCells( bool bIncludeHiddenCells, const uno::Reference< frame::XModel >& xChartModel ) 192*cdf0e10cSrcweir { 193*cdf0e10cSrcweir bool bChanged = false; 194*cdf0e10cSrcweir try 195*cdf0e10cSrcweir { 196*cdf0e10cSrcweir ControllerLockGuard aLockedControllers( xChartModel ); 197*cdf0e10cSrcweir 198*cdf0e10cSrcweir uno::Reference< beans::XPropertySet > xDiagramProperties( ChartModelHelper::findDiagram(xChartModel), uno::UNO_QUERY ); 199*cdf0e10cSrcweir if (xDiagramProperties.is()) 200*cdf0e10cSrcweir { 201*cdf0e10cSrcweir bool bOldValue = bIncludeHiddenCells; 202*cdf0e10cSrcweir xDiagramProperties->getPropertyValue( C2U("IncludeHiddenCells") ) >>= bOldValue; 203*cdf0e10cSrcweir if( bOldValue == bIncludeHiddenCells ) 204*cdf0e10cSrcweir bChanged = true; 205*cdf0e10cSrcweir 206*cdf0e10cSrcweir //set the property on all instances in all cases to get the different objects in sync! 207*cdf0e10cSrcweir 208*cdf0e10cSrcweir uno::Any aNewValue = uno::makeAny(bIncludeHiddenCells); 209*cdf0e10cSrcweir 210*cdf0e10cSrcweir try 211*cdf0e10cSrcweir { 212*cdf0e10cSrcweir uno::Reference< chart2::XChartDocument > xChartDoc( xChartModel, uno::UNO_QUERY ); 213*cdf0e10cSrcweir if( xChartDoc.is() ) 214*cdf0e10cSrcweir { 215*cdf0e10cSrcweir uno::Reference< beans::XPropertySet > xDataProviderProperties( xChartDoc->getDataProvider(), uno::UNO_QUERY ); 216*cdf0e10cSrcweir if( xDataProviderProperties.is() ) 217*cdf0e10cSrcweir xDataProviderProperties->setPropertyValue(C2U("IncludeHiddenCells"), aNewValue ); 218*cdf0e10cSrcweir } 219*cdf0e10cSrcweir } 220*cdf0e10cSrcweir catch( const beans::UnknownPropertyException& ) 221*cdf0e10cSrcweir { 222*cdf0e10cSrcweir //the property is optional! 223*cdf0e10cSrcweir } 224*cdf0e10cSrcweir 225*cdf0e10cSrcweir try 226*cdf0e10cSrcweir { 227*cdf0e10cSrcweir uno::Reference< chart2::data::XDataSource > xUsedData( DataSourceHelper::getUsedData( xChartModel ) ); 228*cdf0e10cSrcweir if( xUsedData.is() ) 229*cdf0e10cSrcweir { 230*cdf0e10cSrcweir uno::Reference< beans::XPropertySet > xProp; 231*cdf0e10cSrcweir uno::Sequence< uno::Reference< chart2::data::XLabeledDataSequence > > aData( xUsedData->getDataSequences()); 232*cdf0e10cSrcweir for( sal_Int32 i=0; i<aData.getLength(); ++i ) 233*cdf0e10cSrcweir { 234*cdf0e10cSrcweir xProp.set( uno::Reference< beans::XPropertySet >( aData[i]->getValues(), uno::UNO_QUERY ) ); 235*cdf0e10cSrcweir if(xProp.is()) 236*cdf0e10cSrcweir xProp->setPropertyValue(C2U("IncludeHiddenCells"), aNewValue ); 237*cdf0e10cSrcweir xProp.set( uno::Reference< beans::XPropertySet >( aData[i]->getLabel(), uno::UNO_QUERY ) ); 238*cdf0e10cSrcweir if(xProp.is()) 239*cdf0e10cSrcweir xProp->setPropertyValue(C2U("IncludeHiddenCells"), aNewValue ); 240*cdf0e10cSrcweir } 241*cdf0e10cSrcweir } 242*cdf0e10cSrcweir } 243*cdf0e10cSrcweir catch( const beans::UnknownPropertyException& ) 244*cdf0e10cSrcweir { 245*cdf0e10cSrcweir //the property is optional! 246*cdf0e10cSrcweir } 247*cdf0e10cSrcweir 248*cdf0e10cSrcweir xDiagramProperties->setPropertyValue( C2U("IncludeHiddenCells"), aNewValue); 249*cdf0e10cSrcweir } 250*cdf0e10cSrcweir } 251*cdf0e10cSrcweir catch (uno::Exception& e) 252*cdf0e10cSrcweir { 253*cdf0e10cSrcweir ASSERT_EXCEPTION(e); 254*cdf0e10cSrcweir } 255*cdf0e10cSrcweir return bChanged; 256*cdf0e10cSrcweir } 257*cdf0e10cSrcweir 258*cdf0e10cSrcweir //............................................................................. 259*cdf0e10cSrcweir } //namespace chart 260*cdf0e10cSrcweir //............................................................................. 261