1 /*************************************************************************
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
5 * Copyright 2000, 2010 Oracle and/or its affiliates.
7 * OpenOffice.org - a multi-platform office productivity suite
9 * This file is part of OpenOffice.org.
11 * OpenOffice.org is free software: you can redistribute it and/or modify
12 * it under the terms of the GNU Lesser General Public License version 3
13 * only, as published by the Free Software Foundation.
15 * OpenOffice.org is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License version 3 for more details
19 * (a copy is included in the LICENSE file that accompanied this code).
21 * You should have received a copy of the GNU Lesser General Public License
22 * version 3 along with OpenOffice.org. If not, see
23 * <http://www.openoffice.org/license.html>
24 * for a copy of the LGPLv3 License.
26 ************************************************************************/
27 #ifndef __com_sun_star_chart_ChartAxis_idl__
28 #define __com_sun_star_chart_ChartAxis_idl__
30 #ifndef __com_sun_star_drawing_LineProperties_idl__
31 #include
<com
/sun
/star
/drawing
/LineProperties.idl
>
34 #ifndef __com_sun_star_style_CharacterProperties_idl__
35 #include
<com
/sun
/star
/style
/CharacterProperties.idl
>
38 #ifndef __com_sun_star_beans_XPropertySet_idl__
39 #include
<com
/sun
/star
/beans
/XPropertySet.idl
>
42 #ifndef __com_sun_star_chart_ChartAxisArrangeOrderType_idl__
43 #include
<com
/sun
/star
/chart
/ChartAxisArrangeOrderType.idl
>
46 #ifndef __com_sun_star_chart_ChartAxisPosition_idl__
47 #include
<com
/sun
/star
/chart
/ChartAxisPosition.idl
>
50 #ifndef __com_sun_star_chart_ChartAxisLabelPosition_idl__
51 #include
<com
/sun
/star
/chart
/ChartAxisLabelPosition.idl
>
54 #ifndef __com_sun_star_chart_ChartAxisMarkPosition_idl__
55 #include
<com
/sun
/star
/chart
/ChartAxisMarkPosition.idl
>
58 #ifndef _com_sun_star_xml_UserDefinedAttributeSupplier_idl_
59 #include
<com
/sun
/star
/xml
/UserDefinedAttributeSupplier.idl
>
62 //=============================================================================
64 module com
{ module sun
{ module star
{ module chart
{
66 //=============================================================================
68 /** Specifies the axes in a diagram.
70 <p>Note: The text properties correlate to all axis description
71 elements, not to just a single text element.</p>
73 published service ChartAxis
77 /** set the properties for the entire axis line as well as for the
80 service com
::sun
::star
::drawing
::LineProperties
;
82 /** set the properties for all text labels of the axis
84 service com
::sun
::star
::style
::CharacterProperties
;
86 /** If a <type>ChartAxis</type> may be stored as XML element, this
87 service should be supported in order to preserve unparsed XML
92 [optional] service com
::sun
::star
::xml
::UserDefinedAttributeSupplier
;
94 interface com
::sun
::star
::beans
::XPropertySet
;
96 //-------------------------------------------------------------------------
97 /** Properties for scaling:
100 //-------------------------------------------------------------------------
102 /** Contains the maximum value for the axis scale.
104 [optional, property
] double Max
;
106 //-------------------------------------------------------------------------
108 /** Contains the minimum value for the axis scale.
110 [optional, property
] double Min
;
112 //-------------------------------------------------------------------------
114 /** Contains the distance between the main tick marks.
116 [optional, property
] double StepMain
;
118 //-------------------------------------------------------------------------
121 Contains the number of help intervals within a main interval. E.g. a StepHelpCount of 5 divides
122 the main interval into 5 pieces and thus producces 4 help tick marks.
124 [optional, property
] long StepHelpCount
;
126 //-------------------------------------------------------------------------
129 User property StepHelpCount instead
130 Contains the distance between the help tick marks.
132 [optional, property
] double StepHelp
;
134 //-------------------------------------------------------------------------
136 /** The maximium value of the axis scale is calculated by the chart if
137 this property is <TRUE/>.
139 [optional, property
] boolean AutoMax
;
141 //-------------------------------------------------------------------------
143 /** The minimum value of the axis scale is calculated by the chart if
144 this property is <TRUE/>.
146 [optional, property
] boolean AutoMin
;
148 //-------------------------------------------------------------------------
150 /** The distance between the main tick marks is calculated by the chart
151 if this property is <TRUE/>.
153 [optional, property
] boolean AutoStepMain
;
155 //-------------------------------------------------------------------------
157 /** The number of help intervals within a main interval is calculated by the
158 chart if this property is <TRUE/>.
160 [optional, property
] boolean AutoStepHelp
;
163 //-------------------------------------------------------------------------
165 /** Determines if the axis is scaled logarithmically or
168 [optional, property
] boolean Logarithmic
;
170 //-------------------------------------------------------------------------
172 /** Determines if the axis orientation is mathematical or reversed.
174 [optional, property
] boolean ReverseDirection
;
176 //-------------------------------------------------------------------------
178 /** Determines where the axis crosses the other axis.
180 [optional, property
] com
::sun
::star
::chart
::ChartAxisPosition CrossoverPosition
;
182 //-------------------------------------------------------------------------
184 /** Determines the scale value on the other axis when CrossoverPosition is set to VALUE.
186 [optional, property
] double CrossoverValue
;
188 //-------------------------------------------------------------------------
190 /** Indicates the reference value where bars or areas have their grounding.
191 This property has only an effect when the used odf fileformat does not allow for
192 further axis posiioning or the axis is a secondary y-axis.
194 [optional, property
] double Origin
;
196 //-------------------------------------------------------------------------
198 /** The origin is calculated by the chart if this property is <TRUE/>.
200 [optional, property
] boolean AutoOrigin
;
202 //-------------------------------------------------------------------------
203 /** Properties for interval marks:
206 //-------------------------------------------------------------------------
208 /** Determines the type of the marks.@see ChartAxisMarks
210 [property
] long Marks
;
212 //-------------------------------------------------------------------------
214 /** Determines the type of the help marks.@see ChartAxisMarks
216 [property
] long HelpMarks
;
217 //-------------------------------------------------------------------------
219 /** Determines where the interval marks are placed.
221 [optional, property
] com
::sun
::star
::chart
::ChartAxisMarkPosition MarkPosition
;
223 //-------------------------------------------------------------------------
224 /** Properties for axes labels:
227 //-------------------------------------------------------------------------
229 /** Determines whether to display text at the axis or not.
231 [property
] boolean DisplayLabels
;
233 //-------------------------------------------------------------------------
235 /** Contains the type id for the number formatter of the axis.
237 @see com::sun::star::util::XNumberFormatter
239 [property
] long NumberFormat
;
241 //-------------------------------------------------------------------------
243 /** determines whether to use the number format given by the
244 container application, e.g. a spreadsheet document, or from
245 the own property <member>NumberFormat</member>.
247 [optional, property
] boolean LinkNumberFormatToSource
;
249 //-------------------------------------------------------------------------
251 /** Determines where the axis labels are placed.
253 [optional, property
] com
::sun
::star
::chart
::ChartAxisLabelPosition LabelPosition
;
255 //-------------------------------------------------------------------------
257 /** Determines the rotation of the text elements
258 (axis description) in 100th degrees.
260 [property
] long TextRotation
;
262 //-------------------------------------------------------------------------
264 /** The axis description may be arranged in a special order for a
267 [property
] com
::sun
::star
::chart
::ChartAxisArrangeOrderType ArrangeOrder
;
269 //-------------------------------------------------------------------------
271 /** Determines if long text is broken into multiple lines.
273 [property
] boolean TextBreak
;
275 //-------------------------------------------------------------------------
277 /** Determines if certain labels are hidden, if they would otherwise overlap.
278 In this case, the value of this property must be set to <FALSE/>.
280 [property
] boolean TextCanOverlap
;
282 //-------------------------------------------------------------------------
283 /** Properties related to bar charts:
286 //-------------------------------------------------------------------------
288 /** Determines the overlap of the bars in a bar-type chart.
290 <p>The value is given in percent of the width of the bars. The
291 valid range is -100% to +100%. +100% means full overlap, -100%
292 indicates a distance of one bar between 2 neighboring bars.</p>
294 [property
] long Overlap
;
296 //-------------------------------------------------------------------------
298 /** Specifies the width of the gaps between each set of data points
301 <p>The value is given in percent of the width of a bar; the
302 valid range is 0 to 600%.</p>
304 [property
] long GapWidth
;
307 //=============================================================================