1 /**************************************************************
2  *
3  * Licensed to the Apache Software Foundation (ASF) under one
4  * or more contributor license agreements.  See the NOTICE file
5  * distributed with this work for additional information
6  * regarding copyright ownership.  The ASF licenses this file
7  * to you under the Apache License, Version 2.0 (the
8  * "License"); you may not use this file except in compliance
9  * with the License.  You may obtain a copy of the License at
10  *
11  *   http://www.apache.org/licenses/LICENSE-2.0
12  *
13  * Unless required by applicable law or agreed to in writing,
14  * software distributed under the License is distributed on an
15  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16  * KIND, either express or implied.  See the License for the
17  * specific language governing permissions and limitations
18  * under the License.
19  *
20  *************************************************************/
21 
22 
23 
24 // MARKER(update_precomp.py): autogen include statement, do not remove
25 #include "precompiled_chart2.hxx"
26 #include "VPolarAxis.hxx"
27 #include "VPolarAngleAxis.hxx"
28 #include "VPolarRadiusAxis.hxx"
29 #include "macros.hxx"
30 #include "Tickmarks.hxx"
31 #include "ShapeFactory.hxx"
32 
33 #include <memory>
34 
35 //.............................................................................
36 namespace chart
37 {
38 //.............................................................................
39 using namespace ::com::sun::star;
40 using namespace ::com::sun::star::chart2;
41 
createAxis(const AxisProperties & rAxisProperties,const uno::Reference<util::XNumberFormatsSupplier> & xNumberFormatsSupplier,sal_Int32 nDimensionIndex,sal_Int32 nDimensionCount)42 VPolarAxis* VPolarAxis::createAxis( const AxisProperties& rAxisProperties
43            , const uno::Reference< util::XNumberFormatsSupplier >& xNumberFormatsSupplier
44            , sal_Int32 nDimensionIndex, sal_Int32 nDimensionCount )
45 {
46     if( 0==nDimensionIndex )
47         return new VPolarAngleAxis( rAxisProperties, xNumberFormatsSupplier, nDimensionCount );
48     return new VPolarRadiusAxis( rAxisProperties, xNumberFormatsSupplier, nDimensionCount );
49 }
50 
VPolarAxis(const AxisProperties & rAxisProperties,const uno::Reference<util::XNumberFormatsSupplier> & xNumberFormatsSupplier,sal_Int32 nDimensionIndex,sal_Int32 nDimensionCount)51 VPolarAxis::VPolarAxis( const AxisProperties& rAxisProperties
52             , const uno::Reference< util::XNumberFormatsSupplier >& xNumberFormatsSupplier
53             , sal_Int32 nDimensionIndex, sal_Int32 nDimensionCount )
54             : VAxisBase( nDimensionIndex, nDimensionCount, rAxisProperties, xNumberFormatsSupplier )
55             , m_pPosHelper( new PolarPlottingPositionHelper() )
56             , m_aIncrements()
57 {
58     PlotterBase::m_pPosHelper = m_pPosHelper;
59 }
60 
~VPolarAxis()61 VPolarAxis::~VPolarAxis()
62 {
63     delete m_pPosHelper;
64     m_pPosHelper = NULL;
65 }
66 
setIncrements(const std::vector<ExplicitIncrementData> & rIncrements)67 void VPolarAxis::setIncrements( const std::vector< ExplicitIncrementData >& rIncrements )
68 {
69     m_aIncrements = rIncrements;
70 }
71 
isAnythingToDraw()72 sal_Bool VPolarAxis::isAnythingToDraw()
73 {
74     return ( 2==m_nDimension && VAxisBase::isAnythingToDraw() );
75 }
76 
77 //.............................................................................
78 } //namespace chart
79 //.............................................................................
80