b75253f5e8ac55dabc999691369449fa6c851862
[scilab.git] / scilab / modules / graphics / src / c / getHandleProperty / get_data_bounds_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_data_bounds_property.c                                       */
19 /* desc : function to retrieve in Scilab the data_bounds field of         */
20 /*        a handle                                                        */
21 /*------------------------------------------------------------------------*/
22
23 #include "getHandleProperty.h"
24 #include "returnProperty.h"
25 #include "Scierror.h"
26 #include "localization.h"
27
28 #include "getGraphicObjectProperty.h"
29 #include "graphicObjectProperties.h"
30
31 /*------------------------------------------------------------------------*/
32 int get_data_bounds_property(void* _pvCtx, char* pobjUID)
33 {
34     double* dataBounds = NULL;
35     int iView = 0;
36     int* piView = &iView;
37
38     getGraphicObjectProperty(pobjUID, __GO_DATA_BOUNDS__, jni_double_vector, (void **)&dataBounds);
39
40     if (dataBounds == NULL)
41     {
42         Scierror(999, _("'%s' property does not exist for this handle.\n"), "data_bounds");
43         return -1;
44     }
45
46     getGraphicObjectProperty(pobjUID, __GO_VIEW__, jni_int, (void **)&piView);
47
48     /**DJ.Abdemouche 2003**/
49     if (iView == 1)
50     {
51         return sciReturnMatrix(_pvCtx, dataBounds, 2, 3);
52     }
53     else
54     {
55         return sciReturnMatrix(_pvCtx, dataBounds, 2, 2);
56     }
57 }
58 /*------------------------------------------------------------------------*/