05c7ee028fe9d9964ec6eb220350c462a3fcb161
[scilab.git] / scilab / modules / graphics / src / c / getHandleProperty / get_sub_tics_property.c
1 /*
2  * Scilab ( http://www.scilab.org/ ) - This file is part of Scilab
3  * Copyright (C) 2004-2006 - INRIA - Fabrice Leray
4  * Copyright (C) 2006 - INRIA - Allan Cornet
5  * Copyright (C) 2006 - INRIA - Jean-Baptiste Silvy
6  * Copyright (C) 2010 - DIGITEO - Manuel Juliachs
7  * Copyright (C) 2011 - DIGITEO - Vincent Couvert
8  *
9  * This file must be used under the terms of the CeCILL.
10  * This source file is licensed as described in the file COPYING, which
11  * you should have received as part of this distribution.  The terms
12  * are also available at
13  * http://www.cecill.info/licences/Licence_CeCILL_V2.1-en.txt
14  *
15  */
16
17 /*------------------------------------------------------------------------*/
18 /* file: get_sub_tics_property.c                                          */
19 /* desc : function to retrieve in Scilab the sub_tics or sub_ticks field  */
20 /*        of a handle                                                     */
21 /*------------------------------------------------------------------------*/
22
23 #include <string.h>
24
25 #include "getHandleProperty.h"
26 #include "GetProperty.h"
27 #include "returnProperty.h"
28 #include "Scierror.h"
29 #include "localization.h"
30
31 #include "getGraphicObjectProperty.h"
32 #include "graphicObjectProperties.h"
33
34 /*------------------------------------------------------------------------*/
35 int get_sub_tics_property(void* _pvCtx, char* pobjUID)
36 {
37     int iType = -1;
38     int *piType = &iType;
39     int iSubTicks = 0;
40     int* piSubTicks = &iSubTicks;
41
42     /*Dj.A 17/12/2003*/
43     /* modified jb Silvy 01/2006 */
44
45     getGraphicObjectProperty(pobjUID, __GO_TYPE__, jni_int, (void **)&piType);
46
47     /*
48      * Type test required as the Axis object stores subticks as a single int
49      * whereas Axes maintain a 3-element int vector.
50      */
51     if (iType == __GO_AXIS__)
52     {
53         getGraphicObjectProperty(pobjUID, __GO_SUBTICKS__, jni_int, (void**)&piSubTicks);
54
55         if (piSubTicks == NULL)
56         {
57             Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
58             return -1;
59         }
60
61         return sciReturnDouble(_pvCtx, iSubTicks);
62     }
63     else if (iType == __GO_AXES__)
64     {
65         double sub_ticks[3];
66         int iView = 0;
67         int* piView = &iView;
68
69         getGraphicObjectProperty(pobjUID, __GO_X_AXIS_SUBTICKS__, jni_int, (void**)&piSubTicks);
70
71         if (piSubTicks == NULL)
72         {
73             Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
74             return -1;
75         }
76
77         sub_ticks[0] = iSubTicks;
78
79         getGraphicObjectProperty(pobjUID, __GO_Y_AXIS_SUBTICKS__, jni_int, (void**)&piSubTicks);
80         sub_ticks[1] = iSubTicks;
81
82         getGraphicObjectProperty(pobjUID, __GO_Z_AXIS_SUBTICKS__, jni_int, (void**)&piSubTicks);
83         sub_ticks[2] = iSubTicks;
84
85         getGraphicObjectProperty(pobjUID, __GO_VIEW__, jni_int, (void**)&piView);
86
87         if (iView == 1)
88         {
89             return sciReturnRowVector(_pvCtx, sub_ticks, 3);
90         }
91         else
92         {
93             return sciReturnRowVector(_pvCtx, sub_ticks, 2);
94         }
95     }
96     else
97     {
98         Scierror(999, _("'%s' property does not exist for this handle.\n"), "sub_ticks");
99         return -1;
100     }
101 }
102 /*------------------------------------------------------------------------*/