moodle/mod/quiz/report/statistics/statistics_graph.php

167 lines
5.5 KiB
PHP

<?php
// This file is part of Moodle - http://moodle.org/
//
// Moodle is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Moodle is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
/**
* This script renders the quiz statistics graph.
*
* It takes one parameter, the quiz_statistics.id. This is enough to identify the
* quiz etc.
*
* It plots a bar graph showing certain question statistics plotted against
* question number.
*
* @package quiz
* @subpackage statistics
* @copyright 2008 Jamie Pratt
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
*/
require_once(dirname(__FILE__) . '/../../../../config.php');
require_once($CFG->libdir . '/graphlib.php');
require_once($CFG->dirroot . '/mod/quiz/locallib.php');
require_once($CFG->dirroot . '/mod/quiz/report/reportlib.php');
/**
* This helper function returns a sequence of colours each time it is called.
* Used for chooseing colours for graph data series.
* @return string colour name.
*/
function graph_get_new_colour() {
static $colourindex = -1;
$colours = array('red', 'green', 'yellow', 'orange', 'purple', 'black',
'maroon', 'blue', 'ltgreen', 'navy', 'ltred', 'ltltgreen', 'ltltorange',
'olive', 'gray', 'ltltred', 'ltorange', 'lime', 'ltblue', 'ltltblue');
$colourindex = ($colourindex + 1) % count($colours);
return $colours[$colourindex];
}
// Get the parameters.
$quizstatisticsid = required_param('id', PARAM_INT);
// Load enough data to check permissions.
$quizstatistics = $DB->get_record('quiz_statistics', array('id' => $quizstatisticsid));
$quiz = $DB->get_record('quiz', array('id' => $quizstatistics->quizid), '*', MUST_EXIST);
$cm = get_coursemodule_from_instance('quiz', $quiz->id);
// Check access.
require_login($quiz->course, false, $cm);
$modcontext = get_context_instance(CONTEXT_MODULE, $cm->id);
require_capability('quiz/statistics:view', $modcontext);
if (groups_get_activity_groupmode($cm)) {
$groups = groups_get_activity_allowed_groups($cm);
} else {
$groups = array();
}
if ($quizstatistics->groupid && !in_array($quizstatistics->groupid, array_keys($groups))) {
print_error('groupnotamember', 'group');
}
// Load the rest of the required data.
$questions = quiz_report_get_significant_questions($quiz);
$questionstatistics = $DB->get_records_select('quiz_question_statistics',
'quizstatisticsid = ? AND slot IS NOT NULL', array($quizstatistics->id));
// Create the graph, and set the basic options.
$graph = new graph(800, 600);
$graph->parameter['title'] = '';
$graph->parameter['y_label_left'] = '%';
$graph->parameter['x_label'] = get_string('position', 'quiz_statistics');
$graph->parameter['y_label_angle'] = 90;
$graph->parameter['x_label_angle'] = 0;
$graph->parameter['x_axis_angle'] = 60;
$graph->parameter['legend'] = 'outside-right';
$graph->parameter['legend_border'] = 'black';
$graph->parameter['legend_offset'] = 4;
$graph->parameter['bar_size'] = 1;
$graph->parameter['zero_axis'] = 'grayEE';
// Configure what to display.
$fieldstoplot = array(
'facility' => get_string('facility', 'quiz_statistics'),
'discriminativeefficiency' => get_string('discriminative_efficiency', 'quiz_statistics')
);
$fieldstoplotfactor = array('facility' => 100, 'discriminativeefficiency' => 1);
// Prepare the arrays to hold the data.
$xdata = array();
foreach (array_keys($fieldstoplot) as $fieldtoplot) {
$ydata[$fieldtoplot] = array();
$graph->y_format[$fieldtoplot] = array(
'colour' => graph_get_new_colour(),
'bar' => 'fill',
'shadow_offset' => 1,
'legend' => $fieldstoplot[$fieldtoplot]
);
}
// Fill in the data for each question.
foreach ($questionstatistics as $questionstatistic) {
$number = $questions[$questionstatistic->slot]->number;
$xdata[$number] = $number;
foreach ($fieldstoplot as $fieldtoplot => $notused) {
$value = $questionstatistic->$fieldtoplot;
if (is_null($value)) {
$value = 0;
}
$value *= $fieldstoplotfactor[$fieldtoplot];
$ydata[$fieldtoplot][$number] = $value;
}
}
// Sort the fields into order.
sort($xdata);
$graph->x_data = array_values($xdata);
foreach ($fieldstoplot as $fieldtoplot => $notused) {
ksort($ydata[$fieldtoplot]);
$graph->y_data[$fieldtoplot] = array_values($ydata[$fieldtoplot]);
}
$graph->y_order = array_keys($fieldstoplot);
// Find appropriate axis limits.
$max = 0;
$min = 0;
foreach ($fieldstoplot as $fieldtoplot => $notused) {
$max = max($max, max($graph->y_data[$fieldtoplot]));
$min = min($min, min($graph->y_data[$fieldtoplot]));
}
// Set the remaining graph options that depend on the data.
$gridresolution = 10;
$max = ceil($max / $gridresolution) * $gridresolution;
$min = floor($min / $gridresolution) * $gridresolution;
$gridlines = ceil(($max - $min) / $gridresolution) + 1;
$graph->parameter['y_axis_gridlines'] = $gridlines;
$graph->parameter['y_min_left'] = $min;
$graph->parameter['y_max_left'] = $max;
$graph->parameter['y_decimal_left'] = 0;
// Output the graph.
$graph->draw();