簡體   English   中英

Node.js googlemaps集群執行錯誤

[英]Node.js googlemaps cluster execute error

我現在使用node.js平台。 而且我想使用googlemap集群庫。 但是我無法執行源代碼。

googlemaps群集api網址: https : //github.com/googlemaps/js-marker-clusterer

該庫的索引如下。

  • 檔案
  • 例子
  • 圖片
  • src
  • 等等..

在示例目錄中,我想測試一個“ simple_example.html”。

我的node.js源代碼如下。

[app.js]

var express = require("express");
var app = express();
app.set('view engine','ejs');
var path = require("path");
app.set("public", path.join(__dirname, "public"));

app.get('/', function(req, res){
    res.render("simple_example", {} )
});

app.listen(3000);
console.log("Running at Port 3000");

[simple_example.ejs](重要的腳本部分)

<script src="https://maps.googleapis.com/maps/api/js"></script>
<script src="public/data.json"></script>
<script type="text/javascript" src="public/src/markerclusterer.js"></script>

<script>
  function initialize() {
    var center = new google.maps.LatLng(37.4419, -122.1419);

    var map = new google.maps.Map(document.getElementById('map'), {
      zoom: 3,
      center: center,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });

    var markers = [];
    for (var i = 0; i < 100; i++) {
      var dataPhoto = data.photos[i];
      var latLng = new google.maps.LatLng(dataPhoto.latitude,
          dataPhoto.longitude);
      var marker = new google.maps.Marker({
        position: latLng
      });
      markers.push(marker);
    }
    var markerCluster = new MarkerClusterer(map, markers, {imagePath: 'public/images/m'});
  }
  google.maps.event.addDomListener(window, 'load', initialize);
</script>

在此處輸入圖片說明

這張圖片是我的源代碼執行的結果。 但圖片在地圖上沒有標記。 我期望下面的圖片。

在此處輸入圖片說明

我嘗試更改src的路徑,更改Web平台(如python),但無法解決問題。 誰知道解決方案?

創建標記集群后,可通過使用addMarker()方法或向構造函數提供標記數組來支持它。

當他們說通過提供標記數組將標記添加到構造函數時,它類似於執行以下操作:

var markers = []; //create a global array where you store your markers
for (var i = 0; i < 100; i++) {
var latLng = new google.maps.LatLng(data.photos[i].latitude,
data.photos[i].longitude);
var marker = new google.maps.Marker({'position': latLng});
markers.push(marker); //push individual marker onto global array
}
var markerCluster = new MarkerClusterer(map, markers); //create clusterer and push the global array of markers into it.

要使用addMarker()添加它,您基本上可以將其添加到集群中,如下所示:

var markerCluster //cluster object created on global scope

//do your marker creation and add it like this:
markerCluster.addMarker(newMarker, true); //if specify true it'll redraw the map

這是對MarkerCluster的引用: https ://googlemaps.github.io/js-marker-clusterer/docs/examples.html

另外,這是一個演示應用程序如何使用markercluster: https : //github.com/googlemaps/js-marker-clusterer

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM