merge the formfield patch from ooo-build
[ooovba.git] / chart2 / source / tools / RegressionCurveHelper.cxx
blob6256aadbaf817a83ccad5249915d3b9b58780a03
1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4 *
5 * Copyright 2008 by Sun Microsystems, Inc.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * $RCSfile: RegressionCurveHelper.cxx,v $
10 * $Revision: 1.15.16.1 $
12 * This file is part of OpenOffice.org.
14 * OpenOffice.org is free software: you can redistribute it and/or modify
15 * it under the terms of the GNU Lesser General Public License version 3
16 * only, as published by the Free Software Foundation.
18 * OpenOffice.org is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU Lesser General Public License version 3 for more details
22 * (a copy is included in the LICENSE file that accompanied this code).
24 * You should have received a copy of the GNU Lesser General Public License
25 * version 3 along with OpenOffice.org. If not, see
26 * <http://www.openoffice.org/license.html>
27 * for a copy of the LGPLv3 License.
29 ************************************************************************/
31 // MARKER(update_precomp.py): autogen include statement, do not remove
32 #include "precompiled_chart2.hxx"
33 #include "RegressionCurveHelper.hxx"
34 #include "MeanValueRegressionCurveCalculator.hxx"
35 #include "LinearRegressionCurveCalculator.hxx"
36 #include "LogarithmicRegressionCurveCalculator.hxx"
37 #include "ExponentialRegressionCurveCalculator.hxx"
38 #include "PotentialRegressionCurveCalculator.hxx"
39 #include "CommonConverters.hxx"
40 #include "RegressionCurveModel.hxx"
41 #include "ChartTypeHelper.hxx"
42 #include "ChartModelHelper.hxx"
43 #include "macros.hxx"
44 #include "PropertyHelper.hxx"
45 #include "ResId.hxx"
46 #include "Strings.hrc"
47 #include "DiagramHelper.hxx"
48 #include <com/sun/star/chart2/XChartDocument.hpp>
50 using namespace ::com::sun::star;
51 using namespace ::com::sun::star::chart2;
53 using ::com::sun::star::uno::Reference;
54 using ::com::sun::star::uno::Sequence;
55 using ::com::sun::star::uno::XComponentContext;
56 using ::com::sun::star::lang::XServiceName;
57 using ::com::sun::star::beans::XPropertySet;
58 using ::com::sun::star::uno::Exception;
59 using ::rtl::OUString;
61 namespace
63 OUString lcl_getServiceNameForType( ::chart::RegressionCurveHelper::tRegressionType eType )
65 OUString aServiceName;
66 switch( eType )
68 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_LINEAR:
69 aServiceName = C2U( "com.sun.star.chart2.LinearRegressionCurve" );
70 break;
71 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_LOG:
72 aServiceName = C2U( "com.sun.star.chart2.LogarithmicRegressionCurve" );
73 break;
74 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_EXP:
75 aServiceName = C2U( "com.sun.star.chart2.ExponentialRegressionCurve" );
76 break;
77 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_POWER:
78 aServiceName = C2U( "com.sun.star.chart2.PotentialRegressionCurve" );
79 break;
80 default:
81 OSL_ENSURE(false,"unknown regression curve type - use linear instead");
82 aServiceName = C2U( "com.sun.star.chart2.LinearRegressionCurve" );
83 break;
85 return aServiceName;
87 } // anonymous namespace
89 //.............................................................................
90 namespace chart
92 //.............................................................................
94 // static
95 Reference< XRegressionCurve > RegressionCurveHelper::createMeanValueLine(
96 const Reference< XComponentContext > & xContext )
98 return Reference< XRegressionCurve >(
99 new MeanValueRegressionCurve( xContext ));
102 // static
103 Reference< XRegressionCurve > RegressionCurveHelper::createRegressionCurveByServiceName(
104 const Reference< XComponentContext > & xContext,
105 ::rtl::OUString aServiceName )
107 Reference< XRegressionCurve > xResult;
109 // todo: use factory methods with service name
110 if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
111 "com.sun.star.chart2.LinearRegressionCurve" )))
113 xResult.set(
114 new LinearRegressionCurve( xContext ));
116 else if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
117 "com.sun.star.chart2.LogarithmicRegressionCurve" )))
119 xResult.set(
120 new LogarithmicRegressionCurve( xContext ));
122 else if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
123 "com.sun.star.chart2.ExponentialRegressionCurve" )))
125 xResult.set(
126 new ExponentialRegressionCurve( xContext ));
128 else if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
129 "com.sun.star.chart2.PotentialRegressionCurve" )))
131 xResult.set(
132 new PotentialRegressionCurve( xContext ));
135 return xResult;
138 // ------------------------------------------------------------
140 // static
141 Reference< XRegressionCurveCalculator > RegressionCurveHelper::createRegressionCurveCalculatorByServiceName(
142 ::rtl::OUString aServiceName )
144 Reference< XRegressionCurveCalculator > xResult;
146 // todo: use factory methods with service name
147 if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
148 "com.sun.star.chart2.MeanValueRegressionCurve" )))
150 xResult.set( new MeanValueRegressionCurveCalculator());
152 if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
153 "com.sun.star.chart2.LinearRegressionCurve" )))
155 xResult.set( new LinearRegressionCurveCalculator());
157 else if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
158 "com.sun.star.chart2.LogarithmicRegressionCurve" )))
160 xResult.set( new LogarithmicRegressionCurveCalculator());
162 else if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
163 "com.sun.star.chart2.ExponentialRegressionCurve" )))
165 xResult.set( new ExponentialRegressionCurveCalculator());
167 else if( aServiceName.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
168 "com.sun.star.chart2.PotentialRegressionCurve" )))
170 xResult.set( new PotentialRegressionCurveCalculator());
173 return xResult;
176 // static
177 void RegressionCurveHelper::initializeCurveCalculator(
178 const Reference< XRegressionCurveCalculator > & xOutCurveCalculator,
179 const Reference< data::XDataSource > & xSource,
180 bool bUseXValuesIfAvailable /* = true */ )
182 if( ! (xOutCurveCalculator.is() &&
183 xSource.is() ))
184 return;
186 Sequence< double > aXValues, aYValues;
187 bool bXValuesFound = false, bYValuesFound = false;
189 Sequence< Reference< data::XLabeledDataSequence > > aDataSeqs( xSource->getDataSequences());
190 sal_Int32 i = 0;
191 for( i=0;
192 ! (bXValuesFound && bYValuesFound) && i<aDataSeqs.getLength();
193 ++i )
197 Reference< data::XDataSequence > xSeq( aDataSeqs[i]->getValues());
198 Reference< XPropertySet > xProp( xSeq, uno::UNO_QUERY_THROW );
199 ::rtl::OUString aRole;
200 if( xProp->getPropertyValue(
201 ::rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "Role" ))) >>= aRole )
203 if( bUseXValuesIfAvailable &&
204 ! bXValuesFound &&
205 aRole.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "values-x" )))
207 aXValues = DataSequenceToDoubleSequence( xSeq );
208 bXValuesFound = true;
210 else if( ! bYValuesFound &&
211 aRole.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "values-y" )))
213 aYValues = DataSequenceToDoubleSequence( xSeq );
214 bYValuesFound = true;
218 catch( Exception & ex )
220 ASSERT_EXCEPTION( ex );
224 if( ! bXValuesFound &&
225 bYValuesFound )
227 // initialize with 1, 2, ...
228 //first category (index 0) matches with real number 1.0
229 aXValues.realloc( aYValues.getLength());
230 for( i=0; i<aXValues.getLength(); ++i )
231 aXValues[i] = i+1;
232 bXValuesFound = true;
235 if( bXValuesFound && bYValuesFound &&
236 aXValues.getLength() > 0 &&
237 aYValues.getLength() > 0 )
238 xOutCurveCalculator->recalculateRegression( aXValues, aYValues );
241 // static
242 void RegressionCurveHelper::initializeCurveCalculator(
243 const Reference< XRegressionCurveCalculator > & xOutCurveCalculator,
244 const Reference< XDataSeries > & xSeries,
245 const Reference< frame::XModel > & xModel )
247 sal_Int32 nAxisType = ChartTypeHelper::getAxisType(
248 ChartModelHelper::getChartTypeOfSeries( xModel, xSeries ), 0 ); // x-axis
250 initializeCurveCalculator( xOutCurveCalculator,
251 uno::Reference< data::XDataSource >( xSeries, uno::UNO_QUERY ),
252 (nAxisType == AxisType::REALNUMBER) );
255 // ----------------------------------------
257 // static
258 bool RegressionCurveHelper::hasMeanValueLine(
259 const uno::Reference< XRegressionCurveContainer > & xRegCnt )
261 if( !xRegCnt.is())
262 return false;
266 uno::Sequence< uno::Reference< XRegressionCurve > > aCurves(
267 xRegCnt->getRegressionCurves());
268 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
270 if( isMeanValueLine( aCurves[i] ))
271 return true;
274 catch( Exception & ex )
276 ASSERT_EXCEPTION( ex );
279 return false;
282 // static
283 bool RegressionCurveHelper::isMeanValueLine(
284 const uno::Reference< chart2::XRegressionCurve > & xRegCurve )
286 uno::Reference< XServiceName > xServName( xRegCurve, uno::UNO_QUERY );
287 if( xServName.is() &&
288 xServName->getServiceName().equals(
289 C2U( "com.sun.star.chart2.MeanValueRegressionCurve" )))
290 return true;
291 return false;
294 // static
295 uno::Reference< chart2::XRegressionCurve >
296 RegressionCurveHelper::getMeanValueLine(
297 const uno::Reference< chart2::XRegressionCurveContainer > & xRegCnt )
299 if( xRegCnt.is())
303 uno::Sequence< uno::Reference< XRegressionCurve > > aCurves(
304 xRegCnt->getRegressionCurves());
305 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
307 if( isMeanValueLine( aCurves[i] ))
308 return aCurves[i];
311 catch( Exception & ex )
313 ASSERT_EXCEPTION( ex );
317 return uno::Reference< chart2::XRegressionCurve >();
320 // static
321 void RegressionCurveHelper::addMeanValueLine(
322 uno::Reference< XRegressionCurveContainer > & xRegCnt,
323 const uno::Reference< XComponentContext > & xContext,
324 const uno::Reference< XPropertySet > & xSeriesProp )
326 if( !xRegCnt.is() ||
327 ::chart::RegressionCurveHelper::hasMeanValueLine( xRegCnt ) )
328 return;
330 // todo: use a valid context
331 uno::Reference< XRegressionCurve > xCurve( createMeanValueLine( xContext ));
332 xRegCnt->addRegressionCurve( xCurve );
334 if( xSeriesProp.is())
336 uno::Reference< XPropertySet > xProp( xCurve, uno::UNO_QUERY );
337 if( xProp.is())
339 xProp->setPropertyValue( C2U( "LineColor" ),
340 xSeriesProp->getPropertyValue( C2U( "Color" )));
345 // static
346 void RegressionCurveHelper::removeMeanValueLine(
347 Reference< XRegressionCurveContainer > & xRegCnt )
349 if( !xRegCnt.is())
350 return;
354 Sequence< Reference< XRegressionCurve > > aCurves(
355 xRegCnt->getRegressionCurves());
356 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
358 if( isMeanValueLine( aCurves[i] ))
360 xRegCnt->removeRegressionCurve( aCurves[i] );
361 // attention: the iterator i has become invalid now
363 // note: assume that there is only one mean-value curve
364 // to remove multiple mean-value curves remove the break
365 break;
369 catch( Exception & ex )
371 ASSERT_EXCEPTION( ex );
375 void RegressionCurveHelper::addRegressionCurve(
376 tRegressionType eType,
377 uno::Reference< XRegressionCurveContainer > & xRegCnt,
378 const uno::Reference< XComponentContext > & /* xContext */,
379 const uno::Reference< beans::XPropertySet >& xPropertySource,
380 const uno::Reference< beans::XPropertySet >& xEquationProperties )
382 if( !xRegCnt.is() )
383 return;
385 if( eType == REGRESSION_TYPE_NONE )
387 OSL_ENSURE(false,"don't create a regression curve of type none");
388 return;
391 uno::Reference< chart2::XRegressionCurve > xCurve;
392 ::rtl::OUString aServiceName( lcl_getServiceNameForType( eType ));
394 if( aServiceName.getLength())
396 // todo: use a valid context
397 xCurve.set( createRegressionCurveByServiceName(
398 uno::Reference< uno::XComponentContext >(), aServiceName ));
400 if( xEquationProperties.is())
401 xCurve->setEquationProperties( xEquationProperties );
403 uno::Reference< beans::XPropertySet > xProp( xCurve, uno::UNO_QUERY );
404 if( xProp.is())
406 if( xPropertySource.is())
407 comphelper::copyProperties( xPropertySource, xProp );
408 else
410 uno::Reference< XPropertySet > xSeriesProp( xRegCnt, uno::UNO_QUERY );
411 if( xSeriesProp.is())
413 xProp->setPropertyValue( C2U( "LineColor" ),
414 xSeriesProp->getPropertyValue( C2U( "Color" )));
416 // xProp->setPropertyValue( C2U( "LineWidth" ), uno::makeAny( sal_Int32( 100 )));
420 xRegCnt->addRegressionCurve( xCurve );
423 /** removes all regression curves that are not of type mean value
424 and returns true, if anything was removed
426 bool RegressionCurveHelper::removeAllExceptMeanValueLine(
427 uno::Reference< chart2::XRegressionCurveContainer > & xRegCnt )
429 bool bRemovedSomething = false;
430 if( xRegCnt.is())
434 uno::Sequence< uno::Reference< chart2::XRegressionCurve > > aCurves(
435 xRegCnt->getRegressionCurves());
436 ::std::vector< uno::Reference< chart2::XRegressionCurve > > aCurvesToDelete;
437 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
439 if( ! isMeanValueLine( aCurves[i] ))
441 aCurvesToDelete.push_back( aCurves[ i ] );
445 for( ::std::vector< uno::Reference< chart2::XRegressionCurve > >::const_iterator aIt = aCurvesToDelete.begin();
446 aIt != aCurvesToDelete.end(); ++aIt )
448 xRegCnt->removeRegressionCurve( *aIt );
449 bRemovedSomething = true;
452 catch( uno::Exception & ex )
454 ASSERT_EXCEPTION( ex );
457 return bRemovedSomething;
460 void RegressionCurveHelper::removeEquations(
461 uno::Reference< chart2::XRegressionCurveContainer > & xRegCnt )
463 if( xRegCnt.is())
467 uno::Sequence< uno::Reference< chart2::XRegressionCurve > > aCurves(
468 xRegCnt->getRegressionCurves());
469 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
471 if( !isMeanValueLine( aCurves[i] ) )
473 uno::Reference< chart2::XRegressionCurve > xRegCurve( aCurves[ i ] );
474 if( xRegCurve.is() )
476 uno::Reference< beans::XPropertySet > xEqProp( xRegCurve->getEquationProperties() ) ;
477 if( xEqProp.is())
479 xEqProp->setPropertyValue( C2U("ShowEquation"), uno::makeAny( false ));
480 xEqProp->setPropertyValue( C2U("ShowCorrelationCoefficient"), uno::makeAny( false ));
486 catch( uno::Exception & ex )
488 ASSERT_EXCEPTION( ex );
493 // static
494 void RegressionCurveHelper::replaceOrAddCurveAndReduceToOne(
495 tRegressionType eType,
496 uno::Reference< XRegressionCurveContainer > & xRegCnt,
497 const uno::Reference< XComponentContext > & xContext )
499 uno::Reference< chart2::XRegressionCurve > xRegressionCurve( getFirstCurveNotMeanValueLine( xRegCnt ));
500 if( ! xRegressionCurve.is())
501 RegressionCurveHelper::addRegressionCurve( eType, xRegCnt, xContext );
502 else
504 OUString aServiceName( lcl_getServiceNameForType( eType ));
505 if( aServiceName.getLength())
507 RegressionCurveHelper::removeAllExceptMeanValueLine( xRegCnt );
508 RegressionCurveHelper::addRegressionCurve(
509 eType, xRegCnt, xContext,
510 Reference< beans::XPropertySet >( xRegressionCurve, uno::UNO_QUERY ),
511 xRegressionCurve->getEquationProperties());
516 // static
517 uno::Reference< chart2::XRegressionCurve > RegressionCurveHelper::getFirstCurveNotMeanValueLine(
518 const Reference< XRegressionCurveContainer > & xRegCnt )
520 if( !xRegCnt.is())
521 return NULL;
525 uno::Sequence< uno::Reference< chart2::XRegressionCurve > > aCurves(
526 xRegCnt->getRegressionCurves());
527 ::std::vector< uno::Reference< chart2::XRegressionCurve > > aCurvesToDelete;
528 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
530 if( ! isMeanValueLine( aCurves[i] ))
532 return aCurves[ i ];
536 catch( Exception & ex )
538 ASSERT_EXCEPTION( ex );
541 return NULL;
544 // static
545 RegressionCurveHelper::tRegressionType RegressionCurveHelper::getRegressionType(
546 const Reference< XRegressionCurve > & xCurve )
548 tRegressionType eResult = REGRESSION_TYPE_UNKNOWN;
552 Reference< lang::XServiceName > xServName( xCurve, uno::UNO_QUERY );
553 if( xServName.is())
555 ::rtl::OUString aServiceName( xServName->getServiceName() );
557 if( aServiceName.equalsAsciiL(
558 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.LinearRegressionCurve" )))
560 eResult = REGRESSION_TYPE_LINEAR;
562 else if( aServiceName.equalsAsciiL(
563 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.LogarithmicRegressionCurve" )))
565 eResult = REGRESSION_TYPE_LOG;
567 else if( aServiceName.equalsAsciiL(
568 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.ExponentialRegressionCurve" )))
570 eResult = REGRESSION_TYPE_EXP;
572 else if( aServiceName.equalsAsciiL(
573 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.PotentialRegressionCurve" )))
575 eResult = REGRESSION_TYPE_POWER;
577 else if( aServiceName.equalsAsciiL(
578 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.MeanValueRegressionCurve" )))
580 eResult = REGRESSION_TYPE_MEAN_VALUE;
584 catch( Exception & ex )
586 ASSERT_EXCEPTION( ex );
589 return eResult;
592 // static
593 RegressionCurveHelper::tRegressionType RegressionCurveHelper::getFirstRegressTypeNotMeanValueLine(
594 const Reference< XRegressionCurveContainer > & xRegCnt )
596 tRegressionType eResult = REGRESSION_TYPE_NONE;
598 if( xRegCnt.is())
600 Sequence< Reference< XRegressionCurve > > aCurves(
601 xRegCnt->getRegressionCurves());
602 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
604 tRegressionType eType = getRegressionType( aCurves[i] );
605 if( eType != REGRESSION_TYPE_MEAN_VALUE &&
606 eType != REGRESSION_TYPE_UNKNOWN )
608 eResult = eType;
609 break;
614 return eResult;
617 OUString RegressionCurveHelper::getUINameForRegressionCurve( const Reference< XRegressionCurve >& xRegressionCurve )
619 OUString aResult;
620 Reference< lang::XServiceName > xServiceName( xRegressionCurve, uno::UNO_QUERY );
621 if( ! xServiceName.is())
622 return aResult;
624 OUString aServiceName( xServiceName->getServiceName());
625 if( aServiceName.equalsAsciiL(
626 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.MeanValueRegressionCurve" )))
628 OSL_ENSURE( false, "Meanvalue lines in legend not supported" );
629 aResult = OUString();
630 // aResult = ::chart::SchResId::getResString( STR_OBJECT_AVERAGE_LINE );
632 else if( aServiceName.equalsAsciiL(
633 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.LinearRegressionCurve" )))
635 aResult = ::chart::SchResId::getResString( STR_REGRESSION_LINEAR );
637 else if( aServiceName.equalsAsciiL(
638 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.LogarithmicRegressionCurve" )))
640 aResult = ::chart::SchResId::getResString( STR_REGRESSION_LOG );
642 else if( aServiceName.equalsAsciiL(
643 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.ExponentialRegressionCurve" )))
645 aResult = ::chart::SchResId::getResString( STR_REGRESSION_EXP );
647 else if( aServiceName.equalsAsciiL(
648 RTL_CONSTASCII_STRINGPARAM( "com.sun.star.chart2.PotentialRegressionCurve" )))
650 aResult = ::chart::SchResId::getResString( STR_REGRESSION_POWER );
653 return aResult;
656 // static
657 ::std::vector< Reference< chart2::XRegressionCurve > >
658 RegressionCurveHelper::getAllRegressionCurvesNotMeanValueLine(
659 const Reference< chart2::XDiagram > & xDiagram )
661 ::std::vector< Reference< chart2::XRegressionCurve > > aResult;
662 ::std::vector< Reference< chart2::XDataSeries > > aSeries( DiagramHelper::getDataSeriesFromDiagram( xDiagram ));
663 for( ::std::vector< Reference< chart2::XDataSeries > >::iterator aIt( aSeries.begin());
664 aIt != aSeries.end(); ++aIt )
666 Reference< chart2::XRegressionCurveContainer > xCurveCnt( *aIt, uno::UNO_QUERY );
667 if( xCurveCnt.is())
669 uno::Sequence< uno::Reference< chart2::XRegressionCurve > > aCurves(
670 xCurveCnt->getRegressionCurves());
671 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
673 if( ! isMeanValueLine( aCurves[i] ))
674 aResult.push_back( aCurves[i] );
679 return aResult;
682 // static
683 void RegressionCurveHelper::resetEquationPosition(
684 const Reference< chart2::XRegressionCurve > & xCurve )
686 if( xCurve.is())
690 const OUString aPosPropertyName( RTL_CONSTASCII_USTRINGPARAM( "RelativePosition" ));
691 Reference< beans::XPropertySet > xEqProp( xCurve->getEquationProperties()); // since m233: , uno::UNO_SET_THROW );
692 if( xEqProp->getPropertyValue( aPosPropertyName ).hasValue())
693 xEqProp->setPropertyValue( aPosPropertyName, uno::Any());
695 catch( const uno::Exception & ex )
697 ASSERT_EXCEPTION( ex );
702 sal_Int32 RegressionCurveHelper::getRegressionCurveIndex(
703 const Reference< chart2::XRegressionCurveContainer > & xContainer,
704 const Reference< chart2::XRegressionCurve > & xCurve )
706 if( xContainer.is())
708 uno::Sequence< uno::Reference< XRegressionCurve > > aCurves(
709 xContainer->getRegressionCurves());
710 for( sal_Int32 i = 0; i < aCurves.getLength(); ++i )
712 if( xCurve == aCurves[i] )
713 return i;
716 return -1;
719 bool RegressionCurveHelper::hasEquation( const Reference< chart2::XRegressionCurve > & xCurve )
721 bool bHasEquation = false;
722 if( xCurve.is())
724 uno::Reference< beans::XPropertySet > xEquationProp( xCurve->getEquationProperties());
725 if( xEquationProp.is())
727 bool bShowEquation = false;
728 bool bShowCoefficient = false;
729 xEquationProp->getPropertyValue( C2U("ShowEquation")) >>= bShowEquation;
730 xEquationProp->getPropertyValue( C2U("ShowCorrelationCoefficient")) >>= bShowCoefficient;
731 bHasEquation = bShowEquation || bShowCoefficient;
734 return bHasEquation;
737 //.............................................................................
738 } //namespace chart
739 //.............................................................................