Rafael Clares


Gerando Gráficos com PHP
Agosto 9, 2008, 8:41 pm
Arquivado em: PHP | Tags: , , ,

Gráficos utilizando a Classe PHPlot

Pessoal, blz ai né?

Galerinha, vou apresentar hoje o PHPLot, uma classe bacana para criar gráficos em nossas aplicações PHP !

Vou começar dando alguns exemplos básicos da necessidade de se gerar gráficos na aplicação.

* Mostrar estatísticas de acesso diário/mensal/anual de um sistema on-line.
Consumo de itens em uma dada categoria.
* Estatísticas de venda de produtos através da internet.
* Contatos por categoria (dúvidas, vendas, financeiro …)

Enfim, dados de entrada e saída que precisam ser acompanhados e analisados.

Aqui será apresentado o código necessário para gerar o gráfico na tela, não iremos, ao menos neste post, ver como pegar os dados dinâmicamente do banco e gerar o gráfico. Eu estou trabalhando em um projeto que deverá conter esse recurso, então fiz de acordo com as necessidades da aplicação no projeto.

Então, entraremos com os dados pré-definidos requeridos como parâmetros da classe PHPLot.

O gráfico que iremos gerar irá mostrar os usuários cadastrados em um sistema qualquer, exibiremos três barras para cada mês do ano, cada barra representará uma categoria de usuário e a quantidade de ocorrências de cadastro naquele mês.

Primeiramente, vamos ver como o código é estruturado:

<?php
#incluindo a classe. verifique se diretorio e versao sao iguais, altere se precisar
include(‘phplot-5.0.4/phplot.php’);
#Matriz utilizada para gerar os graficos
$data = array(
  array(‘Jan‘, 20, 2, 4), array(‘Fev‘, 30, 3, 4), array(‘Mar‘, 20, 4, 14),
  array(‘Abr‘, 30, 5, 4), array(‘Mai‘, 13, 6, 4), array(‘Jun‘, 37, 7, 24),
  array(‘Jul‘, 10, 8, 4), array(‘Ago‘, 15, 9, 4), array(‘Set‘, 20, 5, 12),
  array(‘Out‘, 28, 4, 14), array(‘Nov‘, 16, 7, 14), array(‘Dez‘, 24, 3, 15),
);
#Instancia o objeto e setando o tamanho do grafico na tela
$plot = new PHPlot(800,600);
#Tipo de borda, consulte a documentacao
$plot->SetImageBorderType(‘plain‘);
#Tipo de grafico, nesse caso barras, existem diversos(pizza…)
$plot->SetPlotType(‘bars‘);
#Tipo de dados, nesse caso texto que esta no array
$plot->SetDataType(text-data);
#Setando os valores com os dados do array
$plot->SetDataValues($data);
#Titulo do grafico
$plot->SetTitle(‘Cadastro de usuários no Site‘);
#Legenda, nesse caso serao tres pq o array possui 3 valores que serao apresentados
$plot->SetLegend(array(‘Estudantes‘,’Colunistas‘, ‘Desenvolvedores‘));
#Utilizados p/ marcar labels, necessario mas nao se aplica neste ex. (manual) :
$plot->SetXTickLabelPos(‘none‘);
$plot->SetXTickPos(‘none‘);
#Gera o grafico na tela
$plot->DrawGraph();
?>

O código acima irá gerar exatamento o gráfico como no exibido na figura abaixo:

A começar pelo Array $data, perceba que ele recebe 4 valores, isso é uma divergência à informação passada mais acima, mas calma, vou explicar. São 4 valores, o primeiro recebe uma string que se refere ao mês, o segundo valor recebe a quantidade de ocorrências para a categoria 1, o segundo recebe a quantidade de ocorrências para a categoria 2, o terceiro recebe a quantidade de ocorrências para a categoria 3.

Então, fora o mês temos 3 valores, opa agora sim ta fazendo sentido o que falei lá em cima. Bem, claro que você pode utilizar quantos valores quiser no seu array vai depender de sua necessidade!

Um outro ponto à ser considerado neste exemplo é a linha:

$plot->SetLegend(array(‘Estudantes’,'Colunistas’, ‘Desenvolvedores’));

Perceba que o método recebe um array com 3 valores, certo até ai não é?

continue nessa linha de raciocinio… O array recebe 3 valores que irão representar justamente os valores das 3 barras que serão geradas, lembra? 3 barras no array $data, 1 barra para cada categoria! lembrou né!!

Então, acontece que o array passado pelo método SetLegend precisa estar em ordem em relação os valores que você quer representar nas 3 barras, por exemplo:

Imagine esse array ->  (‘Janeiro’,10,20,30)

Bem, como dito antes o primeiro valor do array não será representado, trata-se apenas da legenda para as 3 barras do mês de Janeiro. Assim concluímos que, teremos uma barra com altura 10, outra com altura 20 e a última com altura 30. Então vamos voltar ao método SetLegend(), os valores do array passado por esse método irão representar as cores das barras, vamos unir as duas linhas em questão.

1 -(‘Janeiro’, 10, 20, 30)
2 -SetLegend(array(‘Estudantes’,'Colunistas’, ‘Desenvolvedores’))

 Agora, tente visualizar o Estudantes = 10, Colunistas = 20 e Desenvolvedores = 30.

Sacou né? Por isso que você deve prestar atenção na ordem das legendas, parece bobeira mas se você acidentalmente inverter as posições seu sistema não servirá de nada além de apresentar os dados incorretos para o usuário fazendo-o tomar decisões erradas. É sempre bom nos atentarmos à estes detalhes, eles fazem toda a diferença, literalmente!  ;)

Importante!

Cada arquivo como o do exemplo acima gera o gráfico retornando como uma imagem, ou seja, você não adiciona textos ou conteúdo adicional à este arquivo. Para utilizar em meio à outras páginas com conteúdos você pode fazer como descrito abaixo.

Supondo que seus gráficos são gerados pelos arquivos grafico1.php  e grafico2.php, você pode cirar um novo arquivo .php (ou qualquer outro já existente) e inserir as linhas abaixo:

<p>Gráfico 1</p>
<img src=”grafico1.php” />
<p>Gráfico 2</p>
<img src=”grafico2.php” />

 

Algumas considerações:
O PHPlot não se resume apenas à gráficos em barras, ele permite gerar gráficos desde gráficos pizza até os mais complexos gráficos. As cores também podem ser setadas como parâmetro.

Dê uma boa olhada na documentação.

Links:
A Classe PHPlot em  http://sourceforge.net/projects/phplot/

A documentação do PHPlot deve estar contida no pacote, caso contrário http://www.jeo.net/php/phplot/doc/

O Exemplo (não inclui todos os arquivos do PHPlot e docs)
download exemplo

Galerinha, vai terminando por aqui, se quiserem ver como gerar gráficos à partir de uma tabela do banco de dados, peçam aí por comentário que escreverei com muito prazer!

Abraços e obrigado pelos comentários que vocês tem deixado aí, são todos motivadores!  ;)

Rafael Clares


24 Comentários até o momento
Deixe um comentário

Ola Rafael, poderia passar um exemplo de como utilizar usando banco de dados , preciso fazer um grafico simples ou seja quantidade de pessoas cadastradas por cidade

Comentário por Lorenzi

Olá Lorenzi, acredito que para o seu caso é melhor utilizar o exemplo que dei do PHP+Fusion Charts, dê uma olhada no outro post sobre gráficos e se mesmo assim não estiver fácil eu postarei essa semana o exemplo que pediu. Abraços

Comentário por Rafael Clares

Olá Rafel, seria interessante mesmo uns posts utilizando Banco de Dados. Estou aprendendo agora utilizar esta biblioteca, e agradeceria se pudesse ajudar. Está super explicativo seu texto, clareou muita coisa para mim, Parabéns!

Comentário por Aline

então Rafael!
e os posts com Banco de dados?

Comentário por Aline

Boa tarde,

Gostei muito do phplot, no entanto preciso gerar alguns relatorios, e no meio dos textos dos relatórios precisam ser inseridos alguns graficos. Só que quando eu insiro qualquer tipo de texto no arquivo que gera o gráfico dá erro de imagem.
Como posso resolver esse problema, de modo que no meio de um parágrafo apareça um gráfico??

Abraços

Comentário por Diego wildberger

Neste final de semana postarei o exemplo com BD.
abraços

Comentário por Rafael Clares

Olá Diego, entao cara tem como colocar aqui o trecho do código que não está de acordo com que você espera? Acredito que ficará mais fácil.
Abraços,

Comentário por Rafael Clares

Diego, fiz uma macacada aqui e acabei deletando seu último comentário ha-ha. Mas vou colorar no post a sua dica. Valeu brother ;)

Comentário por Rafael Clares

Tem como trabalhar com valores monetários, tipo, imprimir um gráfico com porcentagem de cada valor: R$ 1.000,89 e 234,98, por exemplo?
Valeu

Comentário por Carlos

Carlos, tem sim, claro. Acho que deve ser um dos maiores propósitos de gráficos, trabalhar números.
Dê uma olhada na documentação.
abraços

Comentário por Rafael Clares

não achei nada na documentação que falasse em números monetários. tentei fazer na unha, mas se colocar , ele interpreta como outro valor, tô buscando dados do MySQL e tenho que somar os resultados e mostrar a soma de cada tipo pra ele colocar a % de cada um no gráfico, mas se vier em float, ex 1.203,00 ele interpreta como sendo 1.2 e 00 separado como outro valor…

Comentário por Carlos

Carlos, realmente isso irá ocorrer se você não converter o número para o formato desejado antes de enviar para o gráfico, para isso você terá que utilizar a função number_format do PHP, dê uma olhada em http://br.php.net/number_format.
abraços!

Comentário por Rafael Clares

pois é, utilizei o number_format para formatar os valores. O problema é que o phplot interpreta mil reais como sendo 1 real e 20 reais como sendo um número maior. A função de formataçãod e números do PHPLOT idem…

Comentário por Carlos

Carlos, entendo o que está dizendo, mas como eu havia dito antes à você, dê uma olhada na documentação, bem, você disse que olhou, dai eu insisto em dizer que gráficos devem possuir formatação para numeros e todos os tipos de dados, enfim, vendo que realmente você não conseguiu fazer me propus a procurar na documentação e … em pouquissimo tempo olhando as docs eu consegui fazer o que você tanto precisa, não fiz o programa para você mas vou te apontar o local da documentação onde explica como fazer o que você precisa com apenas um método da classe.
segue o link da documentação:
http://phplot.sourceforge.net/phplotdocs/SetNumberFormat.html
No geral, a sintaxe é a seguinte:

$plot->SetNumberFormat($decimal_point, $thousands_sep)

onde $decimal_point é o separador decimal e $thousands_sep é o separador da milhar, logo,

$plot->SetNumberFormat(‘,’, ‘.’);

basta incluir essa linha logo após instanciar o objeto PHPlot , mais precisamente após
$plot = new PHPlot(600,400);

Espero ter ajudado, de toda forma, tudo que precisa está na documentação, se tiver alguma dificuldade para entender a doc, me avise.
Um grande abraço,

Comentário por Rafael Clares

OI

Você já utilizou a open flash chart ?

Se sim… conseguiu mudar o caminho dos arquivos .swf ?

Obrigada se puder me envia por e-mail..

Valeu…

ah e parabens pelo artigo….

Comentário por Nenê

Olá, no arquivo open_flash_chart_object.php você deve setar a variável $base com o url do diretório desejado.
Até mais,
Ah, nunca usei, nem sabia que existia mas gostei!
Valeu!

Comentário por Rafael Clares

Mesmo problema do carlos, essa funcao mesmo existindo na doc, se colocar os ‘,’,’.’
nao funciona o grafico da erro.

Comentário por Ana

olá,gostaria de saber onde eu salvo o arquivo para aparecer na internet.

Comentário por jessica

Jessica, me desculpe, não entendi o que deseja fazer;

Comentário por Rafael Clares

Eu estou passando por um problema com ele, ao montar o grafico e chama-lo, aparece apenas um quadrado branco com um “x”, e não aparece o meu grafico.. Os gradficosteste do sistema rodam muito bem, e já verifiquei que a tabela para o grafico é montada corretament. Poderias me ajudar? Fico muito grata

Comentário por RSel

Olá Rosana, verifique se seu PHP tem a biblioteca GD/GD2 intalada/ativada, se estiver me envie o código que está gerando o gráfico para eu ver! Tchau

Comentário por Rafael Clares

Muito bom o tutorial realmente funciona, muito obrigado espero que fale mais sobre o Phplot para imprimir objetos do banco de dados ou ate mesmo utilizar os outros graficos.

Comentário por FaGnEr

Cara achei bacana de mais como você explico essa classe e como usar. Valeu mesmo aprendi de mais com isso.
Você poderia me enviar, alguma coisa como posso pegar dados do banco e jogar no grafico?
Obrigado desde ja.

Comentário por EdsonAntolini

Edson, dê uma lida nesse outro post, o principio é o mesmo, gerar o xml ou array a partir do banco de dados, a idéia é a mesma.

http://clares.wordpress.com/2008/08/10/gerando-graficos-com-php-fusioncharts/

abraços

Comentário por Rafael Clares




Deixe um comentário
Linhas e parágrafos quebram automaticamente, endereços de email não serão mostrados, HTML permitido: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <pre> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>