Diff for /loncom/cgi/graph.png between versions 1.8 and 1.22

version 1.8, 2002/01/23 12:39:19 version 1.22, 2003/10/08 15:44:49
Line 25 Line 25
 # http://www.lon-capa.org/  # http://www.lon-capa.org/
 #  #
 # The LearningOnline Network with CAPA  # The LearningOnline Network with CAPA
 # Behrouz Minaei  
 # YEAR=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.
 #   # 
 ####   #### 
   
   =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 strict;
 use GD::Graph::bars3d;  use GD::Graph::bars;
 use GD::Graph::colour;  use GD::Graph::colour;
 use GD::Graph::Data;  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  $|=1;   # Autoflush after each print/write
 my ($cid, $Tag, $Max, $PNo, $data) = split(/&/,$ENV{'QUERY_STRING'});  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;  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);  
   
 my $Range;  my @data =(\@xlabels,\@data11,\@data12);
 if ( $PNo > 10 ) {$Range = 30*$PNo;}  
 else { $Range = 300+30*$PNo; }  my $width;
   my $height = 200;
   
 $Max+=(10 - $Max % 10);  if ($xlab=~/^Concepts$/){
 $Max=int($Max);      $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::bars3d->new($Range, 400);  my $MyGraph = GD::Graph::bars->new($width,$height);
   
 $MyGraph->set(   $MyGraph->set( 
     x_label         => 'Problems #',      x_label         => $xlab,
     y_label         => $Tag,      y_label         => $ylab,
     title           => 'LON-CAPA Graphical Chart, Course: '.$cid,      x_label_position => 0.5,
       long_ticks      => 1,
       tick_length     => 0,
       x_ticks         => 0,
       title           => $Titr,
     y_max_value     => $Max,      y_max_value     => $Max,
     y_tick_number   => 10,  #    y_tick_number   => $ytic,
     y_label_skip    => 1,      y_label_skip    => 5,
     x_label_skip    => 2,      x_label_skip    => $skip_x,   
           x_tick_offset   => $x_tick_offset,
     # colors  
     dclrs           => [ qw( green lblue lyellow lpurple cyan lorange)],      dclrs           => [ qw( lgreen dgreen lyellow lpurple cyan lorange)],
           
     # shadows      bar_spacing     => $bar_space,
     bar_spacing     => 4,      cumulate        => 2,
     shadow_depth    => 1,      zero_axis        => 1,
     shadowclr       => 'dred',  
   #    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,      transparent     => 0,
 ) or warn $MyGraph->error;   ) or warn $MyGraph->error; 
   
 # Tell the server we are sending a gif graphic  
   # Tell the server we are sending a png graphic
 print <<END;  print <<END;
 Content-type: image/gif  Content-type: image/png
   
 END  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 2>/dev/null"; # 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;
   print $BinaryData;

Removed from v.1.8  
changed lines
  Added in v.1.22


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>