Google Maps Rectangle方法包含bug

时间:2012-11-01 12:14:37

标签: javascript google-maps geolocation prototypejs

好吧,我有一个谷歌地图实例,我有一个TraceHandler。这让用户按城市地图制作线条。通过这些线路,我使用谷歌DirectionsRoute服务来生成路线。该服务返回各种信息,重新启动* overview_path。在我的路线中包含所有方向点。通过这些点我创建三角形如下:

            var triangle;
            for (var indexerTrian = 0; indexerTrian < self.bounds.length; indexerTrian++) {

                if (indexerTrian + 1 == self.bounds.length) break;

                var maxLng = self.bounds[indexerTrian].lng() < self.bounds[indexerTrian + 1].lng() ? self.bounds[indexerTrian].lng() : self.bounds[indexerTrian + 1].lng();
                var minLng = self.bounds[indexerTrian].lng() > self.bounds[indexerTrian + 1].lng() ? self.bounds[indexerTrian].lng() : self.bounds[indexerTrian + 1].lng();

                var latLngSouthWest = new gMap.LatLng(self.bounds[indexerTrian].lat(), maxLng);
                var latLngNorthEast = new gMap.LatLng(self.bounds[indexerTrian + 1].lat(), minLng);

                triangle= new gMap.LatLngBounds(latLngSouthWest, latLngNorthEast);

                self.triangles.push(triangle);
            }

此例程的第三部分使用这些三角形在路线中带点。一些代码:

//for each point
for (var i in result.page) {
                    stopPoint = result.page[i];
                    latLng = new gMap.LatLng(stopPoint.latitude, stopPoint.longitude);

                    //for each triangle
                    for (var iTrian = 0; iTrian < self.triangles.length; iTrian++) {

                        //this guy verify if the stopPoint is inside the triangle.
                        //if so. Drop it on map
                        if (self.triangles[iTrian].contains(latLng)) {

                            //this method just generate a Marker instance.
                            self.SetaMarkers(latLng, iconMarker, stopPoint.descricao, true);
                            counter++;
                            break;
                        }
                        //this is a DEBUG if who prints all points if my loop comes to 
                        //end
                        else if ((iTrian + 1) == self.triangles.length) {

                            self.SetaMarkers(latLng, null, stopPoint.descricao, true);
                            //break;
                        }
                    }
                }

这很好用。执行时没有错误。但对于我改变de Longitude的那些三角形,他们的 .contains 不起作用。这可能是一个错误。

这是一张展示的图片。我打印三角形进行调试:http://s7.postimage.org/ek3prgryj/Map.png你们可以在图像中看到。 正常红色标记是超出所有三角形边界的 stopPoint 。那些带有编辑过的图像的是某些三角形范围内的 stopPoints

我已经尝试了很多东西..现在我要打印每个三角形的中心,看看它是否必须在哪里。

1 个答案:

答案 0 :(得分:0)

在25米的路线后使用25米的圆圈解决了这个问题。现在,我可以让用户设置 radius ,这样就可以获得所有人。