version 1.7, 2005/02/17 09:01:03
|
version 1.15, 2008/10/13 14:06:47
|
Line 25
|
Line 25
|
package Apache::imagechoice; |
package Apache::imagechoice; |
use strict; |
use strict; |
use Apache::Constants qw(:common :http); |
use Apache::Constants qw(:common :http); |
|
use Apache::lonnet; |
|
use Apache::lonlocal; |
|
use LONCAPA; |
|
|
|
|
sub deletedata { |
sub deletedata { |
my ($id)=@_; |
my ($id)=@_; |
Line 33 sub deletedata {
|
Line 36 sub deletedata {
|
} |
} |
|
|
sub closewindow { |
sub closewindow { |
my ($r,$output,$filename,$needimage)=@_; |
my ($r,$output,$filename,$needimage,$display)=@_; |
if ($needimage) { |
if ($needimage) { |
$needimage="<img name=\"pickimg\" src=\"$filename\" />"; |
$needimage="<img name=\"pickimg\" src=\"$filename\" />"; |
} |
} |
$r->print(<<"ENDSUBM"); |
my $js=<<"ENDSUBM"; |
<html> |
<script type="text/javascript"> |
<script> |
|
function submitthis() { |
function submitthis() { |
$output |
$output |
self.close(); |
self.close(); |
} |
} |
</script> |
</script> |
<body bgcolor="#FFFFFF" onLoad="submitthis()"> |
ENDSUBM |
|
|
|
my $start_page = |
|
&Apache::loncommon::start_page('Close Window',$js, |
|
{'bgcolor' => '#FFFFFF', |
|
'only_body' => 1, |
|
'add_entries' => { |
|
onload => 'submitthis();'},}); |
|
|
|
my $end_page = |
|
&Apache::loncommon::end_page(); |
|
|
|
$r->print(<<"ENDSUBM"); |
|
$start_page |
<h3>Position Selected</h3> |
<h3>Position Selected</h3> |
|
$display |
$needimage |
$needimage |
</body> |
$end_page |
</html> |
|
ENDSUBM |
ENDSUBM |
} |
} |
|
|
sub storedata { |
sub storedata { |
my ($r,$type,$filename,$id)=@_; |
my ($r,$type,$filename,$id)=@_; |
|
|
my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"}); |
my (undef,@coords)=split(':',$env{"imagechoice.$id.coords"}); |
|
|
my ($output,$needimage); |
my ($output,$needimage); |
|
|
if ($ENV{"imagechoice.$id.formwidth"}) { |
if ($env{"imagechoice.$id.formwidth"}) { |
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formwidth"}.'.value=document.pickimg.width;'; |
$output.='opener.document.forms.'.$env{"imagechoice.$id.formname"}.'.'.$env{"imagechoice.$id.formwidth"}.'.value=document.pickimg.width;'; |
$needimage=1; |
$needimage=1; |
} |
} |
if ($ENV{"imagechoice.$id.formheight"}) { |
if ($env{"imagechoice.$id.formheight"}) { |
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formheight"}.'.value=document.pickimg.height;'; |
$output.='opener.document.forms.'.$env{"imagechoice.$id.formname"}.'.'.$env{"imagechoice.$id.formheight"}.'.value=document.pickimg.height;'; |
$needimage=1; |
$needimage=1; |
} |
} |
|
|
|
my $display; |
if ($type eq 'point') { |
if ($type eq 'point') { |
my (undef,$x,$y)=split(':',$ENV{"imagechoice.$id.coords"}); |
my (undef,$x,$y)=split(':',$env{"imagechoice.$id.coords"}); |
if ($ENV{"imagechoice.$id.formx"}) { |
if ($env{"imagechoice.$id.formx"}) { |
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formx"}.'.value='.$x.';'; |
$output.='opener.document.forms.'.$env{"imagechoice.$id.formname"}.'.'.$env{"imagechoice.$id.formx"}.'.value='.$x.';'; |
|
$display.="<p>The X coordinate is $x</p>\n"; |
} |
} |
if ($ENV{"imagechoice.$id.formy"}) { |
if ($env{"imagechoice.$id.formy"}) { |
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formy"}.'.value='.$y.';'; |
$output.='opener.document.forms.'.$env{"imagechoice.$id.formname"}.'.'.$env{"imagechoice.$id.formy"}.'.value='.$y.';'; |
|
$display.="<p>The Y coordinate is $y</p>\n"; |
} |
} |
} elsif ($type eq 'polygon' or $type eq 'box') { |
} elsif ($type eq 'polygon' or $type eq 'box') { |
my $coordstr; |
my $coordstr; |
Line 83 sub storedata {
|
Line 101 sub storedata {
|
$coordstr.='('.shift(@coords).','.shift(@coords).')-'; |
$coordstr.='('.shift(@coords).','.shift(@coords).')-'; |
} |
} |
chop($coordstr); |
chop($coordstr); |
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formcoord"}.'.value="'.$coordstr.'";'; |
$display.="<p>The selected coordinates are <tt>$coordstr</tt></p>\n"; |
|
$output.='opener.document.forms.'.$env{"imagechoice.$id.formname"}.'.'.$env{"imagechoice.$id.formcoord"}.'.value="'.$coordstr.'";'; |
|
} |
|
if ($display) { |
|
$display.="<p>If this window fails to close you may need to manually replace the old coordinates with the above value.</p>\n"; |
} |
} |
|
|
&deletedata($id); |
&deletedata($id); |
&closewindow($r,$output,$filename,$needimage); |
&closewindow($r,$output,$filename,$needimage,$display); |
} |
} |
|
|
sub getcoord { |
sub getcoord { |
my ($r,$type,$filename,$id)=@_; |
my ($r,$type,$filename,$id)=@_; |
my $heading='Select Position on Image'; |
my $heading=&mt('Select Position on Image'); |
my $nextstage=''; |
my $nextstage=''; |
if ($type eq 'box') { |
if ($type eq 'box') { |
my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"}); |
my (undef,@coords)=split(':',$env{"imagechoice.$id.coords"}); |
my $step=scalar(@coords)/2; |
my $step=scalar(@coords)/2; |
if ($step == 0) { |
if ($step == 0) { |
$heading='Select First Coordinate on Image'; |
$heading=&mt('Select First Coordinate on Image'); |
#$nextstage='<input type="hidden" name="type" value="pairtwo" />'; |
#$nextstage='<input type="hidden" name="type" value="pairtwo" />'; |
} elsif ($step == 1) { |
} elsif ($step == 1) { |
$heading='Select Second Coordinate on Image'; |
$heading=&mt('Select Second Coordinate on Image'); |
#$nextstage='<input type="hidden" name="type" value="pairthree" />'; |
#$nextstage='<input type="hidden" name="type" value="pairthree" />'; |
} else { |
} else { |
$heading='Select Finish to store selection.'; |
$heading=&mt('Select Finish to save selection'); |
$nextstage='<input type="submit" name="finish" value="Finish" />'; |
$nextstage='<input type="submit" name="finish" value="'.&mt('Finish').'" />'; |
} |
} |
} elsif ($type eq 'polygon') { |
} elsif ($type eq 'polygon') { |
$heading='Enter Coordinate or click finish to close Polygon'; |
$heading=&mt('Enter Coordinate or click finish to close Polygon'); |
$nextstage='<input type="submit" name="finish" value="Finish" />'; |
$nextstage='<input type="submit" name="finish" value="'.&mt('Finish').'" />'; |
} elsif ($type eq 'point') { |
} elsif ($type eq 'point') { |
$heading='Click to select a Coordinate or click Finish to store current selection.'; |
$heading=&mt('Click to select a Coordinate or click Finish to save current selection'); |
$nextstage='<input type="submit" name="finish" value="Finish" />'; |
$nextstage='<input type="submit" name="finish" value="'.&mt('Finish').'" />'; |
} |
} |
|
|
|
my $start_page = |
|
&Apache::loncommon::start_page('Get Coordinates',undef, |
|
{'bgcolor' => '#FFFFFF', |
|
'only_body' => 1,}); |
|
|
|
my $end_page = |
|
&Apache::loncommon::end_page(); |
|
my $canceltext=&mt('Cancel'); |
$r->print(<<"END"); |
$r->print(<<"END"); |
<html> |
$start_page |
<body bgcolor="#FFFFFF"> |
|
<h3>$heading</h3> |
<h3>$heading</h3> |
<form method="POST" action="/adm/imagechoice?token=$id"> |
<form method="POST" action="/adm/imagechoice?token=$id"> |
$nextstage |
$nextstage |
<input type="submit" name="cancel" value="Cancel" /> |
<input type="submit" name="cancel" value="$canceltext" /> |
<br /> |
<br /> |
<input name="image" type="image" src="$filename" /> |
<input name="image" type="image" src="$filename" /> |
</form> |
</form> |
</body> |
$end_page |
</html> |
|
END |
END |
} |
} |
|
|
sub savecoord { |
sub savecoord { |
my ($id,$type)=@_; |
my ($id,$type)=@_; |
if (defined($ENV{"form.image.x"}) && defined($ENV{"form.image.y"})) { |
if (defined($env{"form.image.x"}) && defined($env{"form.image.y"})) { |
my $data; |
my $data; |
if ($type eq 'point') { |
if ($type eq 'point') { |
$data=join(':',(undef,$ENV{"form.image.x"},$ENV{"form.image.y"})); |
$data=join(':',(undef,$env{"form.image.x"},$env{"form.image.y"})); |
} else { |
} else { |
$data=join(':',($ENV{"imagechoice.$id.coords"}, |
$data=join(':',($env{"imagechoice.$id.coords"}, |
$ENV{"form.image.x"},$ENV{"form.image.y"})); |
$env{"form.image.x"},$env{"form.image.y"})); |
} |
} |
&Apache::lonnet::appenv("imagechoice.$id.coords"=>$data); |
&Apache::lonnet::appenv({"imagechoice.$id.coords"=>$data}); |
} |
} |
return int(scalar(split(':',$ENV{"imagechoice.$id.coords"}))/2); |
return int(scalar(split(':',$env{"imagechoice.$id.coords"}))/2); |
} |
} |
|
|
sub add_obj { |
sub add_obj { |
Line 174 sub drawX {
|
Line 202 sub drawX {
|
|
|
sub drawPolygon { |
sub drawPolygon { |
my ($data,$id,$imid)=@_; |
my ($data,$id,$imid)=@_; |
my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"}); |
my (undef,@coords)=split(':',$env{"imagechoice.$id.coords"}); |
my $coordstr; |
my $coordstr; |
while (@coords) { |
while (@coords) { |
$coordstr.='('.shift(@coords).','.shift(@coords).')-'; |
$coordstr.='('.shift(@coords).','.shift(@coords).')-'; |
Line 190 sub drawPolygon {
|
Line 218 sub drawPolygon {
|
|
|
sub drawBox { |
sub drawBox { |
my ($data,$id,$imid)=@_; |
my ($data,$id,$imid)=@_; |
my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"}); |
my (undef,@coords)=split(':',$env{"imagechoice.$id.coords"}); |
if (scalar(@coords) < 4) { return ''; } |
if (scalar(@coords) < 4) { return ''; } |
my $width = 1; |
my $width = 1; |
my $extrawidth = 2; |
my $extrawidth = 2; |
Line 202 sub drawBox {
|
Line 230 sub drawBox {
|
sub drawimage { |
sub drawimage { |
my ($r,$type,$filename,$id)=@_; |
my ($r,$type,$filename,$id)=@_; |
my $imid=&Apache::loncommon::get_cgi_id(); |
my $imid=&Apache::loncommon::get_cgi_id(); |
my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"}); |
my (undef,@coords)=split(':',$env{"imagechoice.$id.coords"}); |
if (scalar(@coords) < 2) { return &Apache::lonnet::hreflocation('',$filename); } |
if (scalar(@coords) < 2) { return &Apache::lonnet::hreflocation('',$filename); } |
my %data; |
my %data; |
$data{"cgi.$imid.BGIMG"}=$filename; |
$data{"cgi.$imid.BGIMG"}=$filename; |
Line 211 sub drawimage {
|
Line 239 sub drawimage {
|
&drawX(\%data,$imid,$x,$y); |
&drawX(\%data,$imid,$x,$y); |
if ($type eq "polygon") { &drawPolygon(\%data,$id,$imid); } |
if ($type eq "polygon") { &drawPolygon(\%data,$id,$imid); } |
if ($type eq "box") { &drawBox(\%data,$id,$imid); } |
if ($type eq "box") { &drawBox(\%data,$id,$imid); } |
&Apache::lonnet::appenv(%data); |
&Apache::lonnet::appenv(\%data); |
return "/adm/randomlabel.png?token=$imid" |
return "/adm/randomlabel.png?token=$imid" |
} |
} |
|
|
Line 221 sub handler {
|
Line 249 sub handler {
|
$r->send_http_header; |
$r->send_http_header; |
my %data; |
my %data; |
my (undef,$id) = split(/=/,$ENV{'QUERY_STRING'}); |
my (undef,$id) = split(/=/,$ENV{'QUERY_STRING'}); |
my $filename = &Apache::lonnet::unescape($ENV{"imagechoice.$id.file"}); |
my $filename = &unescape($env{"imagechoice.$id.file"}); |
my $formname = $ENV{"imagechoice.$id.formname"}; |
my $formname = $env{"imagechoice.$id.formname"}; |
if ($ENV{'form.cancel'} eq 'Cancel') { |
if ($env{'form.cancel'} eq &mt('Cancel')) { |
&deletedata($id); |
&deletedata($id); |
&closewindow($r,'',$filename); |
&closewindow($r,'',$filename); |
return OK; |
return OK; |
} |
} |
my $type=$ENV{"imagechoice.$id.type"}; |
my $type=$env{"imagechoice.$id.type"}; |
if (defined($ENV{'form.type'})) { $type=$ENV{'form.type'}; } |
if (defined($env{'form.type'})) { $type=$env{'form.type'}; } |
my $numcoords=&savecoord($id,$type); |
my $numcoords=&savecoord($id,$type); |
my $imurl=&drawimage($r,$type,$filename,$id); |
my $imurl=&drawimage($r,$type,$filename,$id); |
if (($ENV{'form.finish'} eq 'Finish')) { |
if ($env{'form.finish'} eq &mt('Finish')) { |
&storedata($r,$type,$imurl,$id); |
&storedata($r,$type,$imurl,$id); |
} else { |
} else { |
&getcoord($r,$type,$imurl,$id); |
&getcoord($r,$type,$imurl,$id); |