2007-05-22 12:58:02 -05:00
|
|
|
/*************************************************************************
|
|
|
|
*
|
2008-04-10 16:05:41 -05:00
|
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
2007-05-22 12:58:02 -05:00
|
|
|
*
|
2010-02-12 08:01:35 -06:00
|
|
|
* Copyright 2000, 2010 Oracle and/or its affiliates.
|
2007-05-22 12:58:02 -05:00
|
|
|
*
|
2008-04-10 16:05:41 -05:00
|
|
|
* OpenOffice.org - a multi-platform office productivity suite
|
2007-05-22 12:58:02 -05:00
|
|
|
*
|
2008-04-10 16:05:41 -05:00
|
|
|
* This file is part of OpenOffice.org.
|
2007-05-22 12:58:02 -05:00
|
|
|
*
|
2008-04-10 16:05:41 -05: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-05-22 12:58:02 -05:00
|
|
|
*
|
2008-04-10 16:05:41 -05: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-05-22 12:58:02 -05:00
|
|
|
*
|
2008-04-10 16:05:41 -05: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-05-22 12:58:02 -05:00
|
|
|
*
|
|
|
|
************************************************************************/
|
|
|
|
|
|
|
|
// MARKER(update_precomp.py): autogen include statement, do not remove
|
|
|
|
#include "precompiled_chart2.hxx"
|
|
|
|
|
|
|
|
#include "DataSourceHelper.hxx"
|
|
|
|
#include "macros.hxx"
|
|
|
|
#include "ChartModelHelper.hxx"
|
|
|
|
#include "DiagramHelper.hxx"
|
|
|
|
#include "DataSeriesHelper.hxx"
|
|
|
|
#include "DataSource.hxx"
|
|
|
|
#include "ContainerHelper.hxx"
|
|
|
|
#include "ControllerLockGuard.hxx"
|
|
|
|
#include "PropertyHelper.hxx"
|
2009-06-04 04:41:18 -05:00
|
|
|
#include "CachedDataSequence.hxx"
|
|
|
|
#include "LabeledDataSequence.hxx"
|
2007-05-22 12:58:02 -05:00
|
|
|
|
|
|
|
#include <com/sun/star/chart2/XChartDocument.hpp>
|
|
|
|
#include <com/sun/star/chart2/data/XDataSource.hpp>
|
|
|
|
#include <com/sun/star/chart2/data/XLabeledDataSequence.hpp>
|
|
|
|
|
|
|
|
#include <com/sun/star/chart/ChartDataRowSource.hpp>
|
2008-03-06 10:33:21 -06:00
|
|
|
#include <com/sun/star/chart/ErrorBarStyle.hpp>
|
2007-05-22 12:58:02 -05:00
|
|
|
|
|
|
|
//.............................................................................
|
|
|
|
namespace chart
|
|
|
|
{
|
|
|
|
//.............................................................................
|
|
|
|
using namespace ::com::sun::star;
|
|
|
|
using namespace ::com::sun::star::chart2;
|
|
|
|
using ::com::sun::star::uno::Reference;
|
|
|
|
using ::com::sun::star::uno::Sequence;
|
|
|
|
using ::rtl::OUString;
|
|
|
|
|
|
|
|
namespace
|
|
|
|
{
|
|
|
|
void lcl_addRanges( ::std::vector< ::rtl::OUString > & rOutResult,
|
|
|
|
const uno::Reference< data::XLabeledDataSequence > & xLabeledSeq )
|
|
|
|
{
|
|
|
|
if( ! xLabeledSeq.is())
|
|
|
|
return;
|
|
|
|
uno::Reference< data::XDataSequence > xSeq( xLabeledSeq->getLabel());
|
|
|
|
if( xSeq.is())
|
|
|
|
rOutResult.push_back( xSeq->getSourceRangeRepresentation());
|
|
|
|
xSeq.set( xLabeledSeq->getValues());
|
|
|
|
if( xSeq.is())
|
|
|
|
rOutResult.push_back( xSeq->getSourceRangeRepresentation());
|
|
|
|
}
|
|
|
|
|
2008-03-06 10:33:21 -06:00
|
|
|
void lcl_addDataSourceRanges(
|
|
|
|
::std::vector< ::rtl::OUString > & rOutResult,
|
|
|
|
const uno::Reference< data::XDataSource > & xDataSource )
|
|
|
|
{
|
|
|
|
if( xDataSource.is() )
|
|
|
|
{
|
|
|
|
uno::Sequence< uno::Reference< data::XLabeledDataSequence > > aDataSequences( xDataSource->getDataSequences() );
|
|
|
|
for( sal_Int32 i=0; i<aDataSequences.getLength(); ++i)
|
|
|
|
lcl_addRanges( rOutResult, aDataSequences[i] );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void lcl_addErrorBarRanges(
|
|
|
|
::std::vector< ::rtl::OUString > & rOutResult,
|
|
|
|
const uno::Reference< XDataSeries > & xDataSeries )
|
|
|
|
{
|
|
|
|
uno::Reference< beans::XPropertySet > xSeriesProp( xDataSeries, uno::UNO_QUERY );
|
|
|
|
if( !xSeriesProp.is())
|
|
|
|
return;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
uno::Reference< beans::XPropertySet > xErrorBarProp;
|
|
|
|
if( ( xSeriesProp->getPropertyValue( C2U("ErrorBarY")) >>= xErrorBarProp ) &&
|
|
|
|
xErrorBarProp.is())
|
|
|
|
{
|
|
|
|
sal_Int32 eStyle = ::com::sun::star::chart::ErrorBarStyle::NONE;
|
|
|
|
if( ( xErrorBarProp->getPropertyValue( C2U("ErrorBarStyle")) >>= eStyle ) &&
|
|
|
|
eStyle == ::com::sun::star::chart::ErrorBarStyle::FROM_DATA )
|
|
|
|
{
|
|
|
|
uno::Reference< data::XDataSource > xErrorBarDataSource( xErrorBarProp, uno::UNO_QUERY );
|
|
|
|
if( xErrorBarDataSource.is() )
|
|
|
|
lcl_addDataSourceRanges( rOutResult, xErrorBarDataSource );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch( const uno::Exception & ex )
|
|
|
|
{
|
|
|
|
ASSERT_EXCEPTION( ex );
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-05-22 12:58:02 -05:00
|
|
|
} // anonymous namespace
|
|
|
|
|
2009-06-04 04:41:18 -05:00
|
|
|
Reference< chart2::data::XDataSource > DataSourceHelper::createDataSource(
|
|
|
|
const Sequence< Reference< chart2::data::XLabeledDataSequence > >& rSequences )
|
|
|
|
{
|
|
|
|
return new DataSource(rSequences);
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XDataSequence > DataSourceHelper::createCachedDataSequence()
|
|
|
|
{
|
|
|
|
return new ::chart::CachedDataSequence();
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XDataSequence > DataSourceHelper::createCachedDataSequence( const ::rtl::OUString& rSingleText )
|
|
|
|
{
|
|
|
|
return new ::chart::CachedDataSequence( rSingleText );
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > DataSourceHelper::createLabeledDataSequence(
|
|
|
|
const Reference< chart2::data::XDataSequence >& xValues ,
|
|
|
|
const Reference< chart2::data::XDataSequence >& xLabels )
|
|
|
|
{
|
|
|
|
return new ::chart::LabeledDataSequence( xValues, xLabels );
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > DataSourceHelper::createLabeledDataSequence(
|
|
|
|
const Reference< chart2::data::XDataSequence >& xValues )
|
|
|
|
{
|
|
|
|
return new ::chart::LabeledDataSequence( xValues );
|
|
|
|
}
|
|
|
|
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > DataSourceHelper::createLabeledDataSequence(
|
|
|
|
const Reference< uno::XComponentContext >& xContext )
|
|
|
|
{
|
|
|
|
return new ::chart::LabeledDataSequence( xContext );
|
|
|
|
}
|
|
|
|
|
2007-05-22 12:58:02 -05:00
|
|
|
uno::Sequence< beans::PropertyValue > DataSourceHelper::createArguments(
|
|
|
|
bool bUseColumns, bool bFirstCellAsLabel, bool bHasCategories )
|
|
|
|
{
|
|
|
|
::com::sun::star::chart::ChartDataRowSource eRowSource = ::com::sun::star::chart::ChartDataRowSource_ROWS;
|
|
|
|
if( bUseColumns )
|
|
|
|
eRowSource = ::com::sun::star::chart::ChartDataRowSource_COLUMNS;
|
|
|
|
|
|
|
|
uno::Sequence< beans::PropertyValue > aArguments(3);
|
|
|
|
aArguments[0] = beans::PropertyValue( C2U("DataRowSource")
|
|
|
|
, -1, uno::makeAny( eRowSource )
|
|
|
|
, beans::PropertyState_DIRECT_VALUE );
|
|
|
|
aArguments[1] = beans::PropertyValue( C2U("FirstCellAsLabel")
|
|
|
|
, -1, uno::makeAny( bFirstCellAsLabel )
|
|
|
|
, beans::PropertyState_DIRECT_VALUE );
|
|
|
|
aArguments[2] = beans::PropertyValue( C2U("HasCategories")
|
|
|
|
, -1, uno::makeAny( bHasCategories )
|
|
|
|
, beans::PropertyState_DIRECT_VALUE );
|
|
|
|
|
|
|
|
return aArguments;
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Sequence< beans::PropertyValue > DataSourceHelper::createArguments(
|
|
|
|
const ::rtl::OUString & rRangeRepresentation,
|
|
|
|
const uno::Sequence< sal_Int32 >& rSequenceMapping,
|
|
|
|
bool bUseColumns, bool bFirstCellAsLabel, bool bHasCategories )
|
|
|
|
{
|
|
|
|
uno::Sequence< beans::PropertyValue > aArguments( createArguments( bUseColumns, bFirstCellAsLabel, bHasCategories ));
|
|
|
|
aArguments.realloc( aArguments.getLength() + 1 );
|
|
|
|
aArguments[aArguments.getLength() - 1] =
|
|
|
|
beans::PropertyValue( C2U("CellRangeRepresentation")
|
|
|
|
, -1, uno::makeAny( rRangeRepresentation )
|
|
|
|
, beans::PropertyState_DIRECT_VALUE );
|
|
|
|
if( rSequenceMapping.getLength() )
|
|
|
|
{
|
|
|
|
aArguments.realloc( aArguments.getLength() + 1 );
|
|
|
|
aArguments[aArguments.getLength() - 1] =
|
|
|
|
beans::PropertyValue( C2U("SequenceMapping")
|
|
|
|
, -1, uno::makeAny( rSequenceMapping )
|
|
|
|
, beans::PropertyState_DIRECT_VALUE );
|
|
|
|
}
|
|
|
|
return aArguments;
|
|
|
|
}
|
|
|
|
|
|
|
|
void DataSourceHelper::readArguments( const uno::Sequence< beans::PropertyValue >& rArguments
|
|
|
|
, ::rtl::OUString & rRangeRepresentation, uno::Sequence< sal_Int32 >& rSequenceMapping
|
|
|
|
, bool& bUseColumns, bool& bFirstCellAsLabel, bool& bHasCategories )
|
|
|
|
{
|
|
|
|
const beans::PropertyValue* pArguments = rArguments.getConstArray();
|
|
|
|
for(sal_Int32 i=0; i<rArguments.getLength(); ++i, ++pArguments)
|
|
|
|
{
|
|
|
|
const beans::PropertyValue& aProperty = *pArguments;
|
|
|
|
if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "DataRowSource" ) ))
|
|
|
|
{
|
|
|
|
::com::sun::star::chart::ChartDataRowSource eRowSource;
|
|
|
|
if( aProperty.Value >>= eRowSource )
|
|
|
|
bUseColumns = (eRowSource==::com::sun::star::chart::ChartDataRowSource_COLUMNS);
|
|
|
|
}
|
|
|
|
else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "FirstCellAsLabel" ) ))
|
|
|
|
{
|
|
|
|
aProperty.Value >>= bFirstCellAsLabel;
|
|
|
|
}
|
|
|
|
else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "HasCategories" ) ))
|
|
|
|
{
|
|
|
|
aProperty.Value >>= bHasCategories;
|
|
|
|
}
|
|
|
|
else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "CellRangeRepresentation" ) ))
|
|
|
|
{
|
|
|
|
aProperty.Value >>= rRangeRepresentation;
|
|
|
|
}
|
|
|
|
else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "SequenceMapping" ) ))
|
|
|
|
{
|
|
|
|
aProperty.Value >>= rSequenceMapping;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Reference< chart2::data::XDataSource > DataSourceHelper::pressUsedDataIntoRectangularFormat(
|
|
|
|
const uno::Reference< chart2::XChartDocument >& xChartDoc, bool bWithCategories )
|
|
|
|
{
|
|
|
|
::std::vector< Reference< chart2::data::XLabeledDataSequence > > aResultVector;
|
|
|
|
|
|
|
|
//categories are always the first sequence
|
|
|
|
Reference< chart2::XDiagram > xDiagram( xChartDoc->getFirstDiagram());
|
|
|
|
|
|
|
|
if( bWithCategories )
|
|
|
|
{
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ) );
|
|
|
|
if( xCategories.is() )
|
|
|
|
aResultVector.push_back( xCategories );
|
|
|
|
}
|
|
|
|
|
|
|
|
::std::vector< Reference< chart2::XDataSeries > > xSeriesVector( DiagramHelper::getDataSeriesFromDiagram( xDiagram ) );
|
|
|
|
uno::Reference< chart2::data::XDataSource > xSeriesSource(
|
|
|
|
DataSeriesHelper::getDataSource( ContainerHelper::ContainerToSequence(xSeriesVector) ) );
|
|
|
|
Sequence< Reference< chart2::data::XLabeledDataSequence > > aDataSeqences( xSeriesSource->getDataSequences() );
|
|
|
|
|
|
|
|
//the first x-values is always the next sequence //todo ... other x-values get lost for old format
|
|
|
|
Reference< chart2::data::XLabeledDataSequence > xXValues(
|
|
|
|
DataSeriesHelper::getDataSequenceByRole( xSeriesSource, C2U("values-x") ) );
|
|
|
|
if( xXValues.is() )
|
|
|
|
aResultVector.push_back( xXValues );
|
|
|
|
|
|
|
|
//add all other sequences now without x-values
|
|
|
|
for( sal_Int32 nN=0; nN<aDataSeqences.getLength(); nN++ )
|
|
|
|
{
|
|
|
|
OUString aRole( DataSeriesHelper::GetRole( aDataSeqences[nN] ) );
|
|
|
|
if( !aRole.equals(C2U("values-x")) )
|
|
|
|
aResultVector.push_back( aDataSeqences[nN] );
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< Reference< chart2::data::XLabeledDataSequence > > aResultSequence( aResultVector.size() );
|
|
|
|
::std::copy( aResultVector.begin(), aResultVector.end(), aResultSequence.getArray() );
|
|
|
|
|
|
|
|
return new DataSource( aResultSequence );
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Sequence< ::rtl::OUString > DataSourceHelper::getUsedDataRanges(
|
|
|
|
const uno::Reference< chart2::XDiagram > & xDiagram )
|
|
|
|
{
|
|
|
|
::std::vector< ::rtl::OUString > aResult;
|
|
|
|
|
|
|
|
if( xDiagram.is())
|
|
|
|
{
|
|
|
|
uno::Reference< data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ) );
|
|
|
|
if( xCategories.is() )
|
|
|
|
lcl_addRanges( aResult, xCategories );
|
|
|
|
|
|
|
|
::std::vector< uno::Reference< XDataSeries > > aSeriesVector( DiagramHelper::getDataSeriesFromDiagram( xDiagram ) );
|
|
|
|
for( ::std::vector< uno::Reference< XDataSeries > >::const_iterator aSeriesIt( aSeriesVector.begin() )
|
|
|
|
; aSeriesIt != aSeriesVector.end(); ++aSeriesIt )
|
|
|
|
{
|
|
|
|
uno::Reference< data::XDataSource > xDataSource( *aSeriesIt, uno::UNO_QUERY );
|
2008-03-06 10:33:21 -06:00
|
|
|
lcl_addDataSourceRanges( aResult, xDataSource );
|
|
|
|
lcl_addErrorBarRanges( aResult, *aSeriesIt );
|
2007-05-22 12:58:02 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ContainerHelper::ContainerToSequence( aResult );
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Sequence< ::rtl::OUString > DataSourceHelper::getUsedDataRanges( const uno::Reference< frame::XModel > & xChartModel )
|
|
|
|
{
|
|
|
|
uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartModel ) );
|
|
|
|
return getUsedDataRanges( xDiagram );
|
|
|
|
}
|
|
|
|
|
|
|
|
uno::Reference< chart2::data::XDataSource > DataSourceHelper::getUsedData(
|
2009-11-24 04:19:08 -06:00
|
|
|
const uno::Reference< chart2::XChartDocument >& xChartDoc )
|
2007-05-22 12:58:02 -05:00
|
|
|
{
|
2009-11-24 04:19:08 -06:00
|
|
|
return pressUsedDataIntoRectangularFormat( xChartDoc );
|
2007-05-22 12:58:02 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
uno::Reference< chart2::data::XDataSource > DataSourceHelper::getUsedData(
|
2009-11-24 04:19:08 -06:00
|
|
|
const uno::Reference< frame::XModel >& xChartModel )
|
2007-05-22 12:58:02 -05:00
|
|
|
{
|
|
|
|
::std::vector< uno::Reference< chart2::data::XLabeledDataSequence > > aResult;
|
|
|
|
|
|
|
|
uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartModel ) );
|
|
|
|
uno::Reference< data::XLabeledDataSequence > xCategories( DiagramHelper::getCategoriesFromDiagram( xDiagram ) );
|
|
|
|
if( xCategories.is() )
|
|
|
|
aResult.push_back( xCategories );
|
|
|
|
|
|
|
|
::std::vector< uno::Reference< XDataSeries > > aSeriesVector( ChartModelHelper::getDataSeries( xChartModel ) );
|
|
|
|
for( ::std::vector< uno::Reference< XDataSeries > >::const_iterator aSeriesIt( aSeriesVector.begin() )
|
|
|
|
; aSeriesIt != aSeriesVector.end(); ++aSeriesIt )
|
|
|
|
{
|
|
|
|
uno::Reference< data::XDataSource > xDataSource( *aSeriesIt, uno::UNO_QUERY );
|
|
|
|
if( !xDataSource.is() )
|
|
|
|
continue;
|
|
|
|
uno::Sequence< uno::Reference< data::XLabeledDataSequence > > aDataSequences( xDataSource->getDataSequences() );
|
|
|
|
::std::copy( aDataSequences.getConstArray(), aDataSequences.getConstArray() + aDataSequences.getLength(),
|
|
|
|
::std::back_inserter( aResult ));
|
|
|
|
}
|
|
|
|
|
|
|
|
return uno::Reference< chart2::data::XDataSource >(
|
|
|
|
new DataSource( ContainerHelper::ContainerToSequence( aResult )));
|
|
|
|
}
|
|
|
|
|
|
|
|
bool DataSourceHelper::detectRangeSegmentation(
|
|
|
|
const uno::Reference<
|
|
|
|
frame::XModel >& xChartModel
|
|
|
|
, ::rtl::OUString& rOutRangeString
|
|
|
|
, ::com::sun::star::uno::Sequence< sal_Int32 >& rSequenceMapping
|
|
|
|
, bool& rOutUseColumns
|
|
|
|
, bool& rOutFirstCellAsLabel
|
2009-11-24 04:19:08 -06:00
|
|
|
, bool& rOutHasCategories )
|
2007-05-22 12:58:02 -05:00
|
|
|
{
|
|
|
|
bool bSomethingDetected = false;
|
|
|
|
|
|
|
|
uno::Reference< XChartDocument > xChartDocument( xChartModel, uno::UNO_QUERY );
|
|
|
|
if( !xChartDocument.is() )
|
|
|
|
return bSomethingDetected;
|
|
|
|
uno::Reference< data::XDataProvider > xDataProvider( xChartDocument->getDataProvider() );
|
|
|
|
if( !xDataProvider.is() )
|
|
|
|
return bSomethingDetected;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
DataSourceHelper::readArguments(
|
|
|
|
xDataProvider->detectArguments( pressUsedDataIntoRectangularFormat( xChartDocument ) ),
|
|
|
|
rOutRangeString, rSequenceMapping, rOutUseColumns, rOutFirstCellAsLabel, rOutHasCategories );
|
|
|
|
bSomethingDetected = (rOutRangeString.getLength() > 0);
|
|
|
|
|
|
|
|
uno::Reference< chart2::data::XLabeledDataSequence > xCategories(
|
|
|
|
DiagramHelper::getCategoriesFromDiagram( xChartDocument->getFirstDiagram() ));
|
|
|
|
rOutHasCategories = xCategories.is();
|
|
|
|
}
|
|
|
|
catch( uno::Exception & ex )
|
|
|
|
{
|
|
|
|
ASSERT_EXCEPTION( ex );
|
|
|
|
}
|
|
|
|
return bSomethingDetected;
|
|
|
|
}
|
|
|
|
|
|
|
|
bool DataSourceHelper::allArgumentsForRectRangeDetected(
|
|
|
|
const uno::Reference< chart2::XChartDocument >& xChartDocument )
|
|
|
|
{
|
|
|
|
bool bHasDataRowSource = false;
|
|
|
|
bool bHasFirstCellAsLabel = false;
|
|
|
|
// bool bHasHasCategories = false;
|
|
|
|
bool bHasCellRangeRepresentation = false;
|
|
|
|
// bool bHasSequenceMapping = false;
|
|
|
|
|
|
|
|
uno::Reference< data::XDataProvider > xDataProvider( xChartDocument->getDataProvider() );
|
|
|
|
if( !xDataProvider.is() )
|
|
|
|
return false;
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
const uno::Sequence< beans::PropertyValue > aArguments(
|
|
|
|
xDataProvider->detectArguments( pressUsedDataIntoRectangularFormat( xChartDocument )));
|
|
|
|
const beans::PropertyValue* pArguments = aArguments.getConstArray();
|
|
|
|
for(sal_Int32 i=0; i<aArguments.getLength(); ++i, ++pArguments)
|
|
|
|
{
|
|
|
|
const beans::PropertyValue& aProperty = *pArguments;
|
|
|
|
if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "DataRowSource" ) ))
|
|
|
|
{
|
|
|
|
bHasDataRowSource =
|
|
|
|
(aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(
|
|
|
|
::getCppuType( reinterpret_cast<
|
|
|
|
const ::com::sun::star::chart::ChartDataRowSource * >(0))));
|
|
|
|
}
|
|
|
|
else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "FirstCellAsLabel" ) ))
|
|
|
|
{
|
|
|
|
bHasFirstCellAsLabel =
|
|
|
|
(aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(::getBooleanCppuType()));
|
|
|
|
}
|
|
|
|
// else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "HasCategories" ) ))
|
|
|
|
// {
|
|
|
|
// bHasHasCategories =
|
|
|
|
// (aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(::getBooleanCppuType()));
|
|
|
|
// }
|
|
|
|
else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "CellRangeRepresentation" ) ))
|
|
|
|
{
|
|
|
|
::rtl::OUString aRange;
|
|
|
|
bHasCellRangeRepresentation =
|
|
|
|
(aProperty.Value.hasValue() && (aProperty.Value >>= aRange) && aRange.getLength() > 0);
|
|
|
|
}
|
|
|
|
// else if( aProperty.Name.equalsAsciiL( RTL_CONSTASCII_STRINGPARAM( "SequenceMapping" ) ))
|
|
|
|
// {
|
|
|
|
// bHasSequenceMapping =
|
|
|
|
// (aProperty.Value.hasValue() && aProperty.Value.isExtractableTo(
|
|
|
|
// ::getCppuType( reinterpret_cast<
|
|
|
|
// const uno::Sequence< sal_Int32 > * >(0))));
|
|
|
|
// }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch( const uno::Exception & ex )
|
|
|
|
{
|
|
|
|
ASSERT_EXCEPTION( ex );
|
|
|
|
}
|
|
|
|
|
|
|
|
return (bHasCellRangeRepresentation && bHasDataRowSource && bHasFirstCellAsLabel);
|
|
|
|
}
|
|
|
|
|
|
|
|
void DataSourceHelper::setRangeSegmentation(
|
|
|
|
const uno::Reference< frame::XModel >& xChartModel
|
|
|
|
, const ::com::sun::star::uno::Sequence< sal_Int32 >& rSequenceMapping
|
|
|
|
, bool bUseColumns , bool bFirstCellAsLabel, bool bUseCategories )
|
|
|
|
{
|
|
|
|
uno::Reference< XChartDocument > xChartDocument( xChartModel, uno::UNO_QUERY );
|
|
|
|
if( !xChartDocument.is() )
|
|
|
|
return;
|
|
|
|
uno::Reference< data::XDataProvider > xDataProvider( xChartDocument->getDataProvider() );
|
|
|
|
if( !xDataProvider.is() )
|
|
|
|
return;
|
|
|
|
uno::Reference< XDiagram > xDiagram( ChartModelHelper::findDiagram( xChartModel ) );
|
|
|
|
if( !xDiagram.is() )
|
|
|
|
return;
|
|
|
|
uno::Reference< chart2::XChartTypeManager > xChartTypeManager( xChartDocument->getChartTypeManager() );
|
|
|
|
if( !xChartTypeManager.is() )
|
|
|
|
return;
|
|
|
|
uno::Reference< lang::XMultiServiceFactory > xTemplateFactory( xChartTypeManager, uno::UNO_QUERY );
|
|
|
|
if( !xTemplateFactory.is() )
|
|
|
|
return;
|
|
|
|
|
|
|
|
::rtl::OUString aRangeString;
|
|
|
|
bool bDummy;
|
|
|
|
uno::Sequence< sal_Int32 > aDummy;
|
|
|
|
readArguments( xDataProvider->detectArguments( pressUsedDataIntoRectangularFormat( xChartDocument )),
|
|
|
|
aRangeString, aDummy, bDummy, bDummy, bDummy );
|
|
|
|
|
|
|
|
uno::Sequence< beans::PropertyValue > aArguments(
|
|
|
|
createArguments( aRangeString, rSequenceMapping, bUseColumns, bFirstCellAsLabel, bUseCategories ) );
|
|
|
|
|
|
|
|
uno::Reference< chart2::data::XDataSource > xDataSource( xDataProvider->createDataSource(
|
|
|
|
aArguments ) );
|
|
|
|
if( !xDataSource.is() )
|
|
|
|
return;
|
|
|
|
|
|
|
|
DiagramHelper::tTemplateWithServiceName aTemplateAndService =
|
|
|
|
DiagramHelper::getTemplateForDiagram( xDiagram, xTemplateFactory );
|
|
|
|
|
|
|
|
rtl::OUString aServiceName( aTemplateAndService.second );
|
|
|
|
uno::Reference< chart2::XChartTypeTemplate > xTemplate = aTemplateAndService.first;
|
|
|
|
|
|
|
|
if( !xTemplate.is() )
|
|
|
|
{
|
|
|
|
if( aServiceName.getLength() == 0 )
|
|
|
|
aServiceName = C2U("com.sun.star.chart2.template.Column");
|
|
|
|
xTemplate.set( xTemplateFactory->createInstance( aServiceName ), uno::UNO_QUERY );
|
|
|
|
}
|
|
|
|
if( !xTemplate.is() )
|
|
|
|
return;
|
|
|
|
|
|
|
|
// /-- locked controllers
|
|
|
|
ControllerLockGuard aCtrlLockGuard( xChartModel );
|
|
|
|
xTemplate->changeDiagramData( xDiagram, xDataSource, aArguments );
|
|
|
|
// \-- locked controllers
|
|
|
|
}
|
|
|
|
|
|
|
|
Sequence< OUString > DataSourceHelper::getRangesFromLabeledDataSequence(
|
|
|
|
const Reference< data::XLabeledDataSequence > & xLSeq )
|
|
|
|
{
|
|
|
|
Sequence< OUString > aResult;
|
|
|
|
if( xLSeq.is())
|
|
|
|
{
|
|
|
|
Reference< data::XDataSequence > xLabel( xLSeq->getLabel());
|
|
|
|
Reference< data::XDataSequence > xValues( xLSeq->getValues());
|
|
|
|
|
|
|
|
if( xLabel.is())
|
|
|
|
{
|
|
|
|
if( xValues.is())
|
|
|
|
{
|
|
|
|
aResult.realloc( 2 );
|
|
|
|
aResult[0] = xLabel->getSourceRangeRepresentation();
|
|
|
|
aResult[1] = xValues->getSourceRangeRepresentation();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
aResult.realloc( 1 );
|
|
|
|
aResult[0] = xLabel->getSourceRangeRepresentation();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if( xValues.is())
|
|
|
|
{
|
|
|
|
aResult.realloc( 1 );
|
|
|
|
aResult[0] = xValues->getSourceRangeRepresentation();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return aResult;
|
|
|
|
}
|
|
|
|
|
2009-12-01 08:01:55 -06:00
|
|
|
OUString DataSourceHelper::getRangeFromValues(
|
|
|
|
const Reference< data::XLabeledDataSequence > & xLSeq )
|
|
|
|
{
|
|
|
|
OUString aResult;
|
|
|
|
if( xLSeq.is() )
|
|
|
|
{
|
|
|
|
Reference< data::XDataSequence > xValues( xLSeq->getValues() );
|
|
|
|
if( xValues.is() )
|
|
|
|
aResult = xValues->getSourceRangeRepresentation();
|
|
|
|
}
|
|
|
|
return aResult;
|
|
|
|
}
|
|
|
|
|
2007-05-22 12:58:02 -05:00
|
|
|
Sequence< OUString > DataSourceHelper::getRangesFromDataSource( const Reference< data::XDataSource > & xSource )
|
|
|
|
{
|
|
|
|
::std::vector< OUString > aResult;
|
|
|
|
if( xSource.is())
|
|
|
|
{
|
|
|
|
Sequence< Reference< data::XLabeledDataSequence > > aLSeqSeq( xSource->getDataSequences());
|
|
|
|
for( sal_Int32 i=0; i<aLSeqSeq.getLength(); ++i )
|
|
|
|
{
|
|
|
|
Reference< data::XDataSequence > xLabel( aLSeqSeq[i]->getLabel());
|
|
|
|
Reference< data::XDataSequence > xValues( aLSeqSeq[i]->getValues());
|
|
|
|
|
|
|
|
if( xLabel.is())
|
|
|
|
aResult.push_back( xLabel->getSourceRangeRepresentation());
|
|
|
|
if( xValues.is())
|
|
|
|
aResult.push_back( xValues->getSourceRangeRepresentation());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ContainerHelper::ContainerToSequence( aResult );
|
|
|
|
}
|
|
|
|
|
|
|
|
//.............................................................................
|
|
|
|
} //namespace chart
|
|
|
|
//.............................................................................
|