0

ユーザーからの入力で受け取った緯度と経度の座標を使用して、leaflet.js でマップを視覚化しています。その際、バックグラウンドでヒートマップを計算します (たとえば、選択した座標を囲む 5 km 幅のエリアの人口密度マップ)。

ヒートマップをマップにオーバーレイするにはどうすればよいですか?

これまでに得たものは次のとおりです。マップを生成するためのhtmlファイルと、バックグラウンド計算によって作成された.jsファイルで、選択した座標、いくつかのポリゴンまたは関心を保存し、ラスターマップを保存/ポイントしたい場所です私はその地域のために生成します。

<!DOCTYPE html>
<html>
<head>
  <title>Testmap</title>
  <script src="http://d3js.org/d3.v3.min.js"></script>
  <script src="http://d3js.org/topojson.v1.min.js"></script>
  <style>
    @import url(http://cdn.leafletjs.com/leaflet-0.6.1/leaflet.css);
    #overlay{
      fill:None;
      stroke:#ff00ff;
      stroke-width:4px;
    }
  </style>
</head>
<body>
  <div id="map" style="width: 960px; height: 600px"></div>
  <script src="http://cdn.leafletjs.com/leaflet-0.6.1/leaflet.js"
  </script>
  <script src="rois.js"></script>
  <script>
  var toolserver = L.tileLayer('http://{s}.www.toolserver.org/tiles/bw-mapnik/{z}/{x}/{y}.png');
  var stamen = L.tileLayer('http://{s}.tile.stamen.com/toner/{z}/{x}/{y}.png', {attribution: 'myMap'}).addTo(map);
  var baseLayers = {"stamen": stamen, "toolserver-mapnik":toolserver};

  var geojson = L.geoJson(rois, {
      onEachFeature: onEachFeature
  }).addTo(map)

  var overlays = {
      "geoJson": geojson
  };

  function onEachFeature(feature, layer){
    if (feature.properties) {
      layer.bindPopup("<b>" + feature.properties.street + "</b> is " + feature.properties.length + "km long.");
    }
  }

  var svgContainer= d3.select(map.getPanes().overlayPane).append("svg");
  var group= svgContainer.append("g").attr("class", "leaflet-zoom-hide");
  var path = d3.geo.path().projection(project);
  function project(point) {
    var latlng = new L.LatLng(point[1], point[0]);
    var layerPoint = map.latLngToLayerPoint(latlng);
    return [layerPoint.x, layerPoint.y];
  }  

  </script>
 </body>
</html>

ファイル rois.js は私のプログラムによってバックグラウンドで生成され、選択された座標とマップ上に描画されるいくつかのポリゴンが含まれています。ここにラスター情報を含める方法を理解したいと思います。

var map = L.map('map').setView([52.500,13.385], 13);
var rois = [{
  "type": "FeatureCollection",                                                                        
  "features": [{
    "type": "Feature",
    "id": 1, 
    "geometry": {
      "type": "Polygon",
      "coordinates": [[[13.370, 52.491], [13.400, 52.491], [13.400, 52.509],[13.370, 52.509],[13.370, 52.491]]]
    }
  },
  { "type": "Feature",
    "id": 2, 
    "geometry": {
      "type": "Polygon",
      "coordinates": [[[13.415, 52.496], [13.425, 52.505], [13.435, 52.496], [13.415, 52.496]]]
    }
  }]
}];

ありがとうFP

4

1 に答える 1

0

ヒートマップを生成するリーフレット プラグインを参照してください (リーフレットのバージョンを更新してください。0.6.x は 3 年以上前のものです)。

于 2016-05-13T08:28:11.063 に答える