version 1.116, 2007/06/19 10:00:23
|
version 1.122, 2007/06/29 17:24:03
|
Line 33 use Apache::lonlocal;
|
Line 33 use Apache::lonlocal;
|
use Apache::lonnet; |
use Apache::lonnet; |
use Apache::response; |
use Apache::response; |
|
|
my $bubbles_per_line = 10; |
my $default_bubbles_per_line = 10; |
|
|
|
|
BEGIN { |
BEGIN { |
&Apache::lonxml::register('Apache::radiobuttonresponse',('radiobuttonresponse')); |
&Apache::lonxml::register('Apache::radiobuttonresponse',('radiobuttonresponse')); |
} |
} |
|
|
|
sub bubble_line_count { |
|
my ($numfoils, $bubbles_per_line) = @_; |
|
my $bubble_lines; |
|
$bubble_lines = int($numfoils / $bubbles_per_line); |
|
if (($numfoils % $bubbles_per_line) != 0) { |
|
$bubble_lines++; |
|
} |
|
return $bubble_lines; |
|
|
|
} |
|
|
|
|
sub start_radiobuttonresponse { |
sub start_radiobuttonresponse { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result; |
my $result; |
|
|
|
|
|
|
#when in a radiobutton response use these |
#when in a radiobutton response use these |
&Apache::lonxml::register('Apache::radiobuttonresponse',('foilgroup','foil','conceptgroup')); |
&Apache::lonxml::register('Apache::radiobuttonresponse',('foilgroup','foil','conceptgroup')); |
push (@Apache::lonxml::namespace,'radiobuttonresponse'); |
push (@Apache::lonxml::namespace,'radiobuttonresponse'); |
my $id = &Apache::response::start_response($parstack,$safeeval); |
my $id = &Apache::response::start_response($parstack,$safeeval); |
|
|
%Apache::hint::radiobutton=(); |
%Apache::hint::radiobutton=(); |
undef(%Apache::response::foilnames); |
undef(%Apache::response::foilnames); |
if ($target eq 'meta') { |
if ($target eq 'meta') { |
Line 140 sub storesurvey {
|
Line 156 sub storesurvey {
|
return ''; |
return ''; |
} |
} |
|
|
|
|
sub grade_response { |
sub grade_response { |
my ($max,$randomize)=@_; |
my ($max,$randomize, $bubbles_per_line)=@_; |
#keep the random numbers the same must always call this |
#keep the random numbers the same must always call this |
my ($answer,@whichfoils)=&whichfoils($max,$randomize); |
my ($answer,@whichfoils)=&whichfoils($max,$randomize); |
if ( !&Apache::response::submitted() ) { return; } |
if ( !&Apache::response::submitted() ) { return; } |
my $response; |
my $response; |
|
|
if ($env{'form.submitted'} eq 'scantron') { |
if ($env{'form.submitted'} eq 'scantron') { |
# Need to know how many foils we have so that I know how many |
$response = &Apache::response::getresponse(1,undef, |
# bubble lines to consume: |
&bubble_line_count(scalar(@whichfoils), |
|
$bubbles_per_line), |
my $numfoils = scalar @whichfoils; |
$bubbles_per_line); |
my $bubble_lines = int($numfoils / $bubbles_per_line); |
|
if (($numfoils % $bubbles_per_line) != 0) { |
|
$bubble_lines++; # Partial line of bubbles too. |
|
} |
|
# Get an array of the lines... note offsets seem to go from 1??... |
|
|
|
my @responses; |
|
for (my $i = 1; $i <= $bubble_lines; $i++) { |
|
my $this_line = &Apache::response::getresponse($i); |
|
push(@responses, $this_line); |
|
|
|
} |
|
# Update the lonxml::counter so that the next problem |
|
# Gets the right set of answers: |
|
|
|
&Apache::lonxml::increment_counter($bubble_lines-1); |
|
|
|
# This code assumes that unbubbled lines will be |
|
# blank while bubbled lines nonblank. |
|
# .. multiple answers awards the student 'INCORRECT'. |
|
# This is done by setting resopnse to "Multiple" which will |
|
# not match anything. |
|
#.. otherwise response is set to the line*$bubble_per_line+answer |
|
# |
|
# --- note: |
|
# If it is not possible to do double bubble detection |
|
# easily in grades.pm separating this loop makes it pretty |
|
# easy to do it here. |
|
# Just count the number of non-blank entries, and |
|
# below the loop, check for non-blank entries != 1 |
|
# and report a wrong answer if so. |
|
# |
|
my $answer_line; |
|
my $answer_value = ''; # By default no answer given... |
|
my $num_bubbled_lines=0; |
|
for (my $line_number = 0; $line_number < $bubble_lines; $line_number++) { |
|
if ($responses[$line_number] ne "") { |
|
$answer_line = $line_number; |
|
$answer_value = $responses[$line_number]; |
|
last; |
|
} |
|
} |
|
|
|
$response = $answer_line * $bubbles_per_line + $answer_value; |
|
|
|
|
|
} else { |
} else { |
$response = $env{'form.HWVAL_'.$Apache::inputtags::response['-1']}; |
$response = $env{'form.HWVAL_'.$Apache::inputtags::response['-1']}; |
} |
} |
|
|
|
|
if ( $response !~ /[0-9]+/) { return; } |
if ( $response !~ /[0-9]+/) { return; } |
my $part=$Apache::inputtags::part; |
my $part=$Apache::inputtags::part; |
my $id = $Apache::inputtags::response['-1']; |
my $id = $Apache::inputtags::response['-1']; |
Line 225 sub end_foilgroup {
|
Line 200 sub end_foilgroup {
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
|
|
my $result; |
my $result; |
|
my $bubble_lines; |
|
my $bubbles_per_line; |
|
my $answer_count; |
|
my $id = $Apache::inputtags::response['-1']; |
|
$bubbles_per_line = |
|
&Apache::response::get_response_param($Apache::inputtags::part."_$id", |
|
'numbubbles', |
|
$default_bubbles_per_line); |
|
|
|
|
if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' || |
if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' || |
$target eq 'tex' || $target eq 'analyze') { |
$target eq 'tex' || $target eq 'analyze') { |
my $style = $Apache::lonhomework::type; |
my $style = $Apache::lonhomework::type; |
Line 238 sub end_foilgroup {
|
Line 223 sub end_foilgroup {
|
} elsif ( $target eq 'grade' ) { |
} elsif ( $target eq 'grade' ) { |
$result=&storesurvey(); |
$result=&storesurvey(); |
} |
} |
|
$answer_count = scalar(@{$Apache::response::foilgroup{'names'}}); |
|
|
} else { |
} else { |
|
|
my $name; |
my $name; |
my $max = &Apache::lonxml::get_param('max',$parstack,$safeeval, |
my $max = &Apache::lonxml::get_param('max',$parstack,$safeeval, |
'-2'); |
'-2'); |
my $randomize = &Apache::lonxml::get_param('randomize',$parstack, |
my $randomize = &Apache::lonxml::get_param('randomize',$parstack, |
$safeeval,'-2'); |
$safeeval,'-2'); |
|
my ($answer,@shown) = &whichfoils($max,$randomize); |
|
$answer_count = scalar(@shown); |
|
|
if ($target eq 'web' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'tex') { |
$result=&displayfoils($target,$max,$randomize,$direction); |
$result=&displayfoils($target, |
|
$max, |
|
$randomize, |
|
$direction, |
|
$bubbles_per_line); |
} elsif ($target eq 'answer' ) { |
} elsif ($target eq 'answer' ) { |
$result=&displayanswers($max,$randomize); |
$result=&displayanswers($max,$randomize); |
} elsif ( $target eq 'grade') { |
} elsif ( $target eq 'grade') { |
&grade_response($max,$randomize); |
&grade_response($max,$randomize, |
|
$bubbles_per_line); |
} elsif ( $target eq 'analyze') { |
} elsif ( $target eq 'analyze') { |
my @shown = &whichfoils($max,$randomize); |
|
&Apache::response::analyze_store_foilgroup(\@shown, |
&Apache::response::analyze_store_foilgroup(\@shown, |
['text','value','location']); |
['text','value','location']); |
my $part_id="$Apache::inputtags::part.$Apache::inputtags::response[-1]"; |
my $part_id="$Apache::inputtags::part.$Apache::inputtags::response[-1]"; |
Line 265 sub end_foilgroup {
|
Line 260 sub end_foilgroup {
|
&Apache::response::setup_prior_tries_hash(\&format_prior_answer, |
&Apache::response::setup_prior_tries_hash(\&format_prior_answer, |
[\%Apache::response::foilgroup]); |
[\%Apache::response::foilgroup]); |
} |
} |
|
$bubble_lines = &bubble_line_count($answer_count, $bubbles_per_line); |
&Apache::response::poprandomnumber(); |
&Apache::response::poprandomnumber(); |
&Apache::lonxml::increment_counter(); |
&Apache::lonxml::increment_counter($bubble_lines); |
return $result; |
return $result; |
} |
} |
|
|
Line 304 sub displayallfoils {
|
Line 299 sub displayallfoils {
|
my $result; |
my $result; |
&Apache::lonxml::debug("survey style display"); |
&Apache::lonxml::debug("survey style display"); |
my @names; |
my @names; |
|
&Apache::lonnet::loghthis("Display all foils"); |
if ( $Apache::response::foilgroup{'names'} ) { |
if ( $Apache::response::foilgroup{'names'} ) { |
@names= @{ $Apache::response::foilgroup{'names'} }; |
@names= @{ $Apache::response::foilgroup{'names'} }; |
} |
} |
|
|
my $temp=0; |
my $temp=0; |
my $i =0; |
my $i =0; |
my $id=$Apache::inputtags::response['-1']; |
my $id=$Apache::inputtags::response['-1']; |
Line 376 sub displayallfoils {
|
Line 373 sub displayallfoils {
|
} |
} |
} |
} |
} |
} |
|
|
if (($direction eq 'horizontal') && ($target ne 'tex')) { $result.='</tr></table>'; } |
if (($direction eq 'horizontal') && ($target ne 'tex')) { $result.='</tr></table>'; } |
return $result; |
return $result; |
} |
} |
|
|
|
=pod |
|
|
|
=item &whichfoils($max,$randomize) |
|
|
|
Randomizes the list of foils. |
|
Respects |
|
- each foils desire to be randomized |
|
- the existance of Concept groups of foils (select 1 foil from each) |
|
- and selects a single correct statement from all possilble true statments |
|
- and limits it to a toal of $max foils |
|
|
|
Arguments |
|
$max - maximum number of foils to select (including the true one) |
|
(so a max of 5 is: 1 true, 4 false) |
|
|
|
$randomize - whether to randomize the listing of foils, by default |
|
will randomize, only if randomize is 'no' will it not |
|
|
|
Returns |
|
$answer - location in the array of the correct answer |
|
@foils - array of foil names in to display order |
|
|
|
=cut |
|
|
sub whichfoils { |
sub whichfoils { |
my ($max,$randomize)=@_; |
my ($max,$randomize)=@_; |
|
|
Line 517 sub whichfoils {
|
Line 539 sub whichfoils {
|
} |
} |
|
|
sub displayfoils { |
sub displayfoils { |
my ($target,$max,$randomize,$direction)=@_; |
my ($target,$max,$randomize,$direction, $bubbles_per_line)=@_; |
my $result; |
my $result; |
|
|
my ($answer,@whichfoils)=&whichfoils($max,$randomize); |
my ($answer,@whichfoils)=&whichfoils($max,$randomize); |
Line 596 sub displayfoils {
|
Line 618 sub displayfoils {
|
if($bubble_number >= $bubbles_per_line) { |
if($bubble_number >= $bubbles_per_line) { |
$i = 0; |
$i = 0; |
$bubble_number = 0; |
$bubble_number = 0; |
&Apache::lonxml::increment_counter(1); |
|
$result.='\item[\textbf{'.$Apache::lonxml::counter.'}.]'; |
$result.='\item[\textbf{'.$Apache::lonxml::counter.'}.]'; |
} |
} |
} else { |
} else { |
Line 621 sub displayallanswers {
|
Line 642 sub displayallanswers {
|
if ( $Apache::response::foilgroup{'names'} ) { |
if ( $Apache::response::foilgroup{'names'} ) { |
@names= @{ $Apache::response::foilgroup{'names'} }; |
@names= @{ $Apache::response::foilgroup{'names'} }; |
} |
} |
|
|
my $result=&Apache::response::answer_header('radiobuttonresponse'); |
my $result=&Apache::response::answer_header('radiobuttonresponse'); |
foreach my $name (@names) { |
foreach my $name (@names) { |
$result.=&Apache::response::answer_part('radiobuttonresponse', |
$result.=&Apache::response::answer_part('radiobuttonresponse', |