2007-11-23 10:52:13 +00:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 19:45:32 +00:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
2010-02-12 15:01:35 +01:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
2008-04-10 19:45:32 +00:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
2008-04-10 19:45:32 +00:00
|
|
|
* This file is part of OpenOffice.org.
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
2008-04-10 19:45:32 +00:00
|
|
|
* 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.
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
2008-04-10 19:45:32 +00:00
|
|
|
* 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).
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
2008-04-10 19:45:32 +00:00
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* version 3 along with OpenOffice.org. If not, see
|
|
|
|
* <http://www.openoffice.org/license.html>
|
|
|
|
* for a copy of the LGPLv3 License.
|
2007-11-23 10:52:13 +00:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_chart2.hxx"
|
2008-02-18 14:56:00 +00:00
|
|
|
#include "RegressionCurveHelper.hxx"
|
2007-11-23 10:52:13 +00:00
|
|
|
#include "RegressionCurveItemConverter.hxx"
|
|
|
|
#include "SchWhichPairs.hxx"
|
|
|
|
#include "macros.hxx"
|
|
|
|
#include "ItemPropertyMap.hxx"
|
|
|
|
#include "GraphicPropertyItemConverter.hxx"
|
|
|
|
|
|
|
|
#include <com/sun/star/chart2/XRegressionCurve.hpp>
|
|
|
|
|
|
|
|
// for SfxBoolItem
|
2009-10-16 00:05:16 +02:00
|
|
|
#include <svl/eitem.hxx>
|
2008-02-18 14:56:00 +00:00
|
|
|
#include <svx/chrtitem.hxx>
|
2007-11-23 10:52:13 +00:00
|
|
|
|
|
|
|
#include <functional>
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
|
2008-02-18 14:56:00 +00:00
|
|
|
namespace
|
|
|
|
{
|
|
|
|
|
|
|
|
::chart::RegressionCurveHelper::tRegressionType lcl_convertRegressionType( SvxChartRegress eRegress )
|
|
|
|
{
|
|
|
|
::chart::RegressionCurveHelper::tRegressionType eType = ::chart::RegressionCurveHelper::REGRESSION_TYPE_NONE;
|
|
|
|
switch( eRegress )
|
|
|
|
{
|
|
|
|
case CHREGRESS_LINEAR:
|
|
|
|
eType = ::chart::RegressionCurveHelper::REGRESSION_TYPE_LINEAR;
|
|
|
|
break;
|
|
|
|
case CHREGRESS_LOG:
|
|
|
|
eType = ::chart::RegressionCurveHelper::REGRESSION_TYPE_LOG;
|
|
|
|
break;
|
|
|
|
case CHREGRESS_EXP:
|
|
|
|
eType = ::chart::RegressionCurveHelper::REGRESSION_TYPE_EXP;
|
|
|
|
break;
|
|
|
|
case CHREGRESS_POWER:
|
|
|
|
eType = ::chart::RegressionCurveHelper::REGRESSION_TYPE_POWER;
|
|
|
|
break;
|
|
|
|
case CHREGRESS_NONE:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
return eType;
|
|
|
|
}
|
|
|
|
|
|
|
|
} // anonymous namespace
|
|
|
|
|
2007-11-23 10:52:13 +00:00
|
|
|
namespace chart
|
|
|
|
{
|
|
|
|
namespace wrapper
|
|
|
|
{
|
|
|
|
|
|
|
|
RegressionCurveItemConverter::RegressionCurveItemConverter(
|
|
|
|
const uno::Reference< beans::XPropertySet > & rPropertySet,
|
2008-02-18 14:56:00 +00:00
|
|
|
const uno::Reference< chart2::XRegressionCurveContainer > & xRegCurveCnt,
|
2007-11-23 10:52:13 +00:00
|
|
|
SfxItemPool& rItemPool,
|
|
|
|
SdrModel& rDrawModel,
|
|
|
|
const uno::Reference< lang::XMultiServiceFactory > & xNamedPropertyContainerFactory ) :
|
|
|
|
ItemConverter( rPropertySet, rItemPool ),
|
|
|
|
m_spGraphicConverter( new GraphicPropertyItemConverter(
|
|
|
|
rPropertySet, rItemPool, rDrawModel,
|
|
|
|
xNamedPropertyContainerFactory,
|
2008-02-18 14:56:00 +00:00
|
|
|
GraphicPropertyItemConverter::LINE_PROPERTIES )),
|
|
|
|
m_xCurveContainer( xRegCurveCnt )
|
2007-11-23 10:52:13 +00:00
|
|
|
{}
|
|
|
|
|
|
|
|
RegressionCurveItemConverter::~RegressionCurveItemConverter()
|
|
|
|
{}
|
|
|
|
|
|
|
|
void RegressionCurveItemConverter::FillItemSet( SfxItemSet & rOutItemSet ) const
|
|
|
|
{
|
|
|
|
m_spGraphicConverter->FillItemSet( rOutItemSet );
|
|
|
|
|
|
|
|
// own items
|
|
|
|
ItemConverter::FillItemSet( rOutItemSet );
|
|
|
|
}
|
|
|
|
|
|
|
|
bool RegressionCurveItemConverter::ApplyItemSet( const SfxItemSet & rItemSet )
|
|
|
|
{
|
|
|
|
bool bResult = m_spGraphicConverter->ApplyItemSet( rItemSet );
|
|
|
|
|
|
|
|
// own items
|
|
|
|
return ItemConverter::ApplyItemSet( rItemSet ) || bResult;
|
|
|
|
}
|
|
|
|
|
|
|
|
const USHORT * RegressionCurveItemConverter::GetWhichPairs() const
|
|
|
|
{
|
|
|
|
// must span all used items!
|
|
|
|
return nRegressionCurveWhichPairs;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool RegressionCurveItemConverter::GetItemProperty(
|
|
|
|
tWhichIdType /* nWhichId */, tPropertyNameWithMemberId & /* rOutProperty */ ) const
|
|
|
|
{
|
|
|
|
// No own (non-special) properties
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
bool RegressionCurveItemConverter::ApplySpecialItem(
|
|
|
|
USHORT nWhichId, const SfxItemSet & rItemSet )
|
|
|
|
throw( uno::Exception )
|
|
|
|
{
|
2008-02-18 14:56:00 +00:00
|
|
|
uno::Reference< chart2::XRegressionCurve > xCurve( GetPropertySet(), uno::UNO_QUERY );
|
2007-11-23 10:52:13 +00:00
|
|
|
bool bChanged = false;
|
|
|
|
|
|
|
|
switch( nWhichId )
|
|
|
|
{
|
2008-03-06 15:50:42 +00:00
|
|
|
case SCHATTR_REGRESSION_TYPE:
|
2008-02-18 14:56:00 +00:00
|
|
|
{
|
|
|
|
OSL_ASSERT( xCurve.is());
|
|
|
|
if( xCurve.is())
|
|
|
|
{
|
|
|
|
SvxChartRegress eRegress = static_cast< SvxChartRegress >(
|
|
|
|
static_cast< sal_Int32 >( RegressionCurveHelper::getRegressionType( xCurve )));
|
|
|
|
SvxChartRegress eNewRegress = static_cast< const SvxChartRegressItem & >(
|
|
|
|
rItemSet.Get( nWhichId )).GetValue();
|
|
|
|
if( eRegress != eNewRegress )
|
|
|
|
{
|
|
|
|
// note that changing the regression type changes the object
|
|
|
|
// for which this converter was created. Not optimal, but
|
|
|
|
// currently the only way to handle the type in the
|
|
|
|
// regression curve properties dialog
|
|
|
|
RegressionCurveHelper::replaceOrAddCurveAndReduceToOne(
|
|
|
|
lcl_convertRegressionType( eNewRegress ), m_xCurveContainer,
|
|
|
|
uno::Reference< uno::XComponentContext >());
|
|
|
|
uno::Reference< beans::XPropertySet > xNewPropSet(
|
|
|
|
RegressionCurveHelper::getFirstCurveNotMeanValueLine( m_xCurveContainer ),
|
|
|
|
uno::UNO_QUERY );
|
|
|
|
OSL_ASSERT( xNewPropSet.is());
|
|
|
|
if( xNewPropSet.is())
|
|
|
|
{
|
|
|
|
resetPropertySet( xNewPropSet );
|
|
|
|
bChanged = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2007-11-23 10:52:13 +00:00
|
|
|
case SCHATTR_REGRESSION_SHOW_EQUATION:
|
|
|
|
{
|
|
|
|
OSL_ASSERT( xCurve.is());
|
|
|
|
if( xCurve.is())
|
|
|
|
{
|
|
|
|
bool bNewShow = static_cast< BOOL >(
|
|
|
|
static_cast< const SfxBoolItem & >(
|
|
|
|
rItemSet.Get( nWhichId )).GetValue());
|
|
|
|
|
|
|
|
uno::Reference< beans::XPropertySet > xEqProp( xCurve->getEquationProperties());
|
|
|
|
OSL_ASSERT( xEqProp.is());
|
|
|
|
bool bOldShow = false;
|
|
|
|
if( xEqProp.is() &&
|
|
|
|
(xEqProp->getPropertyValue( C2U( "ShowEquation" )) >>= bOldShow) &&
|
|
|
|
bOldShow != bNewShow )
|
|
|
|
{
|
|
|
|
xEqProp->setPropertyValue( C2U( "ShowEquation" ), uno::makeAny( bNewShow ));
|
|
|
|
bChanged = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SCHATTR_REGRESSION_SHOW_COEFF:
|
|
|
|
{
|
|
|
|
OSL_ASSERT( xCurve.is());
|
|
|
|
if( xCurve.is())
|
|
|
|
{
|
|
|
|
bool bNewShow = static_cast< BOOL >(
|
|
|
|
static_cast< const SfxBoolItem & >(
|
|
|
|
rItemSet.Get( nWhichId )).GetValue());
|
|
|
|
|
|
|
|
uno::Reference< beans::XPropertySet > xEqProp( xCurve->getEquationProperties());
|
|
|
|
OSL_ASSERT( xEqProp.is());
|
|
|
|
bool bOldShow = false;
|
|
|
|
if( xEqProp.is() &&
|
|
|
|
(xEqProp->getPropertyValue( C2U( "ShowCorrelationCoefficient" )) >>= bOldShow) &&
|
|
|
|
bOldShow != bNewShow )
|
|
|
|
{
|
|
|
|
xEqProp->setPropertyValue( C2U( "ShowCorrelationCoefficient" ), uno::makeAny( bNewShow ));
|
|
|
|
bChanged = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return bChanged;
|
|
|
|
}
|
|
|
|
|
|
|
|
void RegressionCurveItemConverter::FillSpecialItem(
|
|
|
|
USHORT nWhichId, SfxItemSet & rOutItemSet ) const
|
|
|
|
throw( uno::Exception )
|
|
|
|
{
|
2008-02-18 14:56:00 +00:00
|
|
|
uno::Reference< chart2::XRegressionCurve > xCurve( GetPropertySet(), uno::UNO_QUERY );
|
|
|
|
|
2007-11-23 10:52:13 +00:00
|
|
|
switch( nWhichId )
|
|
|
|
{
|
2008-03-06 15:50:42 +00:00
|
|
|
case SCHATTR_REGRESSION_TYPE:
|
2008-02-18 14:56:00 +00:00
|
|
|
{
|
|
|
|
OSL_ASSERT( xCurve.is());
|
|
|
|
if( xCurve.is())
|
|
|
|
{
|
|
|
|
SvxChartRegress eRegress = static_cast< SvxChartRegress >(
|
|
|
|
static_cast< sal_Int32 >( RegressionCurveHelper::getRegressionType( xCurve )));
|
2008-03-06 15:50:42 +00:00
|
|
|
rOutItemSet.Put( SvxChartRegressItem( eRegress, SCHATTR_REGRESSION_TYPE ));
|
2008-02-18 14:56:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2007-11-23 10:52:13 +00:00
|
|
|
case SCHATTR_REGRESSION_SHOW_EQUATION:
|
|
|
|
{
|
|
|
|
OSL_ASSERT( xCurve.is());
|
|
|
|
if( xCurve.is())
|
|
|
|
{
|
|
|
|
uno::Reference< beans::XPropertySet > xEqProp( xCurve->getEquationProperties());
|
|
|
|
OSL_ASSERT( xEqProp.is());
|
|
|
|
bool bShow = false;
|
|
|
|
if( xEqProp.is() &&
|
|
|
|
(xEqProp->getPropertyValue( C2U( "ShowEquation" )) >>= bShow))
|
|
|
|
{
|
|
|
|
rOutItemSet.Put( SfxBoolItem( nWhichId, bShow ));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
|
|
|
case SCHATTR_REGRESSION_SHOW_COEFF:
|
|
|
|
{
|
|
|
|
OSL_ASSERT( xCurve.is());
|
|
|
|
if( xCurve.is())
|
|
|
|
{
|
|
|
|
uno::Reference< beans::XPropertySet > xEqProp( xCurve->getEquationProperties());
|
|
|
|
OSL_ASSERT( xEqProp.is());
|
|
|
|
bool bShow = false;
|
|
|
|
if( xEqProp.is() &&
|
|
|
|
(xEqProp->getPropertyValue( C2U( "ShowCorrelationCoefficient" )) >>= bShow))
|
|
|
|
{
|
|
|
|
rOutItemSet.Put( SfxBoolItem( nWhichId, bShow ));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} // namespace wrapper
|
|
|
|
} // namespace chart
|