Foros del Web » Programando para Internet » PHP »

jpgraph con valores desde BD

Estas en el tema de jpgraph con valores desde BD en el foro de PHP en Foros del Web. Buenas cracks, Estoy tratando de incluir gráficas a mi proyecto con jpgraph. Si uso los ejemplos de esta libreria, funciona perfectamente, el problema es cuando ...
  #1 (permalink)  
Antiguo 23/03/2011, 10:32
 
Fecha de Ingreso: agosto-2009
Mensajes: 216
Antigüedad: 14 años, 8 meses
Puntos: 3
jpgraph con valores desde BD

Buenas cracks,

Estoy tratando de incluir gráficas a mi proyecto con jpgraph. Si uso los ejemplos de esta libreria, funciona perfectamente, el problema es cuando quiero coger los valores de mi gráfico desde mi base de datos.

Donde se genera el gráfico tengo(stats.php):

Código PHP:
<?php
session_start
();
?>
<?php

    
include ('funciones.php');
$sql1 "SELECT *
            FROM stats
            WHERE usuario = 'peter'"
;
            
    
$res1 mysql_query($sql1);
    
$row1 mysql_fetch_array($res1);
    
    
    include (
"jpgraph/jpgraph.php");
    include (
"jpgraph/jpgraph_pie.php");
    include (
"jpgraph/jpgraph_pie3d.php");
    
        

    
    
// Some data
    
$data = array($row1["t1"],$row1["t2"],$row1["t3"],$row1["t4"]);
    
    
// Create the Pie Graph. 
    
$graph = new PieGraph(350,250);
    
    
    
    
$theme_class= new VividTheme;
    
$graph->SetTheme($theme_class);
    
    
// Set A title for the plot
    
$graph->title->Set("Tácticas usadas");
    
    
// Create
    
$p1 = new PiePlot3D($data);
    
$graph->Add($p1);
    
$nombres=array("A","B","C","D");
    
$p1->SetLegends($nombres); 
    
$p1->ShowBorder();
    
$p1->SetColor('black');
    
$p1->ExplodeSlice(1);
    
$graph->Stroke();

?>
Luego llamo al gráfico así:

Código HTML:
<img src="stats.php" alt="" border="0"> 
Me salta el siguiente error: No se puede mostrar la imagen http://127.0.0.1:8888/miweb/stats.php porque contiene errores.

He descubierto, que tan pronto como pongo código MySQL o incluso el include 'funciones.php'; el gráfico deja de aparecer.

Alguna idea??

Gracias!!
  #2 (permalink)  
Antiguo 23/03/2011, 10:37
 
Fecha de Ingreso: agosto-2009
Mensajes: 216
Antigüedad: 14 años, 8 meses
Puntos: 3
Respuesta: jpgraph con valores desde BD

Nueva info:

El problema está en el include, claramente. Ya que lo he quitado y he puesto directamente la función de conexión de la bd dentro de stats.php y funciona perfectamente....

Hay algún modo de evitar tener que poner el código de conexión de la bd en todos los gráficos que vaya a usar?? Es un poco coñazo, la verdad, porque son unos cuantos.

Gracias!
  #3 (permalink)  
Antiguo 23/03/2011, 11:08
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: jpgraph con valores desde BD

Revisa que no tengas salida de texto dentro de tu archivo funciones.php, lo mejor es que ese tipo de scripts no tengan el ?> al final para evitar que tengan salidas de texto.

Saludos.
  #4 (permalink)  
Antiguo 23/03/2011, 11:16
 
Fecha de Ingreso: agosto-2009
Mensajes: 216
Antigüedad: 14 años, 8 meses
Puntos: 3
Respuesta: jpgraph con valores desde BD

Cita:
Iniciado por GatorV Ver Mensaje
Revisa que no tengas salida de texto dentro de tu archivo funciones.php, lo mejor es que ese tipo de scripts no tengan el ?> al final para evitar que tengan salidas de texto.

Saludos.
Hola GatorV, gracias por tu respuesta.

Te refieres a que funciones.php no tenga el ?> al final del documento? Eso no generaría un error?? Pregunto, que no lo sé, pero me parece raro

Un saludo!
  #5 (permalink)  
Antiguo 23/03/2011, 12:01
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: jpgraph con valores desde BD

No, para PHP el único que es obligatorio es el <?php al inicio.

Saludos.
  #6 (permalink)  
Antiguo 23/03/2011, 13:18
 
Fecha de Ingreso: agosto-2009
Mensajes: 216
Antigüedad: 14 años, 8 meses
Puntos: 3
Respuesta: jpgraph con valores desde BD

Cita:
Iniciado por GatorV Ver Mensaje
No, para PHP el único que es obligatorio es el <?php al inicio.

Saludos.
Ok. Lo hice y me sigue pasando lo mismo. Alguna idea??

Gracias.
  #7 (permalink)  
Antiguo 12/05/2011, 16:15
 
Fecha de Ingreso: enero-2011
Ubicación: Maracaibo
Mensajes: 179
Antigüedad: 13 años, 3 meses
Puntos: 2
Respuesta: jpgraph con valores desde BD

Hola bienpiyao, despues de tu consulta debes hacer un while para que recorra toda la tabla y luego pasar esa variable al grafico, algo asi:


Código PHP:
$query mysql_query("SELECT votos,candidato FROM encuesta");
    
    while(
$row mysql_fetch_array($query))
    {
     
$data[] = $row[0];
     
$can[] = $row[1];
    } 
espero te sirva
  #8 (permalink)  
Antiguo 24/05/2011, 15:53
 
Fecha de Ingreso: mayo-2011
Mensajes: 2
Antigüedad: 12 años, 11 meses
Puntos: 0
Respuesta: jpgraph con valores desde BD

Hola. Estoy graficando una distribución normal y necesito calcular una sumatoria del arreglo que saco de la BD antes de recorrerlo otra vez para enviarlo al gráfico. Eso me da el error "Empty input data array specified for plot. Must have al leats one data point"
No funciona ni llamando la sumatoria en una clase.

Código PHP:
$cadena =  "select distinct a.grade FROM evaluation_student_evals a inner join td_estudiantes b on a.party_id = b.id_estudiante where b.cod_depto = '$depto' and a.grade >= 0 and a.grade <= 100 order by a.grade ";
$sql $conectar-> consultas($cadena);        
//calcular sigma y miu          
$total pg_num_rows($sql);
$suma 0;
while (
$row pg_fetch_assoc($sql))
    {
        
$suma += $row['grade'];
    }
$media $suma/$total
              
//Normalizar datos de notas Z = (X-miu)/sigma
      
while ($row pg_fetch_assoc($sql))
    {        
        
$z[$i] = ($row['grade'] - 57)/12// $z => arreglo con notas normalizadas
        
$ordenada[$i] = (1/($desviacion*sqrt(pi())))*(exp(-0.5*(($row['grade']-57)*($row['grade'] - 57))/($desviacion*$desviacion)));                             
        
$i++;
    }        

        
$graph = new Graph(600,400,"auto");
        
$graph->SetScale("linlin");
        
$theme_class=new UniversalTheme;        
        
$graph->SetTheme($theme_class);
        
$graph->yaxis->HideZeroLabel();
        
$graph->yaxis->HideLine(false);
        
$graph->yaxis->HideTicks(false,false);
        
        
$graph->xgrid->Show();
        
$graph->xgrid->SetLineStyle("solid");
        
$graph->xaxis->SetTickLabels(array(-3,-2,-1,0,1,2,3));
        
$graph->xgrid->SetColor('#E3E3E3');
        
        
$p1 = new LinePlot($ordenada);
        
$graph->Add($p1);
        
$p1->SetColor("#6495ED");
        
$graph->legend->SetFrameWeight(1);
        
        
// Output line
        
$graph->Stroke(); 
Gracias!
  #9 (permalink)  
Antiguo 27/05/2011, 00:31
 
Fecha de Ingreso: mayo-2011
Mensajes: 2
Antigüedad: 12 años, 11 meses
Puntos: 0
Respuesta: jpgraph con valores desde BD

Me contesto a mí misma. Jpgraph respeta el framework MVC. Él sólo recibe datos, no manipula los datos.

Etiquetas: bd, jpgraph
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 08:57.