xref: /AOO41X/main/chart2/source/tools/DataSourceHelper.cxx (revision cdf0e10c4e3984b49a9502b011690b615761d4a3)
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 
31*cdf0e10cSrcweir #include "DataSourceHelper.hxx"
32*cdf0e10cSrcweir #include "macros.hxx"
33*cdf0e10cSrcweir #include "ChartModelHelper.hxx"
34*cdf0e10cSrcweir #include "DiagramHelper.hxx"
35*cdf0e10cSrcweir #include "DataSeriesHelper.hxx"
36*cdf0e10cSrcweir #include "DataSource.hxx"
37*cdf0e10cSrcweir #include "ContainerHelper.hxx"
38*cdf0e10cSrcweir #include "ControllerLockGuard.hxx"
39*cdf0e10cSrcweir #include "PropertyHelper.hxx"
40*cdf0e10cSrcweir #include "CachedDataSequence.hxx"
41*cdf0e10cSrcweir #include "LabeledDataSequence.hxx"
42*cdf0e10cSrcweir 
43*cdf0e10cSrcweir #include <com/sun/star/chart2/XChartDocument.hpp>
44*cdf0e10cSrcweir #include <com/sun/star/chart2/data/XDataSource.hpp>
45*cdf0e10cSrcweir #include <com/sun/star/chart2/data/XLabeledDataSequence.hpp>
46*cdf0e10cSrcweir 
47*cdf0e10cSrcweir #include <com/sun/star/chart/ChartDataRowSource.hpp>
48*cdf0e10cSrcweir #include <com/sun/star/chart/ErrorBarStyle.hpp>
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 using ::com::sun::star::uno::Reference;
57*cdf0e10cSrcweir using ::com::sun::star::uno::Sequence;
58*cdf0e10cSrcweir using ::rtl::OUString;
59*cdf0e10cSrcweir 
60*cdf0e10cSrcweir namespace
61*cdf0e10cSrcweir {
62*cdf0e10cSrcweir void lcl_addRanges( ::std::vector< ::rtl::OUString > & rOutResult,
63*cdf0e10cSrcweir                     const uno::Reference< data::XLabeledDataSequence > & xLabeledSeq )
64*cdf0e10cSrcweir {
65*cdf0e10cSrcweir     if( ! xLabeledSeq.is())
66*cdf0e10cSrcweir         return;
67*cdf0e10cSrcweir     uno::Reference< data::XDataSequence > xSeq( xLabeledSeq->getLabel());
68*cdf0e10cSrcweir     if( xSeq.is())
69*cdf0e10cSrcweir         rOutResult.push_back( xSeq->getSourceRangeRepresentation());
70*cdf0e10cSrcweir     xSeq.set( xLabeledSeq->getValues());
71*cdf0e10cSrcweir     if( xSeq.is())
72*cdf0e10cSrcweir         rOutResult.push_back( xSeq->getSourceRangeRepresentation());
73*cdf0e10cSrcweir }
74*cdf0e10cSrcweir 
75*cdf0e10cSrcweir void lcl_addDataSourceRanges(
76*cdf0e10cSrcweir     ::std::vector< ::rtl::OUString > & rOutResult,
77*cdf0e10cSrcweir     const uno::Reference< data::XDataSource > & xDataSource )
78*cdf0e10cSrcweir {
79*cdf0e10cSrcweir     if( xDataSource.is() )
80*cdf0e10cSrcweir     {
81*cdf0e10cSrcweir         uno::Sequence< uno::Reference< data::XLabeledDataSequence > > aDataSequences( xDataSource->getDataSequences() );
82*cdf0e10cSrcweir         for( sal_Int32 i=0; i<aDataSequences.getLength(); ++i)
83*cdf0e10cSrcweir             lcl_addRanges( rOutResult, aDataSequences[i] );
84*cdf0e10cSrcweir     }
85*cdf0e10cSrcweir }
86*cdf0e10cSrcweir 
87*cdf0e10cSrcweir void lcl_addErrorBarRanges(
88*cdf0e10cSrcweir     ::std::vector< ::rtl::OUString > & rOutResult,
89*cdf0e10cSrcweir     const uno::Reference< XDataSeries > & xDataSeries )
90*cdf0e10cSrcweir {
91*cdf0e10cSrcweir     uno::Reference< beans::XPropertySet > xSeriesProp( xDataSeries, uno::UNO_QUERY );
92*cdf0e10cSrcweir     if( !xSeriesProp.is())
93*cdf0e10cSrcweir         return;
94*cdf0e10cSrcweir 
95*cdf0e10cSrcweir     try
96*cdf0e10cSrcweir     {
97*cdf0e10cSrcweir         uno::Reference< beans::XPropertySet > xErrorBarProp;
98*cdf0e10cSrcweir         if( ( xSeriesProp->getPropertyValue( C2U("ErrorBarY")) >>= xErrorBarProp ) &&
99*cdf0e10cSrcweir             xErrorBarProp.is())
100*cdf0e10cSrcweir         {
101*cdf0e10cSrcweir             sal_Int32 eStyle = ::com::sun::star::chart::ErrorBarStyle::NONE;
102*cdf0e10cSrcweir             if( ( xErrorBarProp->getPropertyValue( C2U("ErrorBarStyle")) >>= eStyle ) &&
103*cdf0e10cSrcweir                 eStyle == ::com::sun::star::chart::ErrorBarStyle::FROM_DATA )
104*cdf0e10cSrcweir             {
105*cdf0e10cSrcweir                 uno::Reference< data::XDataSource > xErrorBarDataSource( xErrorBarProp, uno::UNO_QUERY );
106*cdf0e10cSrcweir                 if( xErrorBarDataSource.is() )
107*cdf0e10cSrcweir                     lcl_addDataSourceRanges( rOutResult, xErrorBarDataSource );
108*cdf0e10cSrcweir             }
109*cdf0e10cSrcweir         }
110*cdf0e10cSrcweir     }
111*cdf0e10cSrcweir     catch( const uno::Exception & ex )
112*cdf0e10cSrcweir     {
113*cdf0e10cSrcweir         ASSERT_EXCEPTION( ex );
114*cdf0e10cSrcweir     }
115*cdf0e10cSrcweir }
116*cdf0e10cSrcweir 
117*cdf0e10cSrcweir } // anonymous namespace
118*cdf0e10cSrcweir 
119*cdf0e10cSrcweir Reference< chart2::data::XDataSource > DataSourceHelper::createDataSource(
120*cdf0e10cSrcweir         const Sequence< Reference< chart2::data::XLabeledDataSequence > >& rSequences )
121*cdf0e10cSrcweir {
122*cdf0e10cSrcweir     return new DataSource(rSequences);
123*cdf0e10cSrcweir }
124*cdf0e10cSrcweir 
125*cdf0e10cSrcweir Reference< chart2::data::XDataSequence > DataSourceHelper::createCachedDataSequence()
126*cdf0e10cSrcweir {
127*cdf0e10cSrcweir     return new ::chart::CachedDataSequence();
128*cdf0e10cSrcweir }
129*cdf0e10cSrcweir 
130*cdf0e10cSrcweir Reference< chart2::data::XDataSequence > DataSourceHelper::createCachedDataSequence( const ::rtl::OUString& rSingleText )
131*cdf0e10cSrcweir {
132*cdf0e10cSrcweir     return new ::chart::CachedDataSequence( rSingleText );
133*cdf0e10cSrcweir }
134*cdf0e10cSrcweir 
135*cdf0e10cSrcweir Reference< chart2::data::XLabeledDataSequence > DataSourceHelper::createLabeledDataSequence(
136*cdf0e10cSrcweir         const Reference< chart2::data::XDataSequence >& xValues ,
137*cdf0e10cSrcweir         const Reference< chart2::data::XDataSequence >& xLabels )
138*cdf0e10cSrcweir {
139*cdf0e10cSrcweir     return new ::chart::LabeledDataSequence( xValues, xLabels );
140*cdf0e10cSrcweir }
141*cdf0e10cSrcweir 
142*cdf0e10cSrcweir Reference< chart2::data::XLabeledDataSequence > DataSourceHelper::createLabeledDataSequence(
143*cdf0e10cSrcweir         const Reference< chart2::data::XDataSequence >& xValues )
144*cdf0e10cSrcweir {
145*cdf0e10cSrcweir     return new ::chart::LabeledDataSequence( xValues );
146*cdf0e10cSrcweir }
147*cdf0e10cSrcweir 
148*cdf0e10cSrcweir Reference< chart2::data::XLabeledDataSequence > DataSourceHelper::createLabeledDataSequence(
149*cdf0e10cSrcweir         const Reference< uno::XComponentContext >& xContext )
150*cdf0e10cSrcweir {
151*cdf0e10cSrcweir     return new ::chart::LabeledDataSequence( xContext );
152*cdf0e10cSrcweir }
153*cdf0e10cSrcweir 
154*cdf0e10cSrcweir uno::Sequence< beans::PropertyValue > DataSourceHelper::createArguments(
155*cdf0e10cSrcweir                                             bool bUseColumns, bool bFirstCellAsLabel, bool bHasCategories )
156*cdf0e10cSrcweir {
157*cdf0e10cSrcweir     ::com::sun::star::chart::ChartDataRowSource eRowSource = ::com::sun::star::chart::ChartDataRowSource_ROWS;
158*cdf0e10cSrcweir     if( bUseColumns )
159*cdf0e10cSrcweir         eRowSource = ::com::sun::star::chart::ChartDataRowSource_COLUMNS;
160*cdf0e10cSrcweir 
161*cdf0e10cSrcweir     uno::Sequence< beans::PropertyValue > aArguments(3);
162*cdf0e10cSrcweir     aArguments[0] = beans::PropertyValue( C2U("DataRowSource")
163*cdf0e10cSrcweir         , -1, uno::makeAny( eRowSource )
164*cdf0e10cSrcweir         , beans::PropertyState_DIRECT_VALUE );
165*cdf0e10cSrcweir     aArguments[1] = beans::PropertyValue( C2U("FirstCellAsLabel")
166*cdf0e10cSrcweir         , -1, uno::makeAny( bFirstCellAsLabel )
167*cdf0e10cSrcweir         , beans::PropertyState_DIRECT_VALUE );
168*cdf0e10cSrcweir     aArguments[2] = beans::PropertyValue( C2U("HasCategories")
169*cdf0e10cSrcweir         , -1, uno::makeAny( bHasCategories )
170*cdf0e10cSrcweir         , beans::PropertyState_DIRECT_VALUE );
171*cdf0e10cSrcweir 
172*cdf0e10cSrcweir     return aArguments;
173*cdf0e10cSrcweir }
174*cdf0e10cSrcweir 
175*cdf0e10cSrcweir uno::Sequence< beans::PropertyValue > DataSourceHelper::createArguments(
176*cdf0e10cSrcweir                                             const ::rtl::OUString & rRangeRepresentation,
177*cdf0e10cSrcweir                                             const uno::Sequence< sal_Int32 >& rSequenceMapping,
178*cdf0e10cSrcweir                                             bool bUseColumns, bool bFirstCellAsLabel, bool bHasCategories )
179*cdf0e10cSrcweir {
180*cdf0e10cSrcweir     uno::Sequence< beans::PropertyValue > aArguments( createArguments( bUseColumns, bFirstCellAsLabel, bHasCategories ));
181*cdf0e10cSrcweir     aArguments.realloc( aArguments.getLength() + 1 );
182*cdf0e10cSrcweir     aArguments[aArguments.getLength() - 1] =
183*cdf0e10cSrcweir         beans::PropertyValue( C2U("CellRangeRepresentation")
184*cdf0e10cSrcweir                               , -1, uno::makeAny( rRangeRepresentation )
185*cdf0e10cSrcweir                               , beans::PropertyState_DIRECT_VALUE );
186*cdf0e10cSrcweir     if( rSequenceMapping.getLength() )
187*cdf0e10cSrcweir     {
188*cdf0e10cSrcweir         aArguments.realloc( aArguments.getLength() + 1 );
189*cdf0e10cSrcweir         aArguments[aArguments.getLength() - 1] =
190*cdf0e10cSrcweir             beans::PropertyValue( C2U("SequenceMapping")
191*cdf0e10cSrcweir                                 , -1, uno::makeAny( rSequenceMapping )
192*cdf0e10cSrcweir                                 , beans::PropertyState_DIRECT_VALUE );
193*cdf0e10cSrcweir     }
194*cdf0e10cSrcweir     return aArguments;
195*cdf0e10cSrcweir }
196*cdf0e10cSrcweir 
197*cdf0e10cSrcweir void DataSourceHelper::readArguments( const uno::Sequence< beans::PropertyValue >& rArguments
198*cdf0e10cSrcweir                                      , ::rtl::OUString & rRangeRepresentation, uno::Sequence< sal_Int32 >& rSequenceMapping
199*cdf0e10cSrcweir             , bool& bUseColumns, bool& bFirstCellAsLabel, bool& bHasCategories )
200*cdf0e10cSrcweir {
201*cdf0e10cSrcweir     const beans::PropertyValue* pArguments = rArguments.getConstArray();
202*cdf0e10cSrcweir 	for(sal_Int32 i=0; i<rArguments.getLength(); ++i, ++pArguments)
203*cdf0e10cSrcweir 	{
204*cdf0e10cSrcweir         const beans::PropertyValue& aProperty = *pArguments;
205*cdf0e10cSrcweir 		if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "DataRowSource" ) ))
206*cdf0e10cSrcweir 		{
207*cdf0e10cSrcweir             ::com::sun::star::chart::ChartDataRowSource eRowSource;
208*cdf0e10cSrcweir 			if( aProperty.Value >>= eRowSource )
209*cdf0e10cSrcweir                 bUseColumns = (eRowSource==::com::sun::star::chart::ChartDataRowSource_COLUMNS);
210*cdf0e10cSrcweir 		}
211*cdf0e10cSrcweir         else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "FirstCellAsLabel" ) ))
212*cdf0e10cSrcweir 		{
213*cdf0e10cSrcweir 			aProperty.Value >>= bFirstCellAsLabel;
214*cdf0e10cSrcweir 		}
215*cdf0e10cSrcweir         else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "HasCategories" ) ))
216*cdf0e10cSrcweir 		{
217*cdf0e10cSrcweir 			aProperty.Value >>= bHasCategories;
218*cdf0e10cSrcweir 		}
219*cdf0e10cSrcweir         else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "CellRangeRepresentation" ) ))
220*cdf0e10cSrcweir         {
221*cdf0e10cSrcweir             aProperty.Value >>= rRangeRepresentation;
222*cdf0e10cSrcweir         }
223*cdf0e10cSrcweir         else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "SequenceMapping" ) ))
224*cdf0e10cSrcweir         {
225*cdf0e10cSrcweir             aProperty.Value >>= rSequenceMapping;
226*cdf0e10cSrcweir         }
227*cdf0e10cSrcweir     }
228*cdf0e10cSrcweir }
229*cdf0e10cSrcweir 
230*cdf0e10cSrcweir uno::Reference< chart2::data::XDataSource > DataSourceHelper::pressUsedDataIntoRectangularFormat(
231*cdf0e10cSrcweir         const uno::Reference< chart2::XChartDocument >& xChartDoc, bool bWithCategories )
232*cdf0e10cSrcweir {
233*cdf0e10cSrcweir     ::std::vector< Reference< chart2::data::XLabeledDataSequence > > aResultVector;
234*cdf0e10cSrcweir 
235*cdf0e10cSrcweir     //categories are always the first sequence
236*cdf0e10cSrcweir     Reference< chart2::XDiagram > xDiagram( xChartDoc->getFirstDiagram());
237*cdf0e10cSrcweir 
238*cdf0e10cSrcweir     if( bWithCategories )
239*cdf0e10cSrcweir     {
240*cdf0e10cSrcweir         Reference< chart2::data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ) );
241*cdf0e10cSrcweir         if( xCategories.is() )
242*cdf0e10cSrcweir             aResultVector.push_back( xCategories );
243*cdf0e10cSrcweir     }
244*cdf0e10cSrcweir 
245*cdf0e10cSrcweir     ::std::vector< Reference< chart2::XDataSeries > > xSeriesVector( DiagramHelper::getDataSeriesFromDiagram( xDiagram ) );
246*cdf0e10cSrcweir     uno::Reference< chart2::data::XDataSource > xSeriesSource(
247*cdf0e10cSrcweir         DataSeriesHelper::getDataSource( ContainerHelper::ContainerToSequence(xSeriesVector) ) );
248*cdf0e10cSrcweir     Sequence< Reference< chart2::data::XLabeledDataSequence > > aDataSeqences( xSeriesSource->getDataSequences() );
249*cdf0e10cSrcweir 
250*cdf0e10cSrcweir     //the first x-values is always the next sequence //todo ... other x-values get lost for old format
251*cdf0e10cSrcweir     Reference< chart2::data::XLabeledDataSequence > xXValues(
252*cdf0e10cSrcweir         DataSeriesHelper::getDataSequenceByRole( xSeriesSource, C2U("values-x") ) );
253*cdf0e10cSrcweir     if( xXValues.is() )
254*cdf0e10cSrcweir         aResultVector.push_back( xXValues );
255*cdf0e10cSrcweir 
256*cdf0e10cSrcweir     //add all other sequences now without x-values
257*cdf0e10cSrcweir     for( sal_Int32 nN=0; nN<aDataSeqences.getLength(); nN++ )
258*cdf0e10cSrcweir     {
259*cdf0e10cSrcweir         OUString aRole( DataSeriesHelper::GetRole( aDataSeqences[nN] ) );
260*cdf0e10cSrcweir         if( !aRole.equals(C2U("values-x")) )
261*cdf0e10cSrcweir             aResultVector.push_back( aDataSeqences[nN] );
262*cdf0e10cSrcweir     }
263*cdf0e10cSrcweir 
264*cdf0e10cSrcweir     Sequence< Reference< chart2::data::XLabeledDataSequence > > aResultSequence( aResultVector.size() );
265*cdf0e10cSrcweir     ::std::copy( aResultVector.begin(), aResultVector.end(), aResultSequence.getArray() );
266*cdf0e10cSrcweir 
267*cdf0e10cSrcweir     return new DataSource( aResultSequence );
268*cdf0e10cSrcweir }
269*cdf0e10cSrcweir 
270*cdf0e10cSrcweir uno::Sequence< ::rtl::OUString > DataSourceHelper::getUsedDataRanges(
271*cdf0e10cSrcweir     const uno::Reference< chart2::XDiagram > & xDiagram )
272*cdf0e10cSrcweir {
273*cdf0e10cSrcweir     ::std::vector< ::rtl::OUString > aResult;
274*cdf0e10cSrcweir 
275*cdf0e10cSrcweir     if( xDiagram.is())
276*cdf0e10cSrcweir     {
277*cdf0e10cSrcweir         uno::Reference< data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ) );
278*cdf0e10cSrcweir         if( xCategories.is() )
279*cdf0e10cSrcweir             lcl_addRanges( aResult, xCategories );
280*cdf0e10cSrcweir 
281*cdf0e10cSrcweir         ::std::vector< uno::Reference< XDataSeries > > aSeriesVector( DiagramHelper::getDataSeriesFromDiagram( xDiagram ) );
282*cdf0e10cSrcweir         for( ::std::vector< uno::Reference< XDataSeries > >::const_iterator aSeriesIt( aSeriesVector.begin() )
283*cdf0e10cSrcweir                  ; aSeriesIt != aSeriesVector.end(); ++aSeriesIt )
284*cdf0e10cSrcweir         {
285*cdf0e10cSrcweir             uno::Reference< data::XDataSource > xDataSource( *aSeriesIt, uno::UNO_QUERY );
286*cdf0e10cSrcweir             lcl_addDataSourceRanges( aResult, xDataSource );
287*cdf0e10cSrcweir             lcl_addErrorBarRanges( aResult, *aSeriesIt );
288*cdf0e10cSrcweir         }
289*cdf0e10cSrcweir     }
290*cdf0e10cSrcweir 
291*cdf0e10cSrcweir     return ContainerHelper::ContainerToSequence( aResult );
292*cdf0e10cSrcweir }
293*cdf0e10cSrcweir 
294*cdf0e10cSrcweir uno::Sequence< ::rtl::OUString > DataSourceHelper::getUsedDataRanges( const uno::Reference< frame::XModel > & xChartModel )
295*cdf0e10cSrcweir {
296*cdf0e10cSrcweir     uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartModel ) );
297*cdf0e10cSrcweir     return getUsedDataRanges( xDiagram );
298*cdf0e10cSrcweir }
299*cdf0e10cSrcweir 
300*cdf0e10cSrcweir uno::Reference< chart2::data::XDataSource > DataSourceHelper::getUsedData(
301*cdf0e10cSrcweir     const uno::Reference< chart2::XChartDocument >& xChartDoc )
302*cdf0e10cSrcweir {
303*cdf0e10cSrcweir     return pressUsedDataIntoRectangularFormat( xChartDoc );
304*cdf0e10cSrcweir }
305*cdf0e10cSrcweir 
306*cdf0e10cSrcweir uno::Reference< chart2::data::XDataSource > DataSourceHelper::getUsedData(
307*cdf0e10cSrcweir     const uno::Reference< frame::XModel >& xChartModel )
308*cdf0e10cSrcweir {
309*cdf0e10cSrcweir     ::std::vector< uno::Reference< chart2::data::XLabeledDataSequence > > aResult;
310*cdf0e10cSrcweir 
311*cdf0e10cSrcweir     uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartModel ) );
312*cdf0e10cSrcweir     uno::Reference< data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ) );
313*cdf0e10cSrcweir     if( xCategories.is() )
314*cdf0e10cSrcweir         aResult.push_back( xCategories );
315*cdf0e10cSrcweir 
316*cdf0e10cSrcweir     ::std::vector< uno::Reference< XDataSeries > > aSeriesVector( ChartModelHelper::getDataSeries( xChartModel ) );
317*cdf0e10cSrcweir     for( ::std::vector< uno::Reference< XDataSeries > >::const_iterator aSeriesIt( aSeriesVector.begin() )
318*cdf0e10cSrcweir         ; aSeriesIt != aSeriesVector.end(); ++aSeriesIt )
319*cdf0e10cSrcweir     {
320*cdf0e10cSrcweir         uno::Reference< data::XDataSource > xDataSource( *aSeriesIt, uno::UNO_QUERY );
321*cdf0e10cSrcweir         if( !xDataSource.is() )
322*cdf0e10cSrcweir             continue;
323*cdf0e10cSrcweir         uno::Sequence< uno::Reference< data::XLabeledDataSequence > > aDataSequences( xDataSource->getDataSequences() );
324*cdf0e10cSrcweir         ::std::copy( aDataSequences.getConstArray(), aDataSequences.getConstArray() + aDataSequences.getLength(),
325*cdf0e10cSrcweir                      ::std::back_inserter( aResult ));
326*cdf0e10cSrcweir     }
327*cdf0e10cSrcweir 
328*cdf0e10cSrcweir     return uno::Reference< chart2::data::XDataSource >(
329*cdf0e10cSrcweir         new DataSource( ContainerHelper::ContainerToSequence( aResult )));
330*cdf0e10cSrcweir }
331*cdf0e10cSrcweir 
332*cdf0e10cSrcweir bool DataSourceHelper::detectRangeSegmentation(
333*cdf0e10cSrcweir     const uno::Reference<
334*cdf0e10cSrcweir         frame::XModel >& xChartModel
335*cdf0e10cSrcweir     , ::rtl::OUString& rOutRangeString
336*cdf0e10cSrcweir     , ::com::sun::star::uno::Sequence< sal_Int32 >& rSequenceMapping
337*cdf0e10cSrcweir     , bool& rOutUseColumns
338*cdf0e10cSrcweir     , bool& rOutFirstCellAsLabel
339*cdf0e10cSrcweir     , bool& rOutHasCategories )
340*cdf0e10cSrcweir {
341*cdf0e10cSrcweir     bool bSomethingDetected = false;
342*cdf0e10cSrcweir 
343*cdf0e10cSrcweir     uno::Reference< XChartDocument > xChartDocument( xChartModel, uno::UNO_QUERY );
344*cdf0e10cSrcweir     if( !xChartDocument.is() )
345*cdf0e10cSrcweir         return bSomethingDetected;
346*cdf0e10cSrcweir     uno::Reference< data::XDataProvider >  xDataProvider( xChartDocument->getDataProvider() );
347*cdf0e10cSrcweir     if( !xDataProvider.is() )
348*cdf0e10cSrcweir         return bSomethingDetected;
349*cdf0e10cSrcweir 
350*cdf0e10cSrcweir     try
351*cdf0e10cSrcweir     {
352*cdf0e10cSrcweir         DataSourceHelper::readArguments(
353*cdf0e10cSrcweir             xDataProvider->detectArguments( pressUsedDataIntoRectangularFormat( xChartDocument ) ),
354*cdf0e10cSrcweir             rOutRangeString, rSequenceMapping, rOutUseColumns, rOutFirstCellAsLabel, rOutHasCategories );
355*cdf0e10cSrcweir         bSomethingDetected = (rOutRangeString.getLength() > 0);
356*cdf0e10cSrcweir 
357*cdf0e10cSrcweir         uno::Reference< chart2::data::XLabeledDataSequence > xCategories(
358*cdf0e10cSrcweir                     DiagramHelper::getCategoriesFromDiagram( xChartDocument->getFirstDiagram() ));
359*cdf0e10cSrcweir         rOutHasCategories = xCategories.is();
360*cdf0e10cSrcweir     }
361*cdf0e10cSrcweir     catch( uno::Exception & ex )
362*cdf0e10cSrcweir     {
363*cdf0e10cSrcweir         ASSERT_EXCEPTION( ex );
364*cdf0e10cSrcweir     }
365*cdf0e10cSrcweir     return bSomethingDetected;
366*cdf0e10cSrcweir }
367*cdf0e10cSrcweir 
368*cdf0e10cSrcweir bool DataSourceHelper::allArgumentsForRectRangeDetected(
369*cdf0e10cSrcweir     const uno::Reference< chart2::XChartDocument >& xChartDocument )
370*cdf0e10cSrcweir {
371*cdf0e10cSrcweir     bool bHasDataRowSource = false;
372*cdf0e10cSrcweir     bool bHasFirstCellAsLabel = false;
373*cdf0e10cSrcweir //     bool bHasHasCategories = false;
374*cdf0e10cSrcweir     bool bHasCellRangeRepresentation = false;
375*cdf0e10cSrcweir //     bool bHasSequenceMapping = false;
376*cdf0e10cSrcweir 
377*cdf0e10cSrcweir     uno::Reference< data::XDataProvider > xDataProvider( xChartDocument->getDataProvider() );
378*cdf0e10cSrcweir     if( !xDataProvider.is() )
379*cdf0e10cSrcweir         return false;
380*cdf0e10cSrcweir 
381*cdf0e10cSrcweir     try
382*cdf0e10cSrcweir     {
383*cdf0e10cSrcweir         const uno::Sequence< beans::PropertyValue > aArguments(
384*cdf0e10cSrcweir             xDataProvider->detectArguments( pressUsedDataIntoRectangularFormat( xChartDocument )));
385*cdf0e10cSrcweir         const beans::PropertyValue* pArguments = aArguments.getConstArray();
386*cdf0e10cSrcweir         for(sal_Int32 i=0; i<aArguments.getLength(); ++i, ++pArguments)
387*cdf0e10cSrcweir         {
388*cdf0e10cSrcweir             const beans::PropertyValue& aProperty = *pArguments;
389*cdf0e10cSrcweir             if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "DataRowSource" ) ))
390*cdf0e10cSrcweir             {
391*cdf0e10cSrcweir                 bHasDataRowSource =
392*cdf0e10cSrcweir                     (aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(
393*cdf0e10cSrcweir                         ::getCppuType( reinterpret_cast<
394*cdf0e10cSrcweir                                        const ::com::sun::star::chart::ChartDataRowSource * >(0))));
395*cdf0e10cSrcweir             }
396*cdf0e10cSrcweir             else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "FirstCellAsLabel" ) ))
397*cdf0e10cSrcweir             {
398*cdf0e10cSrcweir                 bHasFirstCellAsLabel =
399*cdf0e10cSrcweir                     (aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(::getBooleanCppuType()));
400*cdf0e10cSrcweir             }
401*cdf0e10cSrcweir //             else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "HasCategories" ) ))
402*cdf0e10cSrcweir //             {
403*cdf0e10cSrcweir //                 bHasHasCategories =
404*cdf0e10cSrcweir //                     (aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(::getBooleanCppuType()));
405*cdf0e10cSrcweir //             }
406*cdf0e10cSrcweir             else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "CellRangeRepresentation" ) ))
407*cdf0e10cSrcweir             {
408*cdf0e10cSrcweir                 ::rtl::OUString aRange;
409*cdf0e10cSrcweir                 bHasCellRangeRepresentation =
410*cdf0e10cSrcweir                     (aProperty.Value.hasValue() && (aProperty.Value >>= aRange) && aRange.getLength() > 0);
411*cdf0e10cSrcweir             }
412*cdf0e10cSrcweir //         else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "SequenceMapping" ) ))
413*cdf0e10cSrcweir //         {
414*cdf0e10cSrcweir //             bHasSequenceMapping =
415*cdf0e10cSrcweir //                 (aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(
416*cdf0e10cSrcweir //                     ::getCppuType( reinterpret_cast<
417*cdf0e10cSrcweir //                                    const uno::Sequence< sal_Int32 > * >(0))));
418*cdf0e10cSrcweir //         }
419*cdf0e10cSrcweir         }
420*cdf0e10cSrcweir     }
421*cdf0e10cSrcweir     catch( const uno::Exception & ex )
422*cdf0e10cSrcweir     {
423*cdf0e10cSrcweir         ASSERT_EXCEPTION( ex );
424*cdf0e10cSrcweir     }
425*cdf0e10cSrcweir 
426*cdf0e10cSrcweir     return (bHasCellRangeRepresentation && bHasDataRowSource && bHasFirstCellAsLabel);
427*cdf0e10cSrcweir }
428*cdf0e10cSrcweir 
429*cdf0e10cSrcweir void DataSourceHelper::setRangeSegmentation(
430*cdf0e10cSrcweir             const uno::Reference< frame::XModel >& xChartModel
431*cdf0e10cSrcweir             , const ::com::sun::star::uno::Sequence< sal_Int32 >& rSequenceMapping
432*cdf0e10cSrcweir             , bool bUseColumns , bool bFirstCellAsLabel, bool bUseCategories )
433*cdf0e10cSrcweir {
434*cdf0e10cSrcweir     uno::Reference< XChartDocument > xChartDocument( xChartModel, uno::UNO_QUERY );
435*cdf0e10cSrcweir     if( !xChartDocument.is() )
436*cdf0e10cSrcweir         return;
437*cdf0e10cSrcweir     uno::Reference< data::XDataProvider > xDataProvider( xChartDocument->getDataProvider() );
438*cdf0e10cSrcweir     if( !xDataProvider.is() )
439*cdf0e10cSrcweir         return;
440*cdf0e10cSrcweir     uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartModel ) );
441*cdf0e10cSrcweir     if( !xDiagram.is() )
442*cdf0e10cSrcweir         return;
443*cdf0e10cSrcweir     uno::Reference< chart2::XChartTypeManager > xChartTypeManager( xChartDocument->getChartTypeManager() );
444*cdf0e10cSrcweir     if( !xChartTypeManager.is() )
445*cdf0e10cSrcweir         return;
446*cdf0e10cSrcweir     uno::Reference< lang::XMultiServiceFactory > xTemplateFactory( xChartTypeManager, uno::UNO_QUERY );
447*cdf0e10cSrcweir     if( !xTemplateFactory.is() )
448*cdf0e10cSrcweir         return;
449*cdf0e10cSrcweir 
450*cdf0e10cSrcweir     ::rtl::OUString aRangeString;
451*cdf0e10cSrcweir     bool bDummy;
452*cdf0e10cSrcweir     uno::Sequence< sal_Int32 > aDummy;
453*cdf0e10cSrcweir     readArguments( xDataProvider->detectArguments( pressUsedDataIntoRectangularFormat( xChartDocument )),
454*cdf0e10cSrcweir                    aRangeString, aDummy, bDummy, bDummy, bDummy );
455*cdf0e10cSrcweir 
456*cdf0e10cSrcweir     uno::Sequence< beans::PropertyValue > aArguments(
457*cdf0e10cSrcweir         createArguments( aRangeString, rSequenceMapping, bUseColumns, bFirstCellAsLabel, bUseCategories ) );
458*cdf0e10cSrcweir 
459*cdf0e10cSrcweir     uno::Reference< chart2::data::XDataSource > xDataSource( xDataProvider->createDataSource(
460*cdf0e10cSrcweir                                                                  aArguments ) );
461*cdf0e10cSrcweir     if( !xDataSource.is() )
462*cdf0e10cSrcweir         return;
463*cdf0e10cSrcweir 
464*cdf0e10cSrcweir     ControllerLockGuard aCtrlLockGuard( xChartModel );
465*cdf0e10cSrcweir     xDiagram->setDiagramData( xDataSource, aArguments );
466*cdf0e10cSrcweir }
467*cdf0e10cSrcweir 
468*cdf0e10cSrcweir Sequence< OUString > DataSourceHelper::getRangesFromLabeledDataSequence(
469*cdf0e10cSrcweir     const Reference< data::XLabeledDataSequence > & xLSeq )
470*cdf0e10cSrcweir {
471*cdf0e10cSrcweir     Sequence< OUString > aResult;
472*cdf0e10cSrcweir     if( xLSeq.is())
473*cdf0e10cSrcweir     {
474*cdf0e10cSrcweir         Reference< data::XDataSequence > xLabel( xLSeq->getLabel());
475*cdf0e10cSrcweir         Reference< data::XDataSequence > xValues( xLSeq->getValues());
476*cdf0e10cSrcweir 
477*cdf0e10cSrcweir         if( xLabel.is())
478*cdf0e10cSrcweir         {
479*cdf0e10cSrcweir             if( xValues.is())
480*cdf0e10cSrcweir             {
481*cdf0e10cSrcweir                 aResult.realloc( 2 );
482*cdf0e10cSrcweir                 aResult[0] = xLabel->getSourceRangeRepresentation();
483*cdf0e10cSrcweir                 aResult[1] = xValues->getSourceRangeRepresentation();
484*cdf0e10cSrcweir             }
485*cdf0e10cSrcweir             else
486*cdf0e10cSrcweir             {
487*cdf0e10cSrcweir                 aResult.realloc( 1 );
488*cdf0e10cSrcweir                 aResult[0] = xLabel->getSourceRangeRepresentation();
489*cdf0e10cSrcweir             }
490*cdf0e10cSrcweir         }
491*cdf0e10cSrcweir         else if( xValues.is())
492*cdf0e10cSrcweir         {
493*cdf0e10cSrcweir             aResult.realloc( 1 );
494*cdf0e10cSrcweir             aResult[0] = xValues->getSourceRangeRepresentation();
495*cdf0e10cSrcweir         }
496*cdf0e10cSrcweir     }
497*cdf0e10cSrcweir     return aResult;
498*cdf0e10cSrcweir }
499*cdf0e10cSrcweir 
500*cdf0e10cSrcweir OUString DataSourceHelper::getRangeFromValues(
501*cdf0e10cSrcweir     const Reference< data::XLabeledDataSequence > & xLSeq )
502*cdf0e10cSrcweir {
503*cdf0e10cSrcweir     OUString aResult;
504*cdf0e10cSrcweir     if( xLSeq.is() )
505*cdf0e10cSrcweir     {
506*cdf0e10cSrcweir         Reference< data::XDataSequence > xValues( xLSeq->getValues() );
507*cdf0e10cSrcweir         if( xValues.is() )
508*cdf0e10cSrcweir             aResult = xValues->getSourceRangeRepresentation();
509*cdf0e10cSrcweir     }
510*cdf0e10cSrcweir     return aResult;
511*cdf0e10cSrcweir }
512*cdf0e10cSrcweir 
513*cdf0e10cSrcweir Sequence< OUString > DataSourceHelper::getRangesFromDataSource( const Reference< data::XDataSource > & xSource )
514*cdf0e10cSrcweir {
515*cdf0e10cSrcweir     ::std::vector< OUString > aResult;
516*cdf0e10cSrcweir     if( xSource.is())
517*cdf0e10cSrcweir     {
518*cdf0e10cSrcweir         Sequence< Reference< data::XLabeledDataSequence > > aLSeqSeq( xSource->getDataSequences());
519*cdf0e10cSrcweir         for( sal_Int32 i=0; i<aLSeqSeq.getLength(); ++i )
520*cdf0e10cSrcweir         {
521*cdf0e10cSrcweir             Reference< data::XDataSequence > xLabel( aLSeqSeq[i]->getLabel());
522*cdf0e10cSrcweir             Reference< data::XDataSequence > xValues( aLSeqSeq[i]->getValues());
523*cdf0e10cSrcweir 
524*cdf0e10cSrcweir             if( xLabel.is())
525*cdf0e10cSrcweir                 aResult.push_back( xLabel->getSourceRangeRepresentation());
526*cdf0e10cSrcweir             if( xValues.is())
527*cdf0e10cSrcweir                 aResult.push_back( xValues->getSourceRangeRepresentation());
528*cdf0e10cSrcweir         }
529*cdf0e10cSrcweir     }
530*cdf0e10cSrcweir     return ContainerHelper::ContainerToSequence( aResult );
531*cdf0e10cSrcweir }
532*cdf0e10cSrcweir 
533*cdf0e10cSrcweir //.............................................................................
534*cdf0e10cSrcweir } //namespace chart
535*cdf0e10cSrcweir //.............................................................................
536