--- loncom/homework/imageresponse.pm 2008/03/12 02:46:53 1.93 +++ loncom/homework/imageresponse.pm 2010/02/28 23:37:44 1.99 @@ -2,7 +2,7 @@ # The LearningOnline Network with CAPA # image click response style # -# $Id: imageresponse.pm,v 1.93 2008/03/12 02:46:53 raeburn Exp $ +# $Id: imageresponse.pm,v 1.99 2010/02/28 23:37:44 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -29,6 +29,87 @@ #FIXME LATER assumes multiple possible submissions but only one is possible #currently + +=head1 NAME + +Apache::imageresponse + +=head1 SYNOPSIS + +Coordinates the response to clicking an image. + +This is part of the LearningOnline Network with CAPA project +described at http://www.lon-capa.org. + +=head1 SUBROUTINES + +=over + +=item start_imageresponse() + +=item end_imageresponse() + +=item start_foilgroup() + +=item getfoilcounts() + +=item whichfoils() + +=item prep_image() + +=item draw_image() + +=item displayfoils() + +=item format_prior_response() + +=item display_answers() + +=item clean_up_image() + +=item gradefoils() + +=item stringify_submission() + +=item get_submission() + +=item end_foilgroup() + +=item start_conceptgroup() + +=item end_conceptgroup() + +=item insert_foil() + +=item start_foil() + +=item end_foil() + +=item start_text() + +=item end_text() + +=item start_image() + +=item end_image() + +=item start_rectangle() + +=item grade_rectangle() + +=item end_rectangle() + +=item start_polygon() + +=item grade_polygon() + +=item end_polygon() + +=back + +=cut + + package Apache::imageresponse; use strict; use Image::Magick(); @@ -106,7 +187,6 @@ sub end_imageresponse { } &Apache::response::end_response(); - return $result; } @@ -239,7 +319,7 @@ sub displayfoils { my $image=$Apache::response::foilgroup{"$name.image"}; &Apache::lonxml::debug("image is $image"); if ( ($target eq 'web' || $target eq 'answer') - && $image !~ /^http:/ ) { + && $image !~ /^https?\:/ ) { $image=&clean_up_image($image); } push(@images,$image); @@ -305,7 +385,7 @@ sub display_answers { my $image=$Apache::response::foilgroup{"$name.image"}; &Apache::lonxml::debug("image is $image"); if ( ($target eq 'web' || $target eq 'answer') - && $image !~ /^http:/ ) { + && $image !~ /^https?\:/ ) { $image = &clean_up_image($image); } my $token=&prep_image($image,'answeronly',$name); @@ -320,7 +400,7 @@ sub clean_up_image { my ($image)=@_; if ($image =~ /\s*<img\s*/) { ($image) = ($image =~ /src\s*=\s*[\"\']([^\"\']+)[\"\']/i); - if ($image !~ /^http:/) { + if ($image !~ /^https?\:/) { $image=&Apache::lonnet::hreflocation('',$image); } if (!$image) { @@ -367,7 +447,7 @@ sub gradefoils { } elsif ($1 eq 'polygon') { $grade=&grade_polygon($area,$x,$y); } else { - &Apache::lonxml::error("Unknown area style $area"); + &Apache::lonxml::error(&mt('Unknown area style [_1]',$area)); } &Apache::lonxml::debug("Area said $grade"); if ($grade eq 'APPROX_ANS') { last; } @@ -386,8 +466,18 @@ sub gradefoils { my %previous= &Apache::response::check_for_previous(&stringify_submission(\%response), $part,$id); - if ($result - && $Apache::lonhomework::type eq 'survey') { $result='SUBMITTED'; } + if ($result) { + if ($Apache::lonhomework::type eq 'survey') { + $result='SUBMITTED'; + } elsif ($Apache::lonhomework::type eq 'surveycred') { + $result='SUBMITTED_CREDIT'; + } elsif ($Apache::lonhomework::type eq 'anonsurvey') { + $result='ANONYMOUS'; + } elsif ($Apache::lonhomework::type eq 'anonsurveycred') { + $result='ANONYMOUS_CREDIT'; + } + } + &Apache::response::handle_previous(\%previous,$result); $Apache::lonhomework::results{"resource.$part.$id.submission"}= &stringify_submission(\%response); @@ -494,11 +584,12 @@ sub start_foil { $target eq 'analyze' || $target eq 'answer') { my $name = &Apache::lonxml::get_param('name',$parstack,$safeeval); if ($name eq "") { - &Apache::lonxml::warning("Foils without names exist. This can cause problems to malfunction."); + &Apache::lonxml::warning(&mt('Foils without names exist. This can cause problems to malfunction.')); $name=$Apache::lonxml::curdepth; } if (defined($Apache::response::foilnames{$name})) { - &Apache::lonxml::error(&mt("Foil name <b><tt>[_1]</tt></b> appears more than once. Foil names need to be unique.",$name)); + &Apache::lonxml::error(&mt("Foil name [_1] appears more than once. Foil names need to be unique." + ,'<b><tt>'.$name.'</tt></b>')); } $Apache::response::foilnames{$name}++; if ( $Apache::imageresponse::conceptgroup @@ -634,11 +725,13 @@ sub end_image { my ($commentline, $restofstuff) = split(/\n/, $src); $graphinclude = $src; $graphinclude =~ s/^$commentline//; - } else { + } elsif (!($src =~ /\\/)) { my ($path,$file) = &Apache::londefdef::get_eps_image($src); my ($height_param,$width_param)= &Apache::londefdef::image_size($src,0.3,$parstack,$safeeval); $graphinclude = '\graphicspath{{'.$path.'}}\includegraphics[width='.$width_param.' mm]{'.$file.'}'; + } else { + $graphinclude = $src; # Already fully formed. } $Apache::response::foilgroup{"$name.image"} ='\vskip 0 mm \noindent '.$graphinclude; }