--- loncom/homework/randomlylabel.pm 2003/02/27 21:36:27 1.8 +++ loncom/homework/randomlylabel.pm 2004/02/11 21:52:56 1.12.2.1 @@ -2,7 +2,7 @@ # The LearningOnline Network with CAPA # randomlabel.png: composite together text and images into 1 image # -# $Id: randomlylabel.pm,v 1.8 2003/02/27 21:36:27 albertel Exp $ +# $Id: randomlylabel.pm,v 1.12.2.1 2004/02/11 21:52:56 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -50,7 +50,7 @@ sub get_image { GD::Image->trueColor(1); $image = GD::Image->new($imgsrc); } - if ($set_trans) { + if ($set_trans && defined($image)) { my $white=$image->colorExact(255,255,255); if ($white != -1) { $image->transparent($white); } } @@ -60,13 +60,12 @@ sub get_image { sub handler { my $r = shift; $r->content_type('image/png'); - my (undef,$token) = split(/=/,$ENV{'QUERY_STRING'}); - &Apache::loncommon::get_unprocessed_cgi( - &Apache::lonnet::unescape($ENV{'imagerequest.'.$token})); - my $image=&get_image($ENV{"form.BGIMG"},0); + $r->send_http_header; + my (undef,$id) = split(/=/,$ENV{'QUERY_STRING'}); + my $image=&get_image(&Apache::lonnet::unescape($ENV{"cgi.$id.BGIMG"}),0); if (! defined($image)) { - &Apache::lonnet::logthis('Unable to create image object for '. - $ENV{"form.BGIMG"}); + &Apache::lonnet::logthis('Unable to create image object for -'.$id.'-'. + $ENV{"cgi.$id.BGIMG"}); return OK; } #binmode(STDOUT); @@ -74,16 +73,47 @@ sub handler { if (!($black=$image->colorResolve(0,0,0))) { $black = $image->colorClosestHWB(0,0,0); } - for(my $i=0;$i<$ENV{"form.ICOUNT"};$i++) { - my $subimage=&get_image($ENV{"form.IMG$i"},1); - $image->copy($subimage,$ENV{"form.X$i"},$ENV{"form.Y$i"}, + for(my $i=0;$i<$ENV{"cgi.$id.ICOUNT"};$i++) { + my $subimage=&get_image(&Apache::lonnet::unescape($ENV{"cgi.$id.IMG$i"}),1); + if (!defined($subimage)) { + &Apache::lonnet::logthis('Unable to create image object for '. + $ENV{"cgi.$id.BGIMG"}); + next; + } + $image->copy($subimage,$ENV{"cgi.$id.IX$i"},$ENV{"cgi.$id.IY$i"}, 0,0,$subimage->getBounds()); } my $height=GD::Font->Giant->height; - for(my $i=0;$i<$ENV{"form.COUNT"};$i++) { - $image->string(gdGiantFont,$ENV{"form.X$i"},$ENV{"form.Y$i"}-$height, - $ENV{"form.LB$i"},$black); + for(my $i=0;$i<$ENV{"cgi.$id.COUNT"};$i++) { + $image->string(gdGiantFont,$ENV{"cgi.$id.X$i"}, + $ENV{"cgi.$id.Y$i"}-$height, + &Apache::lonnet::unescape($ENV{"cgi.$id.LB$i"}),$black); + } + for(my $i=0;$i<$ENV{"cgi.$id.LINECOUNT"};$i++) { + my ($x1,$y1,$x2,$y2,$color,$width)=split(':',$ENV{"cgi.$id.LINE$i"}); + my (undef,$red,undef,$green,undef,$blue)=split(/(..)/,$color); + $red=hex($red);$green=hex($green);$blue=hex($blue); + my $imcolor; + if (!($imcolor = $image->colorResolve($red,$green,$blue))) { + $imcolor = $image->colorClosestHWB($red,$green,$blue); + } + $image->setThickness($width); + $image->line($x1,$y1,$x2,$y2,$imcolor); + } + for(my $i=0;$i<$ENV{"cgi.$id.BOXCOUNT"};$i++) { + my ($x1,$y1,$x2,$y2,$color,$width)=split(':',$ENV{"cgi.$id.BOX$i"}); + if ($x1 > $x2) { my $temp=$x1;$x1=$x2;$x2=$temp; } + if ($y1 > $y2) { my $temp=$y1;$y1=$y2;$y2=$temp; } + my (undef,$red,undef,$green,undef,$blue)=split(/(..)/,$color); + $red=hex($red);$green=hex($green);$blue=hex($blue); + my $imcolor; + if (!($imcolor = $image->colorResolve($red,$green,$blue))) { + $imcolor = $image->colorClosestHWB($red,$green,$blue); + } + $image->setThickness($width); + $image->rectangle($x1,$y1,$x2,$y2,$imcolor); } + $image->setThickness(1); $r->print($image->png); return OK; }