--- loncom/cgi/graph.png 2003/03/26 21:52:37 1.21 +++ loncom/cgi/graph.png 2003/10/09 15:56:41 1.23 @@ -1,6 +1,6 @@ #!/usr/bin/perl # -# $Id: graph.png,v 1.21 2003/03/26 21:52:37 matthew Exp $ +# $Id: graph.png,v 1.23 2003/10/09 15:56:41 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -25,17 +25,35 @@ # http://www.lon-capa.org/ # # The LearningOnline Network with CAPA -# Behrouz Minaei -# YEAR=2001 -# 9/13/01, 9/25/01, 10/6/01, 10/9/01, 12/25/01 -# YEAR=2002 -# 2/1/, 5/13, 5/15 -# YEAR=2003 -# 1/7/, 1/13 +# # 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; @@ -48,7 +66,7 @@ sub unescape { } $|=1; # Autoflush after each print/write -my ($Titr,$xlab,$ylab,$Max,$PNo,$data1,$data2)=split(/&/,$ENV{'QUERY_STRING'}); +my ($Titr,$xlab,$ylab,$Max,$NumBars,$data1,$data2)=split(/&/,$ENV{'QUERY_STRING'}); $Titr = &unescape($Titr); $xlab = &unescape($xlab); $ylab = &unescape($ylab); @@ -56,37 +74,47 @@ $ylab = &unescape($ylab); my @data11=split(/\,/,$data1); my @data12=split(/\,/,$data2); my $skip_x = 1; -my $bar_space=10; +#my $bar_space=1; +my $bar_width=10; my @xlabels; -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; - } -} +for (my $nIdx=0; $nIdx<$NumBars; $nIdx++ ) { + $xlabels[$nIdx]=$nIdx+1; +} + +#if ($Titr =~ /^Percentage$/){ +# for (my $nIdx=0; $nIdx<$NumBars; $nIdx++ ) { +# $xlabels[$nIdx]=$nIdx; +# } +# @data11=(); +# @data11=split(/\,/,$data2); +# @data12=(); +# $Titr = ''; +#} else { +#} my @data =(\@xlabels,\@data11,\@data12); my $width; my $height = 200; -if ($xlab=~/^Concepts$/){ - $width=270; -} elsif ($xlab=~/^Problem\snumber$/){ - $width=450; +if ($NumBars < 10) { + $width = 120+$NumBars*15; + $skip_x = 1; + $bar_width = 15; +} elsif ($NumBars <= 25) { + $width = 120+$NumBars*11; + $skip_x = 5; + $bar_width = 8; +} elsif ($NumBars <= 50) { + $width = 120+$NumBars*8; + $skip_x = 5; + $bar_width = 4; } else { - $width=($PNo==100) ? 800 : (120+$PNo*10); - $skip_x=5; - $bar_space=1; + $width = 120+$NumBars*8; + $skip_x = 5; + $bar_width = 4; } my $x_tick_offset = 0; @@ -106,13 +134,13 @@ $MyGraph->set( title => $Titr, y_max_value => $Max, # y_tick_number => $ytic, - y_label_skip => 5, +# y_label_skip => 5, x_label_skip => $skip_x, x_tick_offset => $x_tick_offset, dclrs => [ qw( lgreen dgreen lyellow lpurple cyan lorange)], - - bar_spacing => $bar_space, + bar_width => $bar_width, +# bar_spacing => $bar_space, cumulate => 2, zero_axis => 1,