|  | /************************************************************** | 
|  | * | 
|  | * Licensed to the Apache Software Foundation (ASF) under one | 
|  | * or more contributor license agreements.  See the NOTICE file | 
|  | * distributed with this work for additional information | 
|  | * regarding copyright ownership.  The ASF licenses this file | 
|  | * to you under the Apache License, Version 2.0 (the | 
|  | * "License"); you may not use this file except in compliance | 
|  | * with the License.  You may obtain a copy of the License at | 
|  | * | 
|  | *   http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, | 
|  | * software distributed under the License is distributed on an | 
|  | * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
|  | * KIND, either express or implied.  See the License for the | 
|  | * specific language governing permissions and limitations | 
|  | * under the License. | 
|  | * | 
|  | *************************************************************/ | 
|  |  | 
|  |  | 
|  | #ifndef CHART2_DIAGRAMHELPER_HXX | 
|  | #define CHART2_DIAGRAMHELPER_HXX | 
|  |  | 
|  | #include "StackMode.hxx" | 
|  | #include "charttoolsdllapi.hxx" | 
|  | #include <com/sun/star/chart2/XAxis.hpp> | 
|  | #include <com/sun/star/chart2/XDiagram.hpp> | 
|  | #include <com/sun/star/chart2/XChartTypeTemplate.hpp> | 
|  | #include <com/sun/star/chart2/XCoordinateSystem.hpp> | 
|  | #include <com/sun/star/chart2/InterpretedData.hpp> | 
|  | #include <com/sun/star/chart2/StackingDirection.hpp> | 
|  | #include <com/sun/star/chart2/XChartDocument.hpp> | 
|  | #include <com/sun/star/lang/XMultiServiceFactory.hpp> | 
|  | #include <com/sun/star/uno/XComponentContext.hpp> | 
|  | #include <com/sun/star/util/XNumberFormats.hpp> | 
|  | #include <com/sun/star/util/XNumberFormatsSupplier.hpp> | 
|  |  | 
|  | #include <utility> | 
|  | #include <vector> | 
|  |  | 
|  |  | 
|  | namespace chart | 
|  | { | 
|  |  | 
|  | enum DiagramPositioningMode | 
|  | { | 
|  | DiagramPositioningMode_AUTO, | 
|  | DiagramPositioningMode_EXCLUDING, | 
|  | DiagramPositioningMode_INCLUDING | 
|  | }; | 
|  |  | 
|  | class OOO_DLLPUBLIC_CHARTTOOLS DiagramHelper | 
|  | { | 
|  | public: | 
|  | typedef ::std::pair< | 
|  | ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartTypeTemplate >, | 
|  | ::rtl::OUString > | 
|  | tTemplateWithServiceName; | 
|  |  | 
|  | /** tries to find a template in the chart-type manager that matches the | 
|  | given diagram. | 
|  |  | 
|  | @param rPreferredTemplateName | 
|  | Check this template first.  This may speed up searching, if the | 
|  | caller assumes a certain template as most likely to be the one that | 
|  | matches. | 
|  |  | 
|  | @return | 
|  | A pair containing a template with the correct properties set as | 
|  | first entry and the service name of the templateas second entry.  If | 
|  | no template was found both elements are empty. | 
|  | */ | 
|  | static tTemplateWithServiceName | 
|  | getTemplateForDiagram( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::lang::XMultiServiceFactory > & xChartTypeManager, | 
|  | const ::rtl::OUString & rPreferredTemplateName = ::rtl::OUString()); | 
|  |  | 
|  | /** Sets the "SwapXAndYAxis" property at all coordinate systems found in the | 
|  | given diagram. | 
|  |  | 
|  | "vertical==true" for bar charts, "vertical==false" for column charts | 
|  | */ | 
|  | static void setVertical( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | bool bVertical = true ); | 
|  |  | 
|  | /** Gets the "SwapXAndYAxis" property at all coordinate systems found in the | 
|  | given diagram. | 
|  |  | 
|  | "vertical==true" for bar charts, "vertical==false" for column charts | 
|  | */ | 
|  | static bool getVertical( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | bool& rbOutFoundResult, bool& rbOutAmbiguousResult ); | 
|  |  | 
|  | static StackMode getStackMode( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | bool& rbFound, bool& rbAmbiguous | 
|  | ); | 
|  |  | 
|  | /** @param bOnlyAtFirstChartType | 
|  | If </sal_True>, the stacking mode is only set at the series found inside | 
|  | the first chart type.  This is the standard for all current | 
|  | templates (the only template that has more than one chart-type and | 
|  | allows stacking is bar/line combi, and for this the stacking only | 
|  | applies to the first chart type/the bars) | 
|  | */ | 
|  | static void setStackMode( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | StackMode eStackMode, | 
|  | bool bOnlyAtFirstChartType = true | 
|  | ); | 
|  |  | 
|  | /** Retrieves the stackmode of the first DataSeries or none. If the series have differing stack | 
|  | modes, rbAmbiguous is set to true. If no series is there rbFound is set to false. | 
|  |  | 
|  | @param xCorrespondingCoordinateSystem | 
|  | The coordinate system in which the given chart type xChartType is | 
|  | located.  (This is needed for determining percent stacking.  If | 
|  | omitted, the result will just indicate "not stacked", "stacked" or | 
|  | "ambiguous") | 
|  | */ | 
|  | static StackMode getStackModeFromChartType( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType > & xChartType, | 
|  | bool& rbFound, bool& rbAmbiguous, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XCoordinateSystem > & xCorrespondingCoordinateSystem = | 
|  | ::com::sun::star::uno::Reference< ::com::sun::star::chart2::XCoordinateSystem >() | 
|  | ); | 
|  |  | 
|  | /** Returns the dimension found for all chart types in the tree.  If the | 
|  | dimension is not unique, 0 is returned. | 
|  | */ | 
|  | static sal_Int32 getDimension( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | /** Sets the dimension of the diagram given. | 
|  |  | 
|  | 1. Sets the dimension of all used ChartTypes | 
|  | 2. Adapts the DataSeriesTree to reflect the new dimension | 
|  | 3. If new coordinate-systems have to be created, adapts the | 
|  | XCoordinateSystemContainer of the diagram. | 
|  | */ | 
|  | static void setDimension( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | sal_Int32 nNewDimensionCount ); | 
|  |  | 
|  | /** Replaces all occurrences of xCooSysToReplace in the tree with | 
|  | xReplacement in the diagram's tree | 
|  | */ | 
|  | SAL_DLLPRIVATE static void replaceCoordinateSystem( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XCoordinateSystem > & xCooSysToReplace, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XCoordinateSystem > & xReplacement ); | 
|  |  | 
|  | static bool isSeriesAttachedToMainAxis( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries >& xDataSeries ); | 
|  |  | 
|  | static bool attachSeriesToAxis( bool bMainAxis, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries >& xSeries, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::uno::XComponentContext > & xContext, | 
|  | bool bAdaptAxes=true ); | 
|  |  | 
|  | static ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XAxis > getAttachedAxis( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries >& xSeries, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram ); | 
|  |  | 
|  | static ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType > | 
|  | getChartTypeOfSeries( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries >& xSeries ); | 
|  |  | 
|  | static ::std::vector< | 
|  | ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries > > | 
|  | getDataSeriesFromDiagram( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | /** return all data series in this diagram grouped by chart-types | 
|  | */ | 
|  | static ::com::sun::star::uno::Sequence< | 
|  | ::com::sun::star::uno::Sequence< | 
|  | ::com::sun::star::uno::Reference< ::com::sun::star::chart2::XDataSeries > > > | 
|  | getDataSeriesGroups( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | static bool isCategoryDiagram( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram ); | 
|  |  | 
|  | static void setCategoriesToDiagram( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::data::XLabeledDataSequence >& xCategories, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram, | 
|  | bool bSetAxisType = false, // when this flag is true ... | 
|  | bool bCategoryAxis = true);// set the AxisType to CATEGORY or back to REALNUMBER | 
|  |  | 
|  | static ::com::sun::star::uno::Reference< ::com::sun::star::chart2::data::XLabeledDataSequence > | 
|  | getCategoriesFromDiagram( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | static ::com::sun::star::uno::Sequence< rtl::OUString > | 
|  | getExplicitSimpleCategories( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartDocument > & xChartDoc ); | 
|  |  | 
|  | SAL_DLLPRIVATE static ::com::sun::star::uno::Sequence< rtl::OUString > | 
|  | generateAutomaticCategoriesFromCooSys( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XCoordinateSystem > & xCooSys ); | 
|  |  | 
|  | static void switchToDateCategories( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartDocument > & xChartDoc ); | 
|  |  | 
|  | static void switchToTextCategories( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartDocument > & xChartDoc ); | 
|  |  | 
|  | static bool isSupportingDateAxis( const ::com::sun::star::uno::Reference< ::com::sun::star::chart2::XDiagram >& xDiagram ); | 
|  | static bool isDateNumberFormat( sal_Int32 nNumberFormat, const ::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormats >& xNumberFormats ); | 
|  | static sal_Int32 getDateNumberFormat( const ::com::sun::star::uno::Reference< ::com::sun::star::util::XNumberFormatsSupplier >& xNumberFormatsSupplier ); | 
|  |  | 
|  | static sal_Int32 getPercentNumberFormat( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::util::XNumberFormatsSupplier >& xNumberFormatsSupplier ); | 
|  |  | 
|  | static ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType > | 
|  | getChartTypeByIndex( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram, sal_Int32 nIndex ); | 
|  |  | 
|  | static ::com::sun::star::uno::Sequence< | 
|  | ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType > > | 
|  | getChartTypesFromDiagram( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | SAL_DLLPRIVATE static bool areChartTypesCompatible( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType >& xFirstType, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType >& xSecondType ); | 
|  |  | 
|  |  | 
|  | /** | 
|  | * Test if a series can be moved. | 
|  | * | 
|  | * @param xDiagram | 
|  | *  Reference to the diagram that contains the series. | 
|  | * | 
|  | * @param xGivenDataSeries | 
|  | *  Reference to the series that should be tested for moving. | 
|  | * | 
|  | * @param bForward | 
|  | *  Direction of the move to be checked. | 
|  | * | 
|  | * @returns </sal_True> if the series can be moved. | 
|  | * | 
|  | */ | 
|  | static bool isSeriesMoveable( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries >& xGivenDataSeries, | 
|  | bool bForward ); | 
|  |  | 
|  | /** | 
|  | * Move a series forward or backward. | 
|  | * | 
|  | * @param xDiagram | 
|  | *  Reference to the diagram that contains the series. | 
|  | * | 
|  | * @param xGivenDataSeries | 
|  | *  Reference to the series that should be moved. | 
|  | * | 
|  | * @param bForward | 
|  | *  Direction in which the series should be moved. | 
|  | * | 
|  | * @returns </sal_True> if the series was moved successfully. | 
|  | * | 
|  | */ | 
|  | static bool moveSeries( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDataSeries >& xGivenDataSeries, | 
|  | bool bForward ); | 
|  |  | 
|  | static bool isSupportingFloorAndWall( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | static bool isPieOrDonutChart( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram >& xDiagram ); | 
|  |  | 
|  | static sal_Int32 getGeometry3D( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | bool& rbFound, bool& rbAmbiguous ); | 
|  |  | 
|  | static void setGeometry3D( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | sal_Int32 nNewGeometry ); | 
|  |  | 
|  | //returns integer from constant group ::com::sun::star::chart::MissingValueTreatment | 
|  | static sal_Int32 getCorrectedMissingValueTreatment( | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram, | 
|  | const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XChartType >& xChartType ); | 
|  |  | 
|  | static DiagramPositioningMode getDiagramPositioningMode( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::chart2::XDiagram > & xDiagram ); | 
|  |  | 
|  | static bool setDiagramPositioning( const ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel >& xChartModel, | 
|  | const ::com::sun::star::awt::Rectangle& rPosRect /*100th mm*/ ); | 
|  |  | 
|  | static ::com::sun::star::awt::Rectangle getDiagramRectangleFromModel( const ::com::sun::star::uno::Reference< ::com::sun::star::frame::XModel >& xChartModel ); | 
|  |  | 
|  | static bool switchDiagramPositioningToExcludingPositioning( const ::com::sun::star::uno::Reference< | 
|  | ::com::sun::star::frame::XModel >& xChartModel | 
|  | , bool bResetModifiedState //set model back to unchanged if it was unchanged before | 
|  | , bool bConvertAlsoFromAutoPositioning ); | 
|  |  | 
|  | private: | 
|  | // not implemented | 
|  | DiagramHelper(); | 
|  |  | 
|  | }; | 
|  |  | 
|  | } //  namespace chart | 
|  |  | 
|  | // CHART2_DIAGRAMHELPER_HXX | 
|  | #endif |