--- loncom/cgi/graph.png 2001/10/10 15:26:00 1.1 +++ loncom/cgi/graph.png 2003/10/08 15:44:49 1.22 @@ -1,92 +1,165 @@ #!/usr/bin/perl # -# The LearningOnline Network with CAPA +# $Id: graph.png,v 1.22 2003/10/08 15:44:49 matthew Exp $ +# +# 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. # -# Behrouz Minaei -# 9/13/2001, 9/25/2001 -# 10/6/2001, 10,9,2001 +# 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 # # A CGI script that dynamically outputs a graphical chart for lonstatistics. +# +#### + +=pod + +=head1 NAME + +graph.png + +=head1 SYNOPSIS + +produces plots based on input + +=head1 DESCRIPTION + +graph.png is a cgi-bin script which produces plots based on input data. + +The query string is expected to be as follows (without whitespace): + +escape(Plot title) & escape(X label)& escape(Y label) & Maximum Y value & +Number of bars & $data1 & $data2 + +$data1 and $data2 are expected to be comma seperated lists of numbers. +escape( value ) means the values must be run through lonnet::escape. + +=cut use strict; use GD::Graph::bars; use GD::Graph::colour; use GD::Graph::Data; -my ($cid, $Tag, $Max, $PNo, $data) = split(/&/,$ENV{'QUERY_STRING'}); +sub unescape { + my $str=shift; + $str =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg; + return $str; +} + +$|=1; # Autoflush after each print/write +my ($Titr,$xlab,$ylab,$Max,$PNo,$data1,$data2)=split(/&/,$ENV{'QUERY_STRING'}); +$Titr = &unescape($Titr); +$xlab = &unescape($xlab); +$ylab = &unescape($ylab); + +my @data11=split(/\,/,$data1); +my @data12=split(/\,/,$data2); +my $skip_x = 1; +my $bar_space=10; -my @data1=split(/\,/,$data); - my @xlabels; -for (my $nIdx=0; $nIdx<$PNo; $nIdx++ ) { - $xlabels[$nIdx]=$nIdx+1; + +if ($Titr =~ /^Percentage$/){ + for (my $nIdx=0; $nIdx<$PNo; $nIdx++ ) { + $xlabels[$nIdx]=$nIdx; + } + @data11=(); + @data11=split(/\,/,$data2); + @data12=(); + $Titr = ''; +} else { + for (my $nIdx=0; $nIdx<$PNo; $nIdx++ ) { + $xlabels[$nIdx]=$nIdx+1; + } } -my @data =(\@xlabels,\@data1); -#print "Content-type: text/html\n\n"; -#print $ENV{'QUERY_STRING'; -#print "
"; -#print $Max; -#print "
"; -#print $PNo; -#print "
"; -#print $data; -#exit; - -my $Range; -if ( $PNo > 10 ) {$Range = 30*$PNo;} -else { $Range = 300+30*$PNo; } - -if ( $Max < 1 ) { $Max = 1; } -elsif ( $Max < 10 ) { $Max = 10; } -elsif ( $Max < 100 ) { $Max = 100; } +my @data =(\@xlabels,\@data11,\@data12); + +my $width; +my $height = 200; + +if ($xlab=~/^Concepts$/){ + $width=270; +} elsif ($xlab=~/^Problem\snumber$/){ + $width=450; +} else { + $width=($PNo==100) ? 800 : (120+$PNo*10); + $skip_x=5; + $bar_space=1; +} + +my $x_tick_offset = 0; +if ($skip_x > 1) { + $x_tick_offset = $skip_x - 1; +} -my $MyGraph = GD::Graph::bars->new($Range, 400); +my $MyGraph = GD::Graph::bars->new($width,$height); $MyGraph->set( - x_label => 'Problems #', - y_label => $Tag, - title => 'LON-CAPA Graphical Chart, Course: '.$cid, + x_label => $xlab, + y_label => $ylab, + x_label_position => 0.5, + long_ticks => 1, + tick_length => 0, + x_ticks => 0, + title => $Titr, y_max_value => $Max, - y_tick_number => 10, - y_label_skip => 1, - x_label_skip => 2, - - # colors - dclrs => [ qw(green lblue lyellow lpurple cyan lorange)], +# y_tick_number => $ytic, + y_label_skip => 5, + x_label_skip => $skip_x, + x_tick_offset => $x_tick_offset, + + dclrs => [ qw( lgreen dgreen lyellow lpurple cyan lorange)], - # shadows - bar_spacing => 4, - shadow_depth => 1, - shadowclr => 'dred', + bar_spacing => $bar_space, + cumulate => 2, + zero_axis => 1, + +# legend_placement => 'RT', + + fgclr => 'black', + boxclr => 'white', + accentclr => 'dblue', + valuesclr => '#ffff77', + l_margin => 10, + b_margin => 10, + r_margin => 10, + t_margin => 10, transparent => 0, ) or warn $MyGraph->error; -# Tell the server we are sending a gif graphic + +# Tell the server we are sending a png graphic print <plot(\@data)->png; undef $MyGraph; binmode(STDOUT); -open IMG,"|pngtopnm|ppmtogif"; # convert into a gif image -print IMG $BinaryData; # output image -$|=1; # be sure to flush before closing -close IMG; - - - - - - - - - - - - - - +#open IMG,"|pngtopnm|ppmtogif 2>/dev/null"; # convert into a gif image +#print IMG $BinaryData; # output image +#$|=1; # be sure to flush before closing +#close IMG; +print $BinaryData;