Parent Directory
|
Revision Log
CONTRIB-497 *Added new visualization, Grade Distribution *Fixed some minor bugs *Made abstract visualization class for creating visualizations by making classes witch extend it. *Made visual_settings.php witch takes a visualization class and truns it in to XML witch flex can read in. *Made flex visualization application read in XML formated settings as well as tab formated data from moodle and combind them to make a custom visualization. *Made flex visualization application read and use langue strings from moodle. *Added printer firendly tab TODO: *Add more visualizations *Refactor some of the flex/actionscript code *More douctenation *More UI functions for the flex application
<?php
require_once $CFG->dirroot . '/grade/report/visual/visualizations/visualization.php';
class grade_distribution extends visualization {
const RANGE = 10;
public $colorencodernode;
public $colorencoderedge;
public $shapeencodernode;
public $shapeencoderedge;
public $grouplegend;
public $itemlegend;
public function __construct() {
parent::__construct(get_string('gradedistribution', 'gradereport_visual'));
$this->layout = visualization::LAYOUT_AXIS;
$this->layoutsettings = null;//array('false', 'true');
//$this->nodeshape = visualization::SHAPE_VERTICAL_BAR;
//$this->edgeshape = visualization::SHAPE_BEZIER;
$this->edges = array(new edge('grade', array('item', 'group')));
$this->xaxis = 'grade';
$this->yaxis = 'students';
$this->xaxislabelformat = '0\\%';
//$this->xaxismax = 100 + grade_distribution::RANGE;
//$this->xaxismin = grade_distribution::RANGE;
$this->xaxisxoffset = -27;
$this->xaxislabel = get_string('grade', 'gradereport_visual');
$this->yaxislabel = get_string('numberstudents', 'gradereport_visual');
$this->title = get_string('gradedistribution:title', 'gradereport_visual');
$this->capabilities = null;
$this->colorencoderedge = new encoder(encoder::ENCODER_COLOR, 'item', array(2));
$this->colorencodernode = new encoder(encoder::ENCODER_COLOR, 'item', array(1));
//$this->shapeencoderedge = new encoder(encoder::ENCODER_SHAPE, 'group', array(2));
$this->shapeencodernode = new encoder(encoder::ENCODER_SHAPE, 'group', array(1));
$this->encoders = array($this->colorencodernode, $this->colorencoderedge, $this->shapeencodernode);
$this->grouplegend = new legend($this->shapeencodernode);
$this->itemlegend = new legend($this->colorencodernode);
$this->legends = array($this->itemlegend, $this->grouplegend);
}
public function report_data($visualreport) {
$data = array();
$data['header'] = array();
$data['header']['students'] = 'students';
// $data['header']['gradelevel'] = 'gradelevel';
$data['header']['grade'] = 'grade';
$data['header']['item'] = 'item';
$data['header']['group'] = 'group';
//$data['header']['range'] = 'range';
$rawdata = array();
$counters = array();
$rangesize = round(100 / grade_distribution::RANGE);
foreach($visualreport->grades as $itemkey=>$itemgrades) {
foreach($itemgrades as $studentkey=>$studentdata) {
if($studentdata != null && $studentdata->finalgrade != null) {
foreach(groups_get_user_groups($visualreport->courseid, $studentkey) as $grouping) {
$gradelevel = floor(round($studentdata->standardise_score($studentdata->finalgrade, $visualreport->gtree->items[$itemkey]->grademin, $visualreport->gtree->items[$itemkey]->grademax, 0, 100)) / grade_distribution::RANGE);
if($gradelevel == $rangesize) {
$gradelevel = $rangesize - 1;
}
if(count($grouping) > 0) {
foreach($grouping as $group) {
if(isset($rawdata[$gradelevel][$itemkey][$group])) {
$rawdata[$gradelevel][$itemkey][$group] += 1;
} else {
$rawdata[$gradelevel][$itemkey][$group] = 1;
}
if(isset($counters[$itemkey][$group])) {
$counters[$itemkey][$group] += 1;
} else {
$counters[$itemkey][$group] = 1;
}
}
} else {
if(isset($rawdata[$gradelevel][$itemkey]['ng'])) {
$rawdata[$gradelevel][$itemkey]['ng'] += 1;
} else {
$rawdata[$gradelevel][$itemkey]['ng'] = 1;
}
if(isset($counters[$itemkey]['ng'])) {
$counters[$itemkey]['ng'] += 1;
} else {
$counters[$itemkey]['ng'] = 1;
}
}
if(isset($rawdata[$gradelevel][$itemkey]['ag'])) {
$rawdata[$gradelevel][$itemkey]['ag'] += 1;
} else {
$rawdata[$gradelevel][$itemkey]['ag'] = 1;
}
if(isset($counters[$itemkey]['ag'])) {
$counters[$itemkey]['ag'] += 1;
} else {
$counters[$itemkey]['ag'] = 1;
}
}
}
}
for($i = 0; $i < $rangesize; $i++) {
foreach(groups_get_all_groups($visualreport->courseid) as $group) {
if(!isset($rawdata[$i][$itemkey][$group->id])) {
$rawdata[$i][$itemkey][$group->id] = 0;
}
}
if(!isset($rawdata[$i][$itemkey]['ng'])) {
$rawdata[$i][$itemkey]['ng'] = 0;
}
if(!isset($rawdata[$i][$itemkey]['ag'])) {
$rawdata[$i][$itemkey]['ag'] = 0;
}
}
}
$i = 0;
foreach($rawdata as $gradelevel=>$items) {
foreach($items as $itemkey=>$groups) {
foreach($groups as $groupkey=>$students) {
$index = $gradelevel * 10000 + $i;
$data[$index]['students'] = $students;
//$data[$index]['gradelevel'] = $gradelevel;
$data[$index]['grade'] = $gradelevel * grade_distribution::RANGE; //($gradelevel * grade_distribution::RANGE) . '% - ' . (($gradelevel + 1) * grade_distribution::RANGE - 1) . '%';
$data[$index]['item'] = $visualreport->gtree->items[$itemkey]->get_name();
if($groupkey == 'ng') {
$data[$index]['group'] = get_string('nogroup', 'gradereport_visual');
} else if($groupkey == 'ag'){
$data[$index]['group'] = get_string('allgroups', 'gradereport_visual');
} else {
$data[$index]['group'] = groups_get_group_name($groupkey);
}
//$data[$index]['range'] = grade_distribution::RANGE;
$i++;
}
}
}
// ksort($data);
return $data;
}
}
?>
| Moodle CVS Admin | ViewVC Help |
| Powered by ViewVC 1.0.7 |