<?php
|
|
|
|
/*
|
|
This datasource returns a response in the form of a google query response
|
|
|
|
USAGE
|
|
All parameters are optional
|
|
datasource.php?xmin=0&xmax=314&xstepnum=25&ymin=0&ymax=314&ystepnum=25
|
|
|
|
DOCUMENTATION
|
|
http://code.google.com/apis/visualization/documentation/dev/implementing_data_source.html
|
|
|
|
|
|
EXAMPLE OF A RESPONSE FILE
|
|
|
|
Note that the reqId in the response must correspond with the reqId from the
|
|
request.
|
|
________________________________________________________________________________
|
|
|
|
google.visualization.Query.setResponse({
|
|
version:'0.6',
|
|
reqId:'0',
|
|
status:'ok',
|
|
table:{
|
|
cols:[
|
|
{id:'x',
|
|
label:'x',
|
|
type:'number'},
|
|
{id:'y',
|
|
label:'y',
|
|
type:'number'},
|
|
{id:'value',
|
|
label:'value',
|
|
type:'number'}
|
|
],
|
|
rows:[
|
|
{c:[{v:0}, {v:0}, {v:10.0}]},
|
|
{c:[{v:1}, {v:0}, {v:12.0}]},
|
|
{c:[{v:2}, {v:0}, {v:13.0}]},
|
|
{c:[{v:0}, {v:1}, {v:11.0}]},
|
|
{c:[{v:1}, {v:1}, {v:14.0}]},
|
|
{c:[{v:2}, {v:1}, {v:11.0}]}
|
|
]
|
|
}
|
|
});
|
|
________________________________________________________________________________
|
|
|
|
*/
|
|
|
|
header('Content-type: text/plain');
|
|
|
|
/**
|
|
* A custom function
|
|
*/
|
|
function custom($x, $y) {
|
|
$d = sqrt(pow($x/100, 2) + pow($y/100, 2));
|
|
|
|
return 50 * exp(-5 * $d / 10) * sin($d*5);
|
|
}
|
|
|
|
|
|
|
|
|
|
// retrieve parameters
|
|
$default_stepnum = 25;
|
|
|
|
$xmin = isset($_REQUEST['xmin']) ? (float)$_REQUEST['xmin'] : -100;
|
|
$xmax = isset($_REQUEST['xmax']) ? (float)$_REQUEST['xmax'] : 100;
|
|
$xstepnum = isset($_REQUEST['xstepnum']) ? (int)$_REQUEST['xstepnum'] : $default_stepnum;
|
|
|
|
$ymin = isset($_REQUEST['ymin']) ? (float)$_REQUEST['ymin'] : -100;
|
|
$ymax = isset($_REQUEST['ymax']) ? (float)$_REQUEST['ymax'] : 100;
|
|
$ystepnum = isset($_REQUEST['ystepnum']) ? (int)$_REQUEST['ystepnum'] : $default_stepnum;
|
|
|
|
// in the reply we must fill in the request id that came with the request
|
|
$reqId = getReqId();
|
|
|
|
// check for a maximum number of datapoints (for safety)
|
|
if ($xstepnum * $ystepnum > 10000) {
|
|
echo "google.visualization.Query.setResponse({
|
|
version:'0.6',
|
|
reqId:'$reqId',
|
|
status:'error',
|
|
errors:[{reason:'not_supported', message:'Maximum number of datapoints exceeded'}]
|
|
});";
|
|
|
|
exit;
|
|
}
|
|
|
|
|
|
// output the header part of the response
|
|
echo "google.visualization.Query.setResponse({
|
|
version:'0.6',
|
|
reqId:'$reqId',
|
|
status:'ok',
|
|
table:{
|
|
cols:[
|
|
{id:'x',
|
|
label:'x',
|
|
type:'number'},
|
|
{id:'y',
|
|
label:'y',
|
|
type:'number'},
|
|
{id:'value',
|
|
label:'',
|
|
type:'number'}
|
|
],
|
|
rows:[";
|
|
|
|
// output the actual values
|
|
$first = true;
|
|
$xstep = ($xmax - $xmin) / $xstepnum;
|
|
$ystep = ($ymax - $ymin) / $ystepnum;
|
|
for ($x = $xmin; $x < $xmax; $x+=$xstep) {
|
|
for ($y = $ymin; $y < $ymax; $y+=$ystep) {
|
|
$value = custom($x,$y);
|
|
|
|
if (!$first) {
|
|
echo ",\n";
|
|
}
|
|
else {
|
|
echo "\n";
|
|
}
|
|
echo " {c:[{v:$x}, {v:$y}, {v:$value}]}";
|
|
|
|
$first = false;
|
|
}
|
|
}
|
|
|
|
|
|
// output the end part of the response
|
|
echo "
|
|
]
|
|
}
|
|
});
|
|
";
|
|
|
|
|
|
/**
|
|
* Retrieve the request id from the get/post data
|
|
* @return {number} $reqId The request id, or 0 if not found
|
|
*/
|
|
function getReqId() {
|
|
$reqId = 0;
|
|
|
|
foreach ($_REQUEST as $req) {
|
|
if (substr($req, 0,6) == "reqId:") {
|
|
$reqId = substr($req, 6);
|
|
}
|
|
}
|
|
|
|
return $reqId;
|
|
}
|
|
|
|
|
|
?>
|