From f8f3f7a19b416724f38ac384778fb5ad3dcd9483 Mon Sep 17 00:00:00 2001 From: Vasilis Daloukas Date: Tue, 14 Jul 2015 12:10:34 +0300 Subject: [PATCH] New: Multianswer question on Snakes and Ladders Game --- locallib.php | 84 +++++++++++++++++++++++++++++++++++++++++++++++-- snakes/play.php | 2 +- version.php | 4 +-- 3 files changed, 85 insertions(+), 5 deletions(-) diff --git a/locallib.php b/locallib.php index bee8c6e..cb937e5 100755 --- a/locallib.php +++ b/locallib.php @@ -1539,6 +1539,8 @@ function game_grade_responses( $question, $responses, $maxgrade, &$answertext) { if( $question->qtype == 'multichoice') { + if( $question->category == 8) + return game_grade_responses_multianswer( $question, $responses, $maxgrade, $answertext); $name = "resp{$question->id}_"; $value = $responses->$name; $answer = $question->options->answers[ $value]; @@ -1560,11 +1562,36 @@ function game_grade_responses( $question, $responses, $maxgrade, &$answertext) } } +function game_grade_responses_multianswer( $question, $responses, $maxgrade, &$answertext) +{ + $name = "resp{$question->id}_"; + + $len = strlen( $name); + $fraction = 0; + foreach( $responses as $key => $value) + { + $sub = substr( $key, 0, strlen( $name)); + if( $sub != $name) + continue; + + $name2 = $name.$value; + $value2 = $responses->$name2; + $answer = $question->options->answers[ $value2]; + $fraction += $answer->fraction; + } + + return $fraction * $maxgrade; +} + function game_print_question( $game, $question, $context) { if( $question->qtype == 'multichoice') - game_print_question_multichoice( $game, $question, $context); - else if( $question->qtype == 'shortanswer') + { + if( $question->category == 8) + game_print_question_multianswer( $game, $question, $context); + else + game_print_question_multichoice( $game, $question, $context); + }else if( $question->qtype == 'shortanswer') game_print_question_shortanswer( $game, $question, $context); } @@ -1620,6 +1647,59 @@ function game_print_question_multichoice( $game, $question, $context) questiontext; + $answerprompt = get_string( 'singleanswer', 'quiz'); + $feedback = ''; + $anss = array(); + foreach( $question->options->answers as $a) + { + $answer = new stdClass(); + if( substr( $a->answer, 0, 3) == '

' or substr( $a->answer, 0, 3) == '

') + { + $a->answer = substr( $a->answer, 3); + $s = rtrim( $a->answer); + if( substr( $s, 0, -3) == '

' or substr( $s, 0, -3) == '

') + $a->answer = substr( $a->answer, 0, -3); + } + $a->answer = game_filterquestion_answer(str_replace( '\"', '"', $a->answer), $a->id, $context->id, $game->course); + $answer->control = "id}_{$a->id}\" name=\"resp{$question->id}_{$a->id}\" type=\"checkbox\" value=\"{$a->id}\" /> ".$a->answer; + $answer->class = 'radio'; + $answer->id = $a->id; + $answer->text = $a->answer; + $answer->feedbackimg = ''; + $answer->feedback = ''; + $anss[] = $answer; + } +?> +

+ id, $context->id, $game->course); ?> +
+ + +
+
+ +
+ + + + + + + +
+ control; ?> +
+
+questiontext; diff --git a/snakes/play.php b/snakes/play.php index 6ed153e..38d3953 100755 --- a/snakes/play.php +++ b/snakes/play.php @@ -301,7 +301,7 @@ function game_snakes_check_questions( $id, $game, $attempt, $snakes, $context) $query->id = $snakes->queryid; $grade = game_grade_responses( $question, $responses, 100, $answertext); - if( $grade < 50){ + if( $grade < 99){ //wrong answer game_update_queries( $game, $attempt, $query, 0, $answertext); continue; diff --git a/version.php b/version.php index fe68b0d..47f094b 100755 --- a/version.php +++ b/version.php @@ -22,10 +22,10 @@ if( !isset( $plugin)) $useplugin = 2; $plugin->component = 'mod_game'; // Full name of the plugin (used for diagnostics) -$plugin->version = 2015071206; // The current module version (Date: YYYYMMDDXX) +$plugin->version = 20150714; // The current module version (Date: YYYYMMDDXX) $plugin->requires = 2010112400; // Requires Moodle 2.0 $plugin->cron = 0; // Period for cron to check this module (secs) -$plugin->release = '3.30.12.6'; +$plugin->release = '3.30.14'; if( $useplugin != 2) $module = $plugin;