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