--- loncom/homework/imagechoice.pm 2004/01/12 19:53:54 1.2
+++ loncom/homework/imagechoice.pm 2004/09/09 20:35:10 1.6
@@ -1,4 +1,4 @@
-# $Id: imagechoice.pm,v 1.2 2004/01/12 19:53:54 albertel Exp $
+# $Id: imagechoice.pm,v 1.6 2004/09/09 20:35:10 albertel Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -29,11 +29,14 @@ use Apache::Constants qw(:common :http);
sub deletedata {
my ($id)=@_;
- &Apache::lonnet::delenv("imagechoice\\.$id");
+ &Apache::lonnet::delenv("imagechoice\\.$id\\.coords");
}
sub closewindow {
- my ($r,$output,$filename)=@_;
+ my ($r,$output,$filename,$needimage)=@_;
+ if ($needimage) {
+ $needimage="";
+ }
$r->print(<<"ENDSUBM");
Position Selected
-
+$needimage
ENDSUBM
}
sub storedata {
- my ($r,$mode,$filename,$id)=@_;
+ my ($r,$type,$filename,$id)=@_;
my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"});
- my $output;
+ my ($output,$needimage);
if ($ENV{"imagechoice.$id.formwidth"}) {
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formwidth"}.'.value=document.pickimg.width;';
+ $needimage=1;
}
if ($ENV{"imagechoice.$id.formheight"}) {
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formheight"}.'.value=document.pickimg.height;';
+ $needimage=1;
}
- if ((defined($ENV{"imagechoice.$id.x"})) && (defined($ENV{"imagechoice.$id.y"})) &&
- ($mode ne 'pairtwo') && ($mode ne 'pairthree')) {
- my $output='';
+ if ($type eq 'point') {
+ my (undef,$x,$y)=split(':',$ENV{"imagechoice.$id.coords"});
if ($ENV{"imagechoice.$id.formx"}) {
- $output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formx"}.
- '.value='.$ENV{"imagechoice.$id.x"}.';';
+ $output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formx"}.'.value='.$x.';';
}
if ($ENV{"imagechoice.$id.formy"}) {
- $output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formy"}.
- '.value='.$ENV{"imagechoice.$id.y"}.';';
- }
- } elsif ($mode eq 'pairthree') {
- my $output='';
- my $outputpair='('.$ENV{"imagechoice.$id.selx"}.','.$ENV{"imagechoice.$id.sely"}.')-('.$ENV{"imagechoice.$id.x"}.','.$ENV{"imagechoice.$id.y"}.')';
-
- if ($ENV{"imagechoice.$id.formcoord"}) {
- $output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formcoord"}.
- '.value="'.$outputpair.'";';
+ $output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formy"}.'.value='.$y.';';
}
- } elsif ($mode eq 'polygon') {
+ } elsif ($type eq 'polygon' or $type eq 'box') {
my $coordstr;
while (@coords) {
$coordstr.='('.shift(@coords).','.shift(@coords).')-';
@@ -91,28 +85,39 @@ sub storedata {
chop($coordstr);
$output.='opener.document.forms.'.$ENV{"imagechoice.$id.formname"}.'.'.$ENV{"imagechoice.$id.formcoord"}.'.value="'.$coordstr.'";';
}
+
&deletedata($id);
- &closewindow($r,$output,$filename);
+ &closewindow($r,$output,$filename,$needimage);
}
sub getcoord {
- my ($r,$mode,$filename,$id)=@_;
- my $heading='Position';
+ my ($r,$type,$filename,$id)=@_;
+ my $heading='Select Position on Image';
my $nextstage='';
- if ($mode eq 'pair') {
- $heading='First Coordinate';
- $nextstage='';
- } elsif ($mode eq 'pairtwo') {
- $heading='Second Coordinate';
- $nextstage='';
- } elsif ($mode eq 'polygon') {
+ if ($type eq 'box') {
+ my (undef,@coords)=split(':',$ENV{"imagechoice.$id.coords"});
+ my $step=scalar(@coords)/2;
+ if ($step == 0) {
+ $heading='Select First Coordinate on Image';
+ #$nextstage='';
+ } elsif ($step == 1) {
+ $heading='Select Second Coordinate on Image';
+ #$nextstage='';
+ } else {
+ $heading='Select Finish to store selection.';
+ $nextstage='';
+ }
+ } elsif ($type eq 'polygon') {
$heading='Enter Coordinate or click finish to close Polygon';
$nextstage='';
+ } elsif ($type eq 'point') {
+ $heading='Click to select a Coordinate or click Finish to store current selection.';
+ $nextstage='';
}
$r->print(<<"END");
-Select $heading on Image
+$heading