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#ifndef com_sun_star_chart2_XDataInterpreter_idl 28*cdf0e10cSrcweir#define com_sun_star_chart2_XDataInterpreter_idl 29*cdf0e10cSrcweir 30*cdf0e10cSrcweir#ifndef __com_sun_star_uno_XInterface_idl__ 31*cdf0e10cSrcweir#include <com/sun/star/uno/XInterface.idl> 32*cdf0e10cSrcweir#endif 33*cdf0e10cSrcweir#ifndef __com_sun_star_beans_PropertyValue_idl__ 34*cdf0e10cSrcweir#include <com/sun/star/beans/PropertyValue.idl> 35*cdf0e10cSrcweir#endif 36*cdf0e10cSrcweir 37*cdf0e10cSrcweir#include <com/sun/star/chart2/InterpretedData.idl> 38*cdf0e10cSrcweir#include <com/sun/star/chart2/data/XDataSource.idl> 39*cdf0e10cSrcweir#include <com/sun/star/chart2/XDataSeries.idl> 40*cdf0e10cSrcweir 41*cdf0e10cSrcweirmodule com 42*cdf0e10cSrcweir{ 43*cdf0e10cSrcweirmodule sun 44*cdf0e10cSrcweir{ 45*cdf0e10cSrcweirmodule star 46*cdf0e10cSrcweir{ 47*cdf0e10cSrcweirmodule chart2 48*cdf0e10cSrcweir{ 49*cdf0e10cSrcweir 50*cdf0e10cSrcweir/** offers tooling to interpret different data sources in a structural 51*cdf0e10cSrcweir and chart-type-dependent way. 52*cdf0e10cSrcweir */ 53*cdf0e10cSrcweirinterface XDataInterpreter : ::com::sun::star::uno::XInterface 54*cdf0e10cSrcweir{ 55*cdf0e10cSrcweir /** Interprets the given data. 56*cdf0e10cSrcweir 57*cdf0e10cSrcweir @param aArguments 58*cdf0e10cSrcweir Arguments that tell the template how to slice the given 59*cdf0e10cSrcweir range. The properties should be defined in a separate 60*cdf0e10cSrcweir service. 61*cdf0e10cSrcweir 62*cdf0e10cSrcweir <p>For standard parameters that may be used, see the 63*cdf0e10cSrcweir service <type>StandardDiagramCreationParameters</type>. 64*cdf0e10cSrcweir </p> 65*cdf0e10cSrcweir 66*cdf0e10cSrcweir @param aSeriesToReUse 67*cdf0e10cSrcweir use all the data series given here for the result before 68*cdf0e10cSrcweir creating new ones. 69*cdf0e10cSrcweir */ 70*cdf0e10cSrcweir InterpretedData interpretDataSource( 71*cdf0e10cSrcweir [in] data::XDataSource xSource, 72*cdf0e10cSrcweir [in] sequence< com::sun::star::beans::PropertyValue > aArguments, 73*cdf0e10cSrcweir [in] sequence< XDataSeries > aSeriesToReUse ); 74*cdf0e10cSrcweir 75*cdf0e10cSrcweir /** Re-interprets the data given in <code>aInterpretedData</code> 76*cdf0e10cSrcweir while keeping the number of data series and the categories. 77*cdf0e10cSrcweir */ 78*cdf0e10cSrcweir InterpretedData reinterpretDataSeries( [in] InterpretedData aInterpretedData ); 79*cdf0e10cSrcweir 80*cdf0e10cSrcweir /** parses the given data and states, if a 81*cdf0e10cSrcweir <member>reinterpretDataSeries</member> call can be done 82*cdf0e10cSrcweir without data loss. 83*cdf0e10cSrcweir 84*cdf0e10cSrcweir @return 85*cdf0e10cSrcweir <TRUE/>, if the data given in 86*cdf0e10cSrcweir <code>aInterpretedData</code> has a similar structure than 87*cdf0e10cSrcweir the one required is used as output of the data interpreter. 88*cdf0e10cSrcweir */ 89*cdf0e10cSrcweir boolean isDataCompatible( [in] InterpretedData aInterpretedData ); 90*cdf0e10cSrcweir 91*cdf0e10cSrcweir /** Try to reverse the operation done in 92*cdf0e10cSrcweir <member>interpretDataSource</member>. 93*cdf0e10cSrcweir 94*cdf0e10cSrcweir <p>In case <code>aInterpretedData</code> is the result of 95*cdf0e10cSrcweir <member>interpretDataSource</member>( <code>xSource</code> ), 96*cdf0e10cSrcweir the result of this method should be <code>xSource</code>.</p> 97*cdf0e10cSrcweir */ 98*cdf0e10cSrcweir data::XDataSource mergeInterpretedData( [in] InterpretedData aInterpretedData ); 99*cdf0e10cSrcweir}; 100*cdf0e10cSrcweir 101*cdf0e10cSrcweir} ; // chart2 102*cdf0e10cSrcweir} ; // com 103*cdf0e10cSrcweir} ; // sun 104*cdf0e10cSrcweir} ; // star 105*cdf0e10cSrcweir 106*cdf0e10cSrcweir 107*cdf0e10cSrcweir#endif 108