| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 | <?php/* This datasource returns a response in the form of a google query responseUSAGEAll parameters are optionaldatasource.php?xmin=0&xmax=314&xstepnum=25&ymin=0&ymax=314&ystepnum=25DOCUMENTATIONhttp://code.google.com/apis/visualization/documentation/dev/implementing_data_source.htmlEXAMPLE OF A RESPONSE FILENote 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}]}    ]  }});________________________________________________________________________________*//** * 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 responseecho "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 responseecho "          ]  }});";/** * 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;}?>
 |