|
|
- <?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;
- }
-
-
- ?>
|