Foros del Web » Programando para Internet » PHP »

Variable php en grafica

Estas en el tema de Variable php en grafica en el foro de PHP en Foros del Web. Buenas, Amigo necesito mostrar en una grafica unos datos que extraigo desde una variable en PHP desde una BD MySql. Tengo un problema, al colocar ...
  #1 (permalink)  
Antiguo 15/05/2012, 09:10
 
Fecha de Ingreso: enero-2012
Mensajes: 109
Antigüedad: 12 años, 3 meses
Puntos: 0
Variable php en grafica

Buenas,

Amigo necesito mostrar en una grafica unos datos que extraigo desde una variable en PHP desde una BD MySql.

Tengo un problema, al colocar la variable en el codigo de la grafica, me agarra solo un valor, me grafica con un el primer valor que hay en la tabla de la BD.

Aqui les dejo el codigo a ver si alguien me ayuda:

Código:
<?php   

$conexion=mysql_connect("localhost","root","movilnet2012");
mysql_select_db("datos");
$consulta="SELECT * FROM valores WHERE Critical";
$queEmp = mysql_query($consulta, $conexion);

while($Emp=mysql_fetch_assoc($queEmp)){


 /* pChart library inclusions */
 include("class/pData.class.php");
 include("class/pDraw.class.php");
 include("class/pImage.class.php");

 /* Create and populate the pData object */
 $MyData = new pData();  

 $MyData->addPoints(array($Emp['Critical'],$Emp['Critical'],$Emp['Critical'],$Emp['Critical'],$Emp['Critical'],5,3,12,15,8,5,5,3,12,15,8,5,5,3,12,15,8,5,5),"Major");
 $MyData->addPoints(array(5,3,5,12,8,3,3,10,5,12,8,3,3,10,5,12,8,3,3,10,5,12,8,3),"Critical");
 $MyData->addPoints(array(2,7,5,18,19,22,2,7,5,18,19,22,2,7,5,18,19,22,2,7,5,18,19,22),"Minor");
 $MyData->setSerieTicks("Probe 2",4);
 $MyData->setSerieWeight("Probe 3",2);
 $MyData->setAxisName(0,"Alarmas");
 $MyData->addPoints(array("00:00","01:00","02:00","03:00","04:00","05:00","06:00","07:00","08:00","09:00","10:00","11:00","12:00","13:00","14:00","15:00","16:00","17:00","18:00","19:00","20:00","21:00","22:00","23:00"),"Labels");
 $MyData->setSerieDescription("Labels","Horas");
 $MyData->setAbscissa("Labels");

 
 /* Create the pChart object */
 $myPicture = new pImage(980,230,$MyData);

 /* Turn of Antialiasing */
 $myPicture->Antialias = FALSE;

 /* Add a border to the picture */
 $myPicture->drawRectangle(0,0,980,229,array("R"=>0,"O"=>0,"B"=>0));
 
 /* Write the chart title */ 
 $myPicture->setFontProperties(array("FontName"=>"class/fonts/Forgotte.ttf","FontSize"=>11));
 $myPicture->drawText(150,35,"Estadisticas Alarmas Movilnet",array("FontSize"=>20,"Align"=>TEXT_ALIGN_BOTTOMMIDDLE));

 /* Set the default font */
 $myPicture->setFontProperties(array("FontName"=>"class/fonts/pf_arma_five.ttf","FontSize"=>6));

 /* Define the chart area */
 $myPicture->setGraphArea(60,40,980,200);

 /* Draw the scale */
 $scaleSettings = array("XMargin"=>10,"YMargin"=>10,"Floating"=>TRUE,"GridR"=>200,"GridO"=>200,"GridB"=>200,"DrawSubTicks"=>TRUE,"CycleBackground"=>TRUE);
 $myPicture->drawScale($scaleSettings);

 /* Turn on Antialiasing */
 $myPicture->Antialias = TRUE;

 /* Draw the line chart */
 $myPicture->drawLineChart();

 /* Write the chart legend */
 $myPicture->drawLegend(540,20,array("Style"=>LEGEND_NOBORDER,"Mode"=>LEGEND_HORIZONTAL));

 /* Render the picture (choose the best way) */
 $myPicture->autoOutput("pictures/example.drawLineChart.simple.png");
   }
?>
Gracias
  #2 (permalink)  
Antiguo 19/05/2012, 13:15
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: Variable php en grafica

El problema es que generas un objeto gráfico por cada registro que devuelve la consulta, por tanto, todos los valores se sobreescriben menos el último. Tienes que hacer primero la consulta, guardar los valores y luego pasarlos a un sólo objeto gráfico. Saludos
__________________
Fere libenter homines, id quod volunt, credunt.

Etiquetas: mysql, sql, tabla, variables, graficos
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 03:14.