1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
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"
44 #include "PropertyHelper.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
;
63 OUString
lcl_getServiceNameForType( ::chart::RegressionCurveHelper::tRegressionType eType
)
65 OUString aServiceName
;
68 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_LINEAR
:
69 aServiceName
= C2U( "com.sun.star.chart2.LinearRegressionCurve" );
71 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_LOG
:
72 aServiceName
= C2U( "com.sun.star.chart2.LogarithmicRegressionCurve" );
74 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_EXP
:
75 aServiceName
= C2U( "com.sun.star.chart2.ExponentialRegressionCurve" );
77 case ::chart::RegressionCurveHelper::REGRESSION_TYPE_POWER
:
78 aServiceName
= C2U( "com.sun.star.chart2.PotentialRegressionCurve" );
81 OSL_ENSURE(false,"unknown regression curve type - use linear instead");
82 aServiceName
= C2U( "com.sun.star.chart2.LinearRegressionCurve" );
87 } // anonymous namespace
89 //.............................................................................
92 //.............................................................................
95 Reference
< XRegressionCurve
> RegressionCurveHelper::createMeanValueLine(
96 const Reference
< XComponentContext
> & xContext
)
98 return Reference
< XRegressionCurve
>(
99 new MeanValueRegressionCurve( xContext
));
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" )))
114 new LinearRegressionCurve( xContext
));
116 else if( aServiceName
.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
117 "com.sun.star.chart2.LogarithmicRegressionCurve" )))
120 new LogarithmicRegressionCurve( xContext
));
122 else if( aServiceName
.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
123 "com.sun.star.chart2.ExponentialRegressionCurve" )))
126 new ExponentialRegressionCurve( xContext
));
128 else if( aServiceName
.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM(
129 "com.sun.star.chart2.PotentialRegressionCurve" )))
132 new PotentialRegressionCurve( xContext
));
138 // ------------------------------------------------------------
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());
177 void RegressionCurveHelper::initializeCurveCalculator(
178 const Reference
< XRegressionCurveCalculator
> & xOutCurveCalculator
,
179 const Reference
< data::XDataSource
> & xSource
,
180 bool bUseXValuesIfAvailable
/* = true */ )
182 if( ! (xOutCurveCalculator
.is() &&
186 Sequence
< double > aXValues
, aYValues
;
187 bool bXValuesFound
= false, bYValuesFound
= false;
189 Sequence
< Reference
< data::XLabeledDataSequence
> > aDataSeqs( xSource
->getDataSequences());
192 ! (bXValuesFound
&& bYValuesFound
) && i
<aDataSeqs
.getLength();
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
&&
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
&&
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
)
232 bXValuesFound
= true;
235 if( bXValuesFound
&& bYValuesFound
&&
236 aXValues
.getLength() > 0 &&
237 aYValues
.getLength() > 0 )
238 xOutCurveCalculator
->recalculateRegression( aXValues
, aYValues
);
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 // ----------------------------------------
258 bool RegressionCurveHelper::hasMeanValueLine(
259 const uno::Reference
< XRegressionCurveContainer
> & xRegCnt
)
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
] ))
274 catch( Exception
& ex
)
276 ASSERT_EXCEPTION( ex
);
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" )))
295 uno::Reference
< chart2::XRegressionCurve
>
296 RegressionCurveHelper::getMeanValueLine(
297 const uno::Reference
< chart2::XRegressionCurveContainer
> & xRegCnt
)
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
] ))
311 catch( Exception
& ex
)
313 ASSERT_EXCEPTION( ex
);
317 return uno::Reference
< chart2::XRegressionCurve
>();
321 void RegressionCurveHelper::addMeanValueLine(
322 uno::Reference
< XRegressionCurveContainer
> & xRegCnt
,
323 const uno::Reference
< XComponentContext
> & xContext
,
324 const uno::Reference
< XPropertySet
> & xSeriesProp
)
327 ::chart::RegressionCurveHelper::hasMeanValueLine( xRegCnt
) )
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
);
339 xProp
->setPropertyValue( C2U( "LineColor" ),
340 xSeriesProp
->getPropertyValue( C2U( "Color" )));
346 void RegressionCurveHelper::removeMeanValueLine(
347 Reference
< XRegressionCurveContainer
> & xRegCnt
)
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
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
)
385 if( eType
== REGRESSION_TYPE_NONE
)
387 OSL_ENSURE(false,"don't create a regression curve of type none");
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
);
406 if( xPropertySource
.is())
407 comphelper::copyProperties( xPropertySource
, xProp
);
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;
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
)
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
] );
476 uno::Reference
< beans::XPropertySet
> xEqProp( xRegCurve
->getEquationProperties() ) ;
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
);
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
);
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());
517 uno::Reference
< chart2::XRegressionCurve
> RegressionCurveHelper::getFirstCurveNotMeanValueLine(
518 const Reference
< XRegressionCurveContainer
> & xRegCnt
)
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
] ))
536 catch( Exception
& ex
)
538 ASSERT_EXCEPTION( ex
);
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
);
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
);
593 RegressionCurveHelper::tRegressionType
RegressionCurveHelper::getFirstRegressTypeNotMeanValueLine(
594 const Reference
< XRegressionCurveContainer
> & xRegCnt
)
596 tRegressionType eResult
= REGRESSION_TYPE_NONE
;
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
)
617 OUString
RegressionCurveHelper::getUINameForRegressionCurve( const Reference
< XRegressionCurve
>& xRegressionCurve
)
620 Reference
< lang::XServiceName
> xServiceName( xRegressionCurve
, uno::UNO_QUERY
);
621 if( ! xServiceName
.is())
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
);
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
);
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
] );
683 void RegressionCurveHelper::resetEquationPosition(
684 const Reference
< chart2::XRegressionCurve
> & xCurve
)
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
)
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
] )
719 bool RegressionCurveHelper::hasEquation( const Reference
< chart2::XRegressionCurve
> & xCurve
)
721 bool bHasEquation
= false;
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
;
737 //.............................................................................
739 //.............................................................................