Para comenzar el proyecto , no conocíamos librerías js que permitieran la manipulación de dichos datos, comenzamos a probar y encontramos bastantes y buenas, pero ninguna se asemeja al poderío de highcharts.
Highcharts es una librería en javascript que permite realizar infinidad de gráficos,completamente configurables, y lo mejor de todo liviano (para todo lo que hace). aquí puedes ver algunas demos .
En este caso voy a realizar un ejemplo a modo recordatorio, en el cual utilizaremos una librería disponible dentro de de esta que es Highstock.
Quiero dejar un registro ya que he visto bastante info sobre este js , pero no he encontrado aún un ejemplo consistente que te permita enviar los datos desde php a la librería en json como corresponde, sino, más bien he visto transformaciones de lo retorna en el controlador (PHP) en la vista (JS). También he considerado hacer el ejemplos con datos tipo "Datatime" comúnmente llamado fecha .
Al final del post adjunto el ejemplo funcionando , es ideal que lean los pasos.
Al grano ...
1.- Levantemos nuestra html :
- <!DOCTYPE html>
- <html>
- <head>
- <title>Ejemplo</title>
- <script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
- <script src="http://code.highcharts.com/stock/highstock.js"></script>
- <script src="http://code.highcharts.com/modules/exporting.js"></script>
- </head>
- <body>
- <div id="chartContainer" style="width:100%; height: 100%;position: relative;">
- </div>
- </body>
- </html>
Utilizaremos Jquery , es posible encontrar Highcharts para "extjs" si estás desarrollando en este FW.
Si prestan atención, verán que hay solo 1 div en el html y que tiene id : chartContainer , este div se utilizará para crear los gráficos.
2.- Creando función :
Seguido agregamos nuestro instancia de Highcharts dentro de los tags <script></script> y cuando la el dom este cargada ,lanzaremos nuestro grafico :
- var chart_; // contenedor del retorno de Highcharts
- $(document).ready(function() {
- });
- function CrearGrafico(data){
- options = {
- chart : {
- renderTo : "chartContainer",
- defaultSeriesType : 'column',
- plotBackgroundColor : null,
- plotBorderWidth : null,
- plotShadow : false,
- height : 800,
- width : 800,
- type : 'line',
- },
- legend : {
- layout : 'vertical',
- align : 'right',
- verticalAlign : 'middle',
- borderWidth : 0
- },
- credits : {
- enabled : false
- },
- scrollbar : {
- enabled : true,
- },
- navigator : {
- enabled : true,
- },
- loading: {
- hideDuration: 1000,
- showDuration: 1000
- },
- rangeSelector : {
- enabled : true,
- selected : 6,
- },
- title : {
- text : 'Grafico de <b>Titulo</b>'
- },
- subtitle : {
- text : 'Grafico de <b><i>Subtitulo</i></b>'
- },
- xAxis : {
- type : 'datetime',
- title : {
- enabled : true,
- text : ' <b>Periodo</b>',
- style : {
- fontWeight : 'normal',
- },
- showEmpty:true,
- },
- },
- yAxis : {
- title : {
- enabled : true,
- text : '<i>' + tipoDato + '</i>',
- style : {
- fontWeight : 'normal',
- },
- showEmpty:true,
- },
- },
- series : data,
- };
- chart_ = new Highcharts.Chart(options);
- }
Esta función recibe un parámetro "data".
3.- Petición ajax:
La llamada ajax tiene que retornar valores json , y por el mismo motivo nosotros debemos recibirlos de la misma manera :
- $.getJSON('ajax.php', function(data) {
- CrearGrafico(data);
- });
Con esto el html final nos queda de la siguiente manera :
- <!DOCTYPE html>
- <html>
- <head>
- <title>Ejemplo</title>
- <script type="text/javascript" src="http://code.jquery.com/jquery-latest.min.js"></script>
- <script src="http://code.highcharts.com/stock/highstock.js"></script>
- <script src="http://code.highcharts.com/modules/exporting.js"></script>
- <script>
- var chart_; // contenedor del retorno de Highcharts
- $(document).ready(function() {
- $.getJSON('ajax.php', function(data) {
- CrearGrafico(data);
- });
- });
- function CrearGrafico(data){
- options = {
- chart : {
- renderTo : "chartContainer",
- defaultSeriesType : 'column',
- plotBackgroundColor : null,
- plotBorderWidth : null,
- plotShadow : false,
- height : 800,
- width : 800,
- type : 'line',
- },
- legend : {
- layout : 'vertical',
- align : 'right',
- verticalAlign : 'middle',
- borderWidth : 0
- },
- credits : {
- enabled : false
- },
- scrollbar : {
- enabled : true,
- },
- navigator : {
- enabled : true,
- },
- loading: {
- hideDuration: 1000,
- showDuration: 1000
- },
- rangeSelector : {
- enabled : true,
- selected : 6,
- },
- title : {
- text : 'Grafico de <b>Titulo</b>'
- },
- subtitle : {
- text : 'Grafico de <b><i>Subtitulo</i></b>'
- },
- xAxis : {
- type : 'datetime',
- title : {
- enabled : true,
- text : ' <b>Periodo</b>',
- style : {
- fontWeight : 'normal',
- },
- showEmpty:true,
- },
- },
- yAxis : {
- title : {
- enabled : true,
- text : '<i>Tipo de dato</i>',
- style : {
- fontWeight : 'normal',
- },
- showEmpty:true,
- },
- },
- series : data,
- };
- chart_ = new Highcharts.Chart(options);
- }
- </script>
- </head>
- <body>
- <div id="chartContainer" style="width:100%; height: 100%;position: relative;">
- </div>
- </body>
- </html>
4.- Ahora revisaremos el archivo PHP - Posgresql :
La información que vamos a desplegar va a ser Fecha (x) ,valor(y) esto va a ser una serie , y cada serie va a tener su propio nombre . con respecto a Y : el valor que retorna la DDBB float y el de Fecha es tu timestamp :
una pequeña muestra :
No entraré en detalles sobre la base de datos , puesto que no se trata de esto el ejemplo.
El código PHP es el siguiente
- <?php
- $dbconn = pg_connect("host=localhost dbname=base_de_datos user=user password=pass")
- or die('Could not connect: ' . pg_last_error());
- function QueryE($query)
- {
- $result = pg_query($query) or die('Query failed: ' . pg_last_error());
- return $result;
- }
- function getSeries($n)
- {
- $aux;
- $aux['name']='Serie:'.$n;
- if($n ==1)
- $result=QueryE('SELECT medicion_fecha,medicion_valor FROM ws_ejemplo_dinamico2(\'W_073_6_248\',10,\'0\') ws order by ws.medicion_fecha asc');
- else if($n==2)
- $result=QueryE('SELECT medicion_fecha,medicion_valor FROM ws_ejemplo_dinamico2(\'W_073_15_104\',6,\'0\') ws order by ws.medicion_fecha asc');
- else
- $result=QueryE('SELECT medicion_fecha,medicion_valor FROM ws_ejemplo_dinamico2(\'W_073_15_294\',6,\'0\') ws order by ws.medicion_fecha asc');
- $numrows=pg_numrows($result);
- for($ri = 0; $ri < $numrows; $ri++) {
- $value=pg_fetch_array($result,$ri);
- $fecha=new DateTime($value['medicion_fecha']); //convertimos los datos a tipo DateTime
- $x=(int)$fecha->format('U')*1000; // convertimos los datosUnix Epoch
- $y=round(($value['medicion_valor']),2); //redondeamos el valor
- $aux['data'][]=array($x,$y);
- }
- return $aux;
- }
- $result = array();
- $rows1=getSeries(1);
- $rows2=getSeries(2);
- $rows3=getSeries(3);
- array_push($result,$rows1);
- array_push($result,$rows2);
- array_push($result,$rows3);
- echo json_encode($result);
Las querys no son relevantes, tener presente que retornan 2 valores (medicion_fecha,medicion_valor) que pueden estar en otro formato o plataforma : CSV,Excel,Mysql,Sqlserver,etc.
Lo relevante este código es que para que Highcharts considere los datos como datatime se le debe indicar en la config ,este tipo, del html ( punto 1 linea verde ) y más aún enviar estos datos en tipo "Unix Epoch" (Linea en rojo del archivo PHP)
La magia de enviar los datos en json directamente desde PHP es "array_push" quien nos permite unir los arrays, luego de estos los datos son convertidos a json por la función "json_encode" y son enviados a la vista .
Al final esto nos genera un gráfico :
El ejercicio va a estar disponible en http://molino.twpanel.com/testing/
Adjunto los 2 archivos para mayor comprensión :
https://mega.co.nz/#!bAYBiSBJ!HDVZwLDn8SW0JmjJb1hWy_vvuHWYsO9sveCexU0HkLI
No hay comentarios:
Publicar un comentario