implementation of the pie chart using OFC
This commit is contained in:
@@ -7,9 +7,12 @@
|
||||
* @package phpMyAdmin
|
||||
*/
|
||||
|
||||
function PMA_chart_pie($data)
|
||||
function PMA_chart_pie($titleText, $data)
|
||||
{
|
||||
return "pie chart placeholder";
|
||||
require_once('./libraries/chart/pma_ofc_pie.php');
|
||||
|
||||
$chart = new PMA_OFC_Pie($titleText, $data);
|
||||
echo $chart->toString();
|
||||
}
|
||||
|
||||
?>
|
||||
|
58
libraries/chart/pma_chart.php
Normal file
58
libraries/chart/pma_chart.php
Normal file
@@ -0,0 +1,58 @@
|
||||
<?php
|
||||
|
||||
class PMA_Chart
|
||||
{
|
||||
/*
|
||||
* The style of the chart title.
|
||||
*/
|
||||
protected $titleStyle = 'font-size: 12px; font-weight: bold;';
|
||||
|
||||
/*
|
||||
* Colors for the different slices in the pie chart.
|
||||
*/
|
||||
protected $colors = array(
|
||||
'#485E70',
|
||||
'#484A70',
|
||||
'#594870',
|
||||
'#6D4870',
|
||||
'#70485E',
|
||||
'#70484A',
|
||||
'#705948',
|
||||
'#706D48',
|
||||
'#5E7048',
|
||||
'#4A7048',
|
||||
'#487059',
|
||||
'#48706D',
|
||||
'#5F7E95',
|
||||
'#839CAF',
|
||||
'#95775F',
|
||||
'#AF9683',
|
||||
);
|
||||
|
||||
/*
|
||||
* Chart background color.
|
||||
*/
|
||||
protected $bgColor = '#f5f5f5';
|
||||
|
||||
/*
|
||||
* The width of the chart.
|
||||
*/
|
||||
protected $width = 400;
|
||||
|
||||
/*
|
||||
* The height of the chart.
|
||||
*/
|
||||
protected $height = 250;
|
||||
|
||||
/*
|
||||
* Colors in the colors array have been written down in an gradient
|
||||
* order. Without shuffling pie chart has an angular gradient.
|
||||
* Colors could also be shuffles in the array initializer.
|
||||
*/
|
||||
function __construct()
|
||||
{
|
||||
shuffle(&$this->colors);
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
89
libraries/chart/pma_ofc_chart.php
Normal file
89
libraries/chart/pma_ofc_chart.php
Normal file
@@ -0,0 +1,89 @@
|
||||
<?php
|
||||
|
||||
require_once('pma_chart.php');
|
||||
|
||||
/*
|
||||
* Base class for every chart implemented using OFC.
|
||||
* Has the code used to embed OFC chart into the page.
|
||||
*/
|
||||
class PMA_OFC_Chart extends PMA_Chart
|
||||
{
|
||||
protected $flashBaseUrl = 'js/';
|
||||
|
||||
protected $chart = null;
|
||||
|
||||
function __construct()
|
||||
{
|
||||
parent::__construct();
|
||||
}
|
||||
|
||||
function get_embed_code($data)
|
||||
{
|
||||
$url = urlencode($url);
|
||||
|
||||
// output buffer
|
||||
$out = array();
|
||||
|
||||
// check for http or https:
|
||||
if (isset($_SERVER['HTTPS']))
|
||||
{
|
||||
if (strtoupper ($_SERVER['HTTPS']) == 'ON')
|
||||
{
|
||||
$protocol = 'https';
|
||||
}
|
||||
else
|
||||
{
|
||||
$protocol = 'http';
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
$protocol = 'http';
|
||||
}
|
||||
|
||||
// if there are more than one charts on the
|
||||
// page, give each a different ID
|
||||
global $open_flash_chart_seqno;
|
||||
$chart_id = 'chart';
|
||||
|
||||
if (!isset($open_flash_chart_seqno))
|
||||
{
|
||||
$open_flash_chart_seqno = 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
$open_flash_chart_seqno++;
|
||||
}
|
||||
|
||||
$obj_id .= '_'. $open_flash_chart_seqno;
|
||||
$data_func_name = 'get_data_for_'.$obj_id;
|
||||
|
||||
// all parameters for the OFC will be given by the return value
|
||||
// of the JS function
|
||||
$out[] = '<script type="text/javascript">';
|
||||
$out[] = 'function '.$data_func_name.'()';
|
||||
$out[] = '{';
|
||||
$out[] = "return '".str_replace("\n", '', $data)."';";
|
||||
$out[] = '}';
|
||||
$out[] = '</script>';
|
||||
|
||||
$out[] = '<object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="'.$protocol.'://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,0,0,0" ';
|
||||
$out[] = 'width="'.$this->width.'" height="'.$this->height.'" id="'.$obj_id.'" align="middle">';
|
||||
$out[] = '<param name="allowScriptAccess" value="sameDomain" />';
|
||||
$out[] = '<param name="movie" value="'.$this->flashBaseUrl.'open-flash-chart.swf?get-data='.$data_func_name.'" />';
|
||||
$out[] = '<param name="quality" value="high" />';
|
||||
$out[] = '<param name="bgcolor" value="#FFFFFF" />';
|
||||
$out[] = '<embed src="'.$this->flashBaseUrl.'open-flash-chart.swf?get-data='.$data_func_name.'" quality="high" bgcolor="#FFFFFF" width="'.$this->width.'" height="'.$this->height.'" name="'.$obj_id.'" align="middle" allowScriptAccess="sameDomain" ';
|
||||
$out[] = 'type="application/x-shockwave-flash" pluginspage="'.$protocol.'://www.macromedia.com/go/getflashplayer" id="'.$obj_id.'"/>';
|
||||
$out[] = '</object>';
|
||||
|
||||
return implode("\n", $out);
|
||||
}
|
||||
|
||||
function toString()
|
||||
{
|
||||
return $this->get_embed_code($this->chart->toPrettyString());
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
46
libraries/chart/pma_ofc_pie.php
Normal file
46
libraries/chart/pma_ofc_pie.php
Normal file
@@ -0,0 +1,46 @@
|
||||
<?php
|
||||
|
||||
require_once('pma_ofc_chart.php');
|
||||
|
||||
/*
|
||||
* Implementation of pie chart using OFC.
|
||||
*/
|
||||
class PMA_OFC_Pie extends PMA_OFC_Chart
|
||||
{
|
||||
function __construct($titleText, $data)
|
||||
{
|
||||
parent::__construct();
|
||||
|
||||
include './libraries/chart/ofc/open-flash-chart.php';
|
||||
|
||||
// create and style chart title
|
||||
$title = new title($titleText);
|
||||
$title->set_style($this->titleStyle);
|
||||
|
||||
// create the main chart element - pie
|
||||
$pie = new pie();
|
||||
$pie->set_alpha(1);
|
||||
$pie->set_start_angle(35);
|
||||
$pie->add_animation(new pie_fade());
|
||||
$pie->add_animation(new pie_bounce(10));
|
||||
$pie->set_tooltip('#val# '._('of').' #total#<br>#percent# '._('of').' 100%');
|
||||
$pie->set_colours($this->colors);
|
||||
|
||||
$values = array();
|
||||
foreach($data as $key => $value) {
|
||||
$values[] = new pie_value($value, $key);
|
||||
}
|
||||
|
||||
$pie->set_values($values);
|
||||
$pie->gradient_fill();
|
||||
|
||||
// create chart
|
||||
$this->chart = new open_flash_chart();
|
||||
$this->chart->x_axis = null;
|
||||
$this->chart->set_bg_colour($this->bgColor);
|
||||
$this->chart->set_title($title);
|
||||
$this->chart->add_element($pie);
|
||||
}
|
||||
}
|
||||
|
||||
?>
|
@@ -587,9 +587,22 @@ foreach ($used_queries as $name => $value) {
|
||||
?>
|
||||
</tbody>
|
||||
</table>
|
||||
<div>
|
||||
<?php echo PMA_chart_pie($used_queries); ?>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<table>
|
||||
<tr><td>
|
||||
<?php
|
||||
// format keys which will be shown in the chart
|
||||
$chart_data = array();
|
||||
foreach($used_queries as $key => $value) {
|
||||
$key = str_replace(array('Com_', '_'), array('', ' '), $key);
|
||||
$chart_data[ucwords($key)] = (int)$value;
|
||||
}
|
||||
echo PMA_chart_pie(__('Query type'), $chart_data);
|
||||
?>
|
||||
</td></tr>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<div id="serverstatussection">
|
||||
|
Reference in New Issue
Block a user