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
<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <pre> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

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 Agosto 19, 2008 @ 1:44 pmOlá 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 Agosto 20, 2008 @ 5:49 pmOlá 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 Agosto 21, 2008 @ 12:20 pmentão Rafael!
Comentário por Aline Agosto 27, 2008 @ 1:08 pme os posts com Banco de dados?
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 Agosto 29, 2008 @ 8:18 pmNeste final de semana postarei o exemplo com BD.
Comentário por Rafael Clares Agosto 29, 2008 @ 8:26 pmabraços
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.
Comentário por Rafael Clares Agosto 30, 2008 @ 3:32 pmAbraços,
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 Setembro 1, 2008 @ 3:38 pmTem 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?
Comentário por Carlos Janeiro 28, 2009 @ 8:42 pmValeu
Carlos, tem sim, claro. Acho que deve ser um dos maiores propósitos de gráficos, trabalhar números.
Comentário por Rafael Clares Janeiro 28, 2009 @ 10:14 pmDê uma olhada na documentação.
abraços
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 Janeiro 29, 2009 @ 12:39 amCarlos, 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.
Comentário por Rafael Clares Janeiro 29, 2009 @ 1:58 pmabraços!
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 Janeiro 30, 2009 @ 10:23 pmCarlos, 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.
Comentário por Rafael Clares Janeiro 30, 2009 @ 11:30 pmUm grande abraço,
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ê Fevereiro 12, 2009 @ 1:38 pmOlá, no arquivo open_flash_chart_object.php você deve setar a variável $base com o url do diretório desejado.
Comentário por Rafael Clares Fevereiro 12, 2009 @ 10:35 pmAté mais,
Ah, nunca usei, nem sabia que existia mas gostei!
Valeu!
Mesmo problema do carlos, essa funcao mesmo existindo na doc, se colocar os ‘,’,’.’
Comentário por Ana Março 11, 2009 @ 7:33 pmnao funciona o grafico da erro.
olá,gostaria de saber onde eu salvo o arquivo para aparecer na internet.
Comentário por jessica Abril 20, 2009 @ 1:19 pmJessica, me desculpe, não entendi o que deseja fazer;
Comentário por Rafael Clares Abril 22, 2009 @ 11:10 amEu 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 Abril 30, 2009 @ 2:22 pmOlá 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 Maio 5, 2009 @ 1:17 pmMuito 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 Julho 4, 2009 @ 5:29 amCara achei bacana de mais como você explico essa classe e como usar. Valeu mesmo aprendi de mais com isso.
Comentário por EdsonAntolini Julho 30, 2009 @ 2:02 pmVocê poderia me enviar, alguma coisa como posso pegar dados do banco e jogar no grafico?
Obrigado desde ja.
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 Julho 30, 2009 @ 2:39 pm