--- loncom/cgi/graph.png 2002/11/01 22:12:46 1.15 +++ loncom/cgi/graph.png 2003/03/26 21:52:37 1.21 @@ -1,6 +1,6 @@ #!/usr/bin/perl # -# $Id: graph.png,v 1.15 2002/11/01 22:12:46 minaeibi Exp $ +# $Id: graph.png,v 1.21 2003/03/26 21:52:37 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -30,6 +30,8 @@ # 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. # #### @@ -39,49 +41,78 @@ use GD::Graph::bars; use GD::Graph::colour; use GD::Graph::Data; +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 @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,\@data11,\@data12); -my $Range1; -my $Range2; +my $width; +my $height = 200; if ($xlab=~/^Concepts$/){ - $Range1=270; - $Range2=200; + $width=270; +} elsif ($xlab=~/^Problem\snumber$/){ + $width=450; } else { - $Range1=450;#250+30*$PNo; - $Range2=200; + $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($Range1,$Range2); +my $MyGraph = GD::Graph::bars->new($width,$height); $MyGraph->set( 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 => $ytic, - y_label_skip => 1, + 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 => 10, + bar_spacing => $bar_space, cumulate => 2, zero_axis => 1, @@ -99,30 +130,18 @@ $MyGraph->set( transparent => 0, ) or warn $MyGraph->error; -#if ($xlab=~/^Concepts$/){ -# $MyGraph->set_legend( 'Correct Answers', 'Incorrect Answers'); -#} - -# Tell the server we are sending a gif graphic +# Tell the server we are sending a png graphic print <set_y_label_font('/home/httpd/cgi-bin/cetus.ttf', 16); -#$MyGraph->set_x_label_font('/home/httpd/cgi-bin/cetus.ttf', 16); -#$MyGraph->set_y_axis_font('/home/httpd/cgi-bin/cetus.ttf', 12); -#$MyGraph->set_x_axis_font('/home/httpd/cgi-bin/cetus.ttf', 12); -#$MyGraph->set_title_font('/home/httpd/cgi-bin/cetus.ttf', 18); -#$MyGraph->set_legend_font('/home/httpd/cgi-bin/cetus.ttf', 10); -#$MyGraph->set_values_font('/home/httpd/cgi-bin/cetus.ttf', 10); - - my $BinaryData=$MyGraph->plot(\@data)->png; undef $MyGraph; binmode(STDOUT); -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; +#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;