Annotation of loncom/homework/randomlylabel.pm, revision 1.13

1.1       albertel    1: #!/usr/bin/perl
                      2: # The LearningOnline Network with CAPA
                      3: # randomlabel.png: composite together text and images into 1 image
                      4: #
1.13    ! albertel    5: # $Id: randomlylabel.pm,v 1.12 2003/11/11 00:39:33 albertel Exp $
1.1       albertel    6: #
                      7: # Copyright Michigan State University Board of Trustees
                      8: #
                      9: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                     10: #
                     11: # LON-CAPA is free software; you can redistribute it and/or modify
                     12: # it under the terms of the GNU General Public License as published by
                     13: # the Free Software Foundation; either version 2 of the License, or
                     14: # (at your option) any later version.
                     15: #
                     16: # LON-CAPA is distributed in the hope that it will be useful,
                     17: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     18: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     19: # GNU General Public License for more details.
                     20: #
                     21: # You should have received a copy of the GNU General Public License
                     22: # along with LON-CAPA; if not, write to the Free Software
                     23: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     24: #
                     25: # /home/httpd/html/adm/gpl.txt
                     26: #
                     27: # http://www.lon-capa.org/
                     28: #
                     29: ###
                     30: 
                     31: package Apache::randomlylabel;
                     32: 
                     33: use strict;
                     34: use Image::Magick;
                     35: use Apache::Constants qw(:common);
                     36: use Apache::loncommon();
1.13    ! albertel   37: use GD();
        !            38: use GD::Polyline();
1.3       albertel   39: 
                     40: sub get_image {
                     41:     my ($imgsrc,$set_trans)=@_;
                     42:     my $image;
1.5       www        43:     if ($imgsrc !~ /\.(png|jpg|jpeg)$/i) {
1.3       albertel   44: 	my $conv_image = Image::Magick->new;
                     45: 	my $current_figure = $conv_image->Read('filename'=>$imgsrc);
                     46: 	$conv_image->Set('magick'=>'png');
                     47: 	my @blobs=$conv_image->ImageToBlob();
                     48: 	undef $conv_image;
                     49: 	$image = GD::Image->new($blobs[0]);
                     50:     } else {
1.6       albertel   51: 	GD::Image->trueColor(1);
1.3       albertel   52: 	$image = GD::Image->new($imgsrc);
                     53:     }
1.9       albertel   54:     if ($set_trans && defined($image)) {
1.3       albertel   55: 	my $white=$image->colorExact(255,255,255);
                     56: 	if ($white != -1) { $image->transparent($white); }
                     57:     }
                     58:     return $image;
                     59: }
1.1       albertel   60: 
                     61: sub handler {
                     62:     my $r = shift;
                     63:     $r->content_type('image/png');
1.11      albertel   64:     my (undef,$id) = split(/=/,$ENV{'QUERY_STRING'});
                     65:     my $image=&get_image(&Apache::lonnet::unescape($ENV{"cgi.$id.BGIMG"}),0);
1.4       matthew    66:     if (! defined($image)) {
1.11      albertel   67:         &Apache::lonnet::logthis('Unable to create image object for -'.$id.'-'.
                     68: 				 $ENV{"cgi.$id.BGIMG"});
1.4       matthew    69:         return OK;
                     70:     }
1.1       albertel   71:     #binmode(STDOUT);
1.8       albertel   72:     my $black;
                     73:     if (!($black=$image->colorResolve(0,0,0))) {
                     74: 	$black = $image->colorClosestHWB(0,0,0);
                     75:     }
1.11      albertel   76:     for(my $i=0;$i<$ENV{"cgi.$id.ICOUNT"};$i++) {
                     77: 	my $subimage=&get_image(&Apache::lonnet::unescape($ENV{"cgi.$id.IMG$i"}),1);
1.9       albertel   78: 	if (!defined($subimage)) {
                     79:             &Apache::lonnet::logthis('Unable to create image object for '.
1.11      albertel   80:                                  $ENV{"cgi.$id.BGIMG"});
1.9       albertel   81:             next;
                     82:         }
1.11      albertel   83: 	$image->copy($subimage,$ENV{"cgi.$id.IX$i"},$ENV{"cgi.$id.IY$i"},
1.3       albertel   84: 		     0,0,$subimage->getBounds());
1.1       albertel   85:     }
1.3       albertel   86:     my $height=GD::Font->Giant->height;
1.11      albertel   87:     for(my $i=0;$i<$ENV{"cgi.$id.COUNT"};$i++) {
1.13    ! albertel   88: 	$image->string(GD::gdGiantFont,$ENV{"cgi.$id.X$i"},
1.11      albertel   89: 		       $ENV{"cgi.$id.Y$i"}-$height,
                     90: 		       &Apache::lonnet::unescape($ENV{"cgi.$id.LB$i"}),$black);
                     91:     }
                     92:     for(my $i=0;$i<$ENV{"cgi.$id.LINECOUNT"};$i++) {
                     93: 	my ($x1,$y1,$x2,$y2,$color,$width)=split(':',$ENV{"cgi.$id.LINE$i"});
1.10      albertel   94: 	my (undef,$red,undef,$green,undef,$blue)=split(/(..)/,$color);
                     95: 	$red=hex($red);$green=hex($green);$blue=hex($blue);
                     96: 	my $imcolor;
                     97: 	if (!($imcolor = $image->colorResolve($red,$green,$blue))) {
                     98: 	    $imcolor = $image->colorClosestHWB($red,$green,$blue);
                     99: 	}
                    100: 	$image->setThickness($width);
                    101:        	$image->line($x1,$y1,$x2,$y2,$imcolor);
1.12      albertel  102:     }
                    103:     for(my $i=0;$i<$ENV{"cgi.$id.BOXCOUNT"};$i++) {
                    104: 	my ($x1,$y1,$x2,$y2,$color,$width)=split(':',$ENV{"cgi.$id.BOX$i"});
                    105: 	if ($x1 > $x2) { my $temp=$x1;$x1=$x2;$x2=$temp; }
                    106: 	if ($y1 > $y2) { my $temp=$y1;$y1=$y2;$y2=$temp; }
                    107: 	my (undef,$red,undef,$green,undef,$blue)=split(/(..)/,$color);
                    108: 	$red=hex($red);$green=hex($green);$blue=hex($blue);
                    109: 	my $imcolor;
                    110: 	if (!($imcolor = $image->colorResolve($red,$green,$blue))) {
                    111: 	    $imcolor = $image->colorClosestHWB($red,$green,$blue);
                    112: 	}
                    113: 	$image->setThickness($width);
                    114:        	$image->rectangle($x1,$y1,$x2,$y2,$imcolor);
1.13    ! albertel  115:     }
        !           116:     for(my $i=0;$i<$ENV{"cgi.$id.POLYCOUNT"};$i++) {
        !           117: 	my ($color,$width,$open)=split(':',$ENV{"cgi.$id.POLYOPT$i"});
        !           118: 	my (undef,$red,undef,$green,undef,$blue)=split(/(..)/,$color);
        !           119: 	$red=hex($red);$green=hex($green);$blue=hex($blue);
        !           120: 	my $imcolor;
        !           121: 	if (!($imcolor = $image->colorResolve($red,$green,$blue))) {
        !           122: 	    $imcolor = $image->colorClosestHWB($red,$green,$blue);
        !           123: 	}
        !           124: 	my $polygon;
        !           125: 	if ($open) {
        !           126: 	    $polygon = new GD::Polyline;
        !           127: 	} else {
        !           128: 	    $polygon = new GD::Polygon;
        !           129: 	}
        !           130: 	foreach my $coord (split('-',$ENV{"cgi.$id.POLY$i"})) {
        !           131: 	    my ($x,$y)=($coord=~m/\(([0-9]+),([0-9]+)\)/);
        !           132: 	    $polygon->addPt($x,$y);
        !           133: 	}
        !           134: 	if ($open) {
        !           135: 	    $image->polydraw($polygon,$imcolor);
        !           136: 	} else {
        !           137: 	    $image->polygon($polygon,$imcolor);
        !           138: 	}
1.10      albertel  139:     }
                    140:     $image->setThickness(1);
1.3       albertel  141:     $r->print($image->png);
1.1       albertel  142:     return OK;
                    143: }
                    144: 
                    145: 1;

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