Bing使用群集映射方向

时间:2017-12-21 08:10:16

标签: bing-maps

我可以使用机动点绘制地图。

以下是地图的屏幕截图

enter image description here

以下是路由的代码。

var maneuverPoints = this.model.get("maneuverPoints");
        if (maneuverPoints) {
            var routePoints = [];
            _.each(maneuverPoints, function (point) {
                routePoints.push(new MsMaps.Location(point.latitude, point.longitude));
            });
            var routeOptions = {
                strokeColor: new MsMaps.Color(1, 65, 255, 35),
                strokeThickness: 3
            };
            var routeShape = new MsMaps.Polyline(routePoints, routeOptions);
            map.entities.push(routeShape);
        }

现在我正在尝试实现群集,我可以按照以下方式执行:

enter image description here

粉色图钉是簇。

群集代码如下:

Microsoft.Maps.loadModule(“Microsoft.Maps.Clustering”,function(){

                var clusterLayer = new Microsoft.Maps.ClusterLayer(pushpins);
                map.layers.insert(clusterLayer);

                clusterLayer.setPushpins(pushpins);
                map.setView(viewOptions);
                var maneuverPoints = this.model.get("maneuverPoints");
                if (maneuverPoints) {
                    var routePoints = [];
                    _.each(maneuverPoints, function (point) {
                        routePoints.push(new MsMaps.Location(point.latitude, point.longitude));
                    });
                    var routeOptions = {
                        strokeColor: new MsMaps.Color(1, 65, 255, 35),
                        strokeThickness: 3
                    };
                    var routeShape = new MsMaps.Polyline(routePoints, routeOptions);
                    map.entities.push(routeShape);
                }

我无法同时进行群集和路由。是否有可能同时做两件事?

1 个答案:

答案 0 :(得分:0)

您的代码没有根据事物的外观进行路由,它只是采用路线线点并将它们渲染为折线。我没有看到代码中使用的指示模块。如果您正在使用该指示模块,为什么不简单地使用内置渲染?您可以自定义它的外观。如果您继续使用折线,请考虑将其添加到图层,以便日后管理。

也就是说,您提供的代码只是聚类和绘制折线。当我测试这个场景时,这很好用。

您在集群层中调用setPushpins的原因是什么?您在创建图层时已经通过了图钉,无需再次传入它们。