]> git.llucax.com Git - mecon/meconlib.git/blob - lib/MECON/Graph.php
Se cambian los die(expr) por trigger_error(expr, E_USER_ERROR) para poder interceptar...
[mecon/meconlib.git] / lib / MECON / Graph.php
1 <?php /* vim: set binary expandtab tabstop=4 shiftwidth=4 textwidth=80:
2 -------------------------------------------------------------------------------
3                              Ministerio de Economía
4                                     meconlib
5 -------------------------------------------------------------------------------
6 This file is part of meconlib.
7
8 meconlib is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2 of the License, or (at your option)
11 any later version.
12
13 meconlib is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
15 FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
16  
17 You should have received a copy of the GNU General Public License; if not,
18 write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,
19 Boston, MA  02111-1307  USA
20 -------------------------------------------------------------------------------
21 Creado: Tue Nov 26 12:45:31 2003
22 Autor:  Manuel Nazar Anchorena <manazar@mecon.gov.ar>
23 -------------------------------------------------------------------------------
24 $Id: Graph.php 428 2003-11-18 14:30:30Z mmarre $
25 -----------------------------------------------------------------------------*/
26
27 require_once 'MECON/Graph/external/jpgraph/src/jpgraph.php';
28
29 /**
30  * Liberia base para el manejo de graficos.  
31  */
32 class MECON_Graph {
33
34
35     /**
36      * Tipo del grafico (xy, torta, gantt)
37      * @var int $ancho
38      * @access private
39      */
40     var $_tipo;
41     
42
43     /**
44      * Ancho del grafico.
45      * @var int $ancho
46      * @access private
47      */
48     var $_ancho;
49     
50     /**
51      * Alto del grafico.
52      * @var int $alto
53      * @access private
54      */
55     var $_alto;
56
57      /**
58      * El grafico propiamente dicho.
59      * @var Graph $grafico
60      * @access private
61      */
62     var $_grafico;
63
64     /**
65      * Booleano que define si se muestran o no los valores
66      * @var bool $verValores
67      * @access private
68      */
69     var $_verValores;
70
71     /**
72      * Class constructor.
73      *
74      * @param string $tipo Tipo de grafico(xy,torta,torta3D,gantt)
75      * @param int $ancho Ancho del grafico
76      * @param int $alto Alto del grafico
77      * @param string $titulo Titulo del grafico.
78      * @param array $attrib_gral Contiene opciones generales para el gráfico.
79      *
80      * Opciones generales para gráficos XY:
81      * - XTitulo (Título del Eje X)
82      * - YTitulo (Título del Eje Y)
83      * - XEtiquetas (Array de Referencias del eje X)
84      * - XEtiquetasRotar (Rota las etiquetas del eje X en 90 grados)
85      * - margenes (array asociativo con alguna/s de las siguientes claves:
86      *              - L (margen izquierdo)
87      *              - R (margen derecho)
88      *              - T (margen superior)
89      *              - B (margen inferior))
90      *
91      * @return void
92      * @access public
93      */
94     function MECON_graph($tipo, $ancho=300, $alto=200,$titulo,$attrib_gral=NULL)
95     {    
96         $this->_tipo=$tipo;
97         $this->_ancho= $ancho;
98         $this->_alto= $alto;
99         
100         if (isset($attrib_gral['verValores']))
101             $this->_verValores= $attrib_gral['verValores'];
102         
103         if($this->_tipo=="xy")
104         {
105             $this->_grafico= new Graph($ancho,$alto,"auto");
106             $this->_grafico->SetScale("textlin");
107
108             if (isset($attrib_gral['Xtitulo']))
109                 $this->_grafico->xaxis->title->Set($attrib_gral['Xtitulo']);
110         
111             if (isset($attrib_gral['Ytitulo']))
112                 $this->_grafico->yaxis->title->Set($attrib_gral['Ytitulo']);
113         
114             if (isset($attrib_gral['XEtiquetas']))
115                 $this->_grafico->xaxis->SetTickLabels($attrib_gral['XEtiquetas']);
116
117                 if (isset($attrib_gral['XEtiquetasRotar']))
118                         $this->_grafico->xaxis->label_angle = 90;
119         }
120
121         if(($this->_tipo=="torta")||($this->_tipo=="torta3D"))
122         {
123             require_once 'MECON/Graph/external/jpgraph/src/jpgraph_pie.php';
124             require_once 'MECON/Graph/external/jpgraph/src/jpgraph_pie3d.php';
125             
126             $this->_grafico= new PieGraph($ancho,$alto);
127             
128         }
129       
130         //Atributos en comun
131         
132         if (isset($titulo))
133             $this->_grafico->title-> Set($titulo);
134         if (isset($attrib_gral['subTitulo']))
135             $this->_grafico->subtitle->Set($attrib_gral['subTitulo']);
136         if (isset($attrib_gral['verSombra']) and $attrib_gral['verSombra']==true)
137             $this->_grafico->SetShadow();
138
139         if (isset($attrib_gral['margenes'])){
140                 if (isset($attrib_gral['margenes']['L']))
141                         $this->_grafico->img->left_margin = $attrib_gral['margenes']['L'];
142                 
143                 if (isset($attrib_gral['margenes']['R']))
144                         $this->_grafico->img->right_margin = $attrib_gral['margenes']['R'];
145                 
146                 if (isset($attrib_gral['margenes']['T']))
147                         $this->_grafico->img->top_margin = $attrib_gral['margenes']['T'];
148                 
149                 if (isset($attrib_gral['margenes']['B']))
150                         $this->_grafico->img->bottom_margin = $attrib_gral['margenes']['B'];
151             }
152
153     }
154
155
156     /**
157      * Agrega Secuencia de datos.
158      *
159      * @param array $tipo Tipo de grafico para la secuencia
160      * @param array $secuencia Datos del arreglo
161      * @param array $atributos Atributos especiales para la secuencia
162      *
163      * Tipos de secuencias para gráficos xy:
164      * - lineas
165      * - barras
166      * - puntos
167      *
168      * Atributos:
169      * - color
170      * - colorRelleno (solamente barras y puntos)
171      * - leyenda
172      * - impulso ("si") (solamente para puntos)
173      * - tipoMarca (de 1 a 17) (solamente para puntos)
174      * - etiquetas (array) (para gráficos de torta muestra las etiquetas
175      *                          en lugar de los porcentajes)
176      * - explotar (para torta y torta3D) (valor que indica la separación de
177      *                      de las porciones de la torta) 
178      * - posLeyenda (array con dos coordenadas para la posición de la leyenda)
179      * - formatoValores (string con el formato que se quiere dar a los valores
180      *                  (sprintf))
181      * - noAgregar (Si está seteado indica que la secuencia se genera pero no
182      *              se agrega al gráfico.  Se utiliza para gráficos de barras
183      *              acumulativos, donde las secuencias deben agregarse todas
184      *              juntas al final)
185      *
186      * @return plot
187      * @access public
188      */
189     function agregarSecuencia($tipo,$secuencia,$atributos=NULL)
190     {
191         if($this->_tipo=="xy")
192         {
193             $valido=false;
194         
195             if ($tipo=="lineas")
196             {
197                 $valido=true;
198                 require_once 'MECON/Graph/external/jpgraph/src/jpgraph_line.php';
199                 $plot= new LinePlot($secuencia);
200
201                 if (isset($atributos['colorRelleno']))
202                     $plot->SetFillColor($atributos['colorRelleno']);
203             }
204            
205         
206             if ($tipo=="barras")
207             {
208                 $valido=true;
209                 require_once 'MECON/Graph/external/jpgraph/src/jpgraph_bar.php';
210                 $plot= new BarPlot($secuencia);
211
212                 if (isset($atributos['colorRelleno']))
213                     $plot->SetFillColor($atributos['colorRelleno']);
214             }
215        
216        
217             if ($tipo=="puntos")
218             {
219                 $valido=true;
220                 require_once 'MECON/Graph/external/jpgraph/src/jpgraph_scatter.php';
221                 $plot= new ScatterPlot($secuencia);
222
223                 if (isset($atributos['tipoMarca']))
224                             $plot->mark->SetType($atributos['tipoMarca']);
225             
226                 if (isset($atributos['impulso']))
227                 {
228                     if ($atributos['impulso']=="si")
229                         $plot->SetImpuls();
230                 }
231             }
232             
233             //Si hubo error
234             if ($valido==true)
235             {
236         
237                 // Seteo opciones generales
238                 if (isset($atributos['formatoValores']))
239                         $plot->value->format = $atributos['formatoValores'];
240
241                 if ($this->_verValores)
242                     $plot->value->Show();
243     
244                 if (isset($atributos['color']))
245                     $plot->SetColor($atributos['color']);
246
247                 if (isset($atributos['leyenda']))
248                 {
249                     $plot->SetLegend($atributos['leyenda']);
250                     //$this->_grafico->legend->SetLayout(LEGEND_HOR);
251                     $this->_grafico->legend->Pos(0.02,0.01);
252                 }
253
254             }else
255             { 
256                 trigger_error ("Error: Tipo de grafico $tipo no valido (aun)", E_USER_ERROR);
257             }
258         }//del if tipo xy
259
260         
261         if(($this->_tipo=="torta")||($this->_tipo=="torta3D"))
262         {
263             if($this->_tipo=="torta")
264                 $plot= new PiePlot($secuencia);
265             
266             if($this->_tipo=="torta3D")
267                 $plot= new PiePlot3D($secuencia);
268
269                 // Esto lo agrego porque si no, no redondea a 100%
270                 $plot->labeltype = 2;
271
272             if ($this->_verValores)
273                 $plot->value->Show();
274         
275             if (isset($atributos['leyendas']))
276                 $plot->SetLegends($atributos['leyendas']);
277
278             if (isset($atributos['etiquetas']))
279                 $plot->SetLabels($atributos['etiquetas']);
280
281             if (isset($atributos['centro']))
282             {
283                 $x=$atributos['centro'][0];
284                 $y=$atributos['centro'][1];
285                 $plot->SetCenter($x,$y);
286             }
287
288             if (isset($atributos['explotar']))
289                         $plot->ExplodeAll($atributos['explotar']);
290                 
291         }// del if torta
292         
293
294         if (isset($atributos['posLeyenda']))
295         {
296                 $this->_grafico->legend->xpos = $atributos['posLeyenda'][0];
297                 $this->_grafico->legend->ypos = $atributos['posLeyenda'][1];
298             }
299
300         if (!isset($atributos['noAgregar']))
301             $this->_grafico->Add($plot);
302         
303             return $plot;    
304     
305     }
306   
307     /**
308      * Acumula las secuencias para generar un gráfico acumulativo de barras
309      * 
310      * Ejemplo de Uso:
311      * @code
312      *      require_once 'MECON/Graph.php';
313      *      
314      *      $v1 = array(12,8,19,3,10,5);
315      *      $v2 = array(1,28,9,13,1,5);
316      *
317      *      $graph =& new MECON_Graph ("xy", 300, 300, 'PRUEBA');
318      *
319      *      $b1plot = $graph->agregarSecuencia("barras", $v1);
320      *      $b2plot = $graph->agregarSecuencia("barras", $v2);
321      *
322      *      $graph->acumular(array($b1plot, $b2plot));
323      *      $graph->generar();
324      *   
325      * @endcode
326      *
327      * @param array $secuencias Secuencias de barras a acumular
328      *
329      * @return void
330      * @access public
331      */
332      function acumular ($secuencias)
333      {
334             $rgb = new RGB();
335             $colores = array_keys ($rgb->rgb_table);
336         
337             // Esto pinta cada secuencia de un color diferente
338             for ($i=0; $i< count($secuencias); $i++)
339                 $secuencias[$i]->SetFillColor ($colores[$i]);
340             
341         $accplot = new AccBarPlot($secuencias);
342         $this->_grafico->Add($accplot);
343      }
344   
345     /**
346      * Genera el gráfico y lo dibuja.
347      *
348      * @return void
349      * @access public
350      */
351     function generar()
352     {
353         $this->_grafico->Stroke();
354     }
355
356     /**
357      * Convierte los valores numéricos de entrada en porcentajes
358      *
359      * Ejemplo de uso:
360      * @code
361      *      require_once 'MECON/Graph.php';
362      * 
363      *      $valores = array (4, 6, 23, 14, 30);
364      *      $nuevos = MECON_Graph::porcentajes($valores);
365      *
366      *      // se obtiene (5, 8, 30, 18, 39) (%)
367      *
368      * @endcode
369      *
370      * @param array $valores Array de valores numéricos
371      *
372      * @return array 
373      * @access public
374      * @static
375      */
376      function porcentajes ($valores)
377      {
378         require_once 'MECON/Graph/external/jpgraph/src/jpgraph_pie.php';
379
380         $plot = new PiePlot ($valores);
381         
382         $porciento = $plot->AdjPercentage ($valores);
383         
384         return $porciento;
385      }
386 }