Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/408.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 从纬度和经度确定哪个是多边形_Javascript_Jquery_Polygon_Latitude Longitude_Leaflet - Fatal编程技术网

Javascript 从纬度和经度确定哪个是多边形

Javascript 从纬度和经度确定哪个是多边形,javascript,jquery,polygon,latitude-longitude,leaflet,Javascript,Jquery,Polygon,Latitude Longitude,Leaflet,我有一张使用传单.js绘制的地图。如果我输入经度和纬度值 我能识别多边形吗?我可以为此获取客户端脚本吗?得到如下答案: //这是基于“多边形中的点算法” function getPoint () { float x=-89.82421875; //x and y represents the lat and lng values float y= 40.18307014852533; var a = boundaries; //the coordinat

我有一张使用传单.js绘制的地图。如果我输入经度和纬度值
我能识别多边形吗?我可以为此获取客户端脚本吗?

得到如下答案:

//这是基于“多边形中的点算法”

function getPoint () {
     float x=-89.82421875;     //x and y represents the lat and lng values
     float y= 40.18307014852533;
    var a = boundaries;    //the coordinates used to draw the map
    for (i = 0; i < a.features.length; i++) {
        PointInPolygon(x,y, a.features[i].geometry.coordinates[0], i);
    }
};

function PointInPolygon(pointX, pointY, _vertices, number) {
        var j = _vertices.length - 1;
        var oddNodes = false;
        var polyX, polyY,polyXJ,polyYJ;

        for (var i = 0; i < _vertices.length; i++) {
            polyY = parseFloat(_vertices[i].toString().split(",")[1]);
            polyX = parseFloat(_vertices[i].toString().split(",")[0]);
            polyXJ = parseFloat(_vertices[j].toString().split(",")[0]);
            polyYJ = parseFloat(_vertices[j].toString().split(",")[1]);
            if (polyY < pointY && polyYJ >= pointY ||
                polyYJ < pointY && polyY >= pointY) {
                if (polyX +
                    (pointY - polyY) / (polyYJ - polyY) * (polyXJ - polyX) < pointX)  
                {  
                    oddNodes = !oddNodes;  
                }  
            }  
            j = i;
        }
        if (oddNodes == true) {
             map._layers[number+1].fire('click');             //fire the map click event
        } 
    }
函数getPoint(){
浮点数x=-89.82421875;//x和y表示lat和lng值
浮动y=40.1830701485233;
var a=边界;//用于绘制地图的坐标
对于(i=0;i=pointY||
polyYJ=pointY){
if(polyX+
(pointY-POLY)/(POLYJ-polyY)*(polyXJ-polyX)
您需要为多边形形状指定lat和lng值。如果您指定一个lat lng值,它将表示点。当指定更多lat lng值时,它将绘制多边形。lat lng的开始和结束应该相同。是的,在多边形(PIP)算法中查找大地测量点。我使用一些lat和lng值集绘制了一张地图。但现在我想从一组lat和lng值中知道多边形id。重复: