我正在尝试执行 node+geo-stuff 以从给定的纬度、经度和半径中检索所有位置以进行该计算,我正在尝试以下内容,但它会导致 NaN。
类似的代码在 php,python 中运行良好,但无法弄清楚我在这里做错了什么。
参考:http ://www.scribd.com/doc/2569355/Geo-Distance-Search-with-MySQL
PS 1:使用 nodejs 进行此计算,因为它需要在服务器端进行计算。PS 2:甚至变量名看起来像php变量,它是js。
$cat file.js
var log =console.log;
var cos=Math.cos;
var sin=Math.sin;
function rad2deg(x){ log("rad2deg:", x,180*x/Math.pi);return (180*x/Math.pi);}
function deg2rad(x){ log("deg2rad:",x,x*Math.pi/180);return (x*Math.pi/180);}
function getNearPoint($lat,$lng,$rad){
console.log("Debug1",$lat,$lng);
$R = 6371; // earth's radius, km
// first-cut bounding box (in degrees)
$maxLat = $lat + rad2deg($rad/$R);
$minLat = $lat - rad2deg($rad/$R);
console.log("Debug2",$lat,$lng);
// compensate for degrees lnggitude getting smaller with increasing latitude
$maxlng = $lng + rad2deg($rad/$R/cos(deg2rad($lat)));
$minlng = $lng - rad2deg($rad/$R/cos(deg2rad($lat)));
console.log("Debug3",$lat,$lng);
// convert origin of filter circle to radians
$lat = deg2rad($lat);
$lng = deg2rad($lng);
console.log("Debug4",$lat,$lng);
//Build database query and do rest of the stuff
}
getNearPoint(19.1947659,72.8768400,50);
这是输出。
$ node file.js
Debug1 19.1947659 72.87684
rad2deg: 0.007848061528802385 NaN
rad2deg: 0.007848061528802385 NaN
Debug2 19.1947659 72.87684
deg2rad: 19.1947659 NaN
rad2deg: NaN NaN
deg2rad: 19.1947659 NaN
rad2deg: NaN NaN
Debug3 19.1947659 72.87684
deg2rad: 19.1947659 NaN
deg2rad: 72.87684 NaN
Debug4 NaN NaN