version 1.1, 2001/10/10 15:26:00
|
version 1.5, 2001/12/25 23:37:43
|
Line 1
|
Line 1
|
#!/usr/bin/perl |
#!/usr/bin/perl |
# |
# |
# The LearningOnline Network with CAPA |
# $Id$ |
|
# |
|
# Copyright Michigan State University Board of Trustees |
|
# |
|
# This file is part of the LearningOnline Network with CAPA (LON-CAPA). |
|
# |
|
# LON-CAPA is free software; you can redistribute it and/or modify |
|
# it under the terms of the GNU General Public License as published by |
|
# the Free Software Foundation; either version 2 of the License, or |
|
# (at your option) any later version. |
|
# |
|
# LON-CAPA is distributed in the hope that it will be useful, |
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of |
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
|
# GNU General Public License for more details. |
|
# |
|
# You should have received a copy of the GNU General Public License |
|
# along with LON-CAPA; if not, write to the Free Software |
|
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
# |
# |
|
# /home/httpd/cgi-bin/graph.gif |
|
# |
|
# http://www.lon-capa.org/ |
|
# |
|
# The LearningOnline Network with CAPA |
# Behrouz Minaei |
# Behrouz Minaei |
# 9/13/2001, 9/25/2001 |
# YEAR=2001 |
# 10/6/2001, 10,9,2001 |
# 9/13/2001, 9/25/2001, 10/6/2001, 10/9/2001, 12/25/2001 |
# |
# |
# A CGI script that dynamically outputs a graphical chart for lonstatistics. |
# A CGI script that dynamically outputs a graphical chart for lonstatistics. |
|
# |
|
#### |
|
|
use strict; |
use strict; |
use GD::Graph::bars; |
use GD::Graph::bars3d; |
use GD::Graph::colour; |
use GD::Graph::colour; |
use GD::Graph::Data; |
use GD::Graph::Data; |
|
|
|
$|=1; # Autoflush after each print/write |
my ($cid, $Tag, $Max, $PNo, $data) = split(/&/,$ENV{'QUERY_STRING'}); |
my ($cid, $Tag, $Max, $PNo, $data) = split(/&/,$ENV{'QUERY_STRING'}); |
|
|
my @data1=split(/\,/,$data); |
my @data1=split(/\,/,$data); |
Line 23 for (my $nIdx=0; $nIdx<$PNo; $nIdx++ ) {
|
Line 49 for (my $nIdx=0; $nIdx<$PNo; $nIdx++ ) {
|
} |
} |
my @data =(\@xlabels,\@data1); |
my @data =(\@xlabels,\@data1); |
|
|
#print "Content-type: text/html\n\n"; |
|
#print $ENV{'QUERY_STRING'; |
|
#print "<br>"; |
|
#print $Max; |
|
#print "<br>"; |
|
#print $PNo; |
|
#print "<br>"; |
|
#print $data; |
|
#exit; |
|
|
|
my $Range; |
my $Range; |
if ( $PNo > 10 ) {$Range = 30*$PNo;} |
if ( $PNo > 10 ) {$Range = 30*$PNo;} |
else { $Range = 300+30*$PNo; } |
else { $Range = 300+30*$PNo; } |
|
|
if ( $Max < 1 ) { $Max = 1; } |
if ( $Max <= 1 ) { $Max = 1; } |
elsif ( $Max < 10 ) { $Max = 10; } |
elsif ( $Max <= 10 ) { $Max = 10; } |
elsif ( $Max < 100 ) { $Max = 100; } |
elsif ( $Max >= 60 ) { $Max = 100; } |
|
|
my $MyGraph = GD::Graph::bars->new($Range, 400); |
my $MyGraph = GD::Graph::bars3d->new($Range, 400); |
|
|
$MyGraph->set( |
$MyGraph->set( |
x_label => 'Problems #', |
x_label => 'Problems #', |
Line 53 $MyGraph->set(
|
Line 69 $MyGraph->set(
|
x_label_skip => 2, |
x_label_skip => 2, |
|
|
# colors |
# colors |
dclrs => [ qw(green lblue lyellow lpurple cyan lorange)], |
dclrs => [ qw( green lblue lyellow lpurple cyan lorange)], |
|
|
# shadows |
# shadows |
bar_spacing => 4, |
bar_spacing => 4, |
Line 72 END
|
Line 88 END
|
my $BinaryData=$MyGraph->plot(\@data)->png; |
my $BinaryData=$MyGraph->plot(\@data)->png; |
undef $MyGraph; |
undef $MyGraph; |
binmode(STDOUT); |
binmode(STDOUT); |
open IMG,"|pngtopnm|ppmtogif"; # convert into a gif image |
open IMG,"|pngtopnm|ppmtogif 2>/dev/null"; # convert into a gif image |
print IMG $BinaryData; # output image |
print IMG $BinaryData; # output image |
$|=1; # be sure to flush before closing |
$|=1; # be sure to flush before closing |
close IMG; |
close IMG; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|