OpenLayers3 WMTS内存不足错误

时间:2017-01-07 21:52:11

标签: javascript out-of-memory openlayers-3 wms

我正在尝试从WMST服务器获取英国的天气雷达数据。

客户可以使功能正常。之后,浏览器(Chrome和Firefox)在一段时间后崩溃,出现内存不足错误。

与简单示例相比,在我的案例中唯一明显不同的是,与服务器的所有交互都需要 API密钥

  var parser = new ol.format.WMTSCapabilities();
  var map;

  //I pass the API key here
  fetch('http://datapoint.metoffice.gov.uk/public/data/inspire/view/wmts?REQUEST=GetCapabilities&key=my_key_goes_here').then(function(response) {
    return response.text();
  }).then(function(text) {
    console.log('Capabilities found.'); //ok

    var result = parser.read(text);
    var options = ol.source.WMTS.optionsFromCapabilities(result, {
        layer: 'RADAR_UK_Composite_Highres', 
        matrixSet: 'EPSG:4326'
    });

    map = new ol.Map({
      layers: [
        new ol.layer.Tile({
          source: new ol.source.OSM(),
          opacity: 0.7
        }),
        new ol.layer.Tile({ //fails when this Tile is included
          opacity: 1,
          source: new ol.source.WMTS(options),
          //I set this,  figuring that the API key is still needed
          url: 'http://datapoint.metoffice.gov.uk/public/data/inspire/view/wmts?my_key_goes_here'
        })
      ],
      target: 'mymap',
      view: new ol.View({
        center: ol.proj.fromLonLat([0, 52.0]),   //near London, UK
        zoom: 7
      })
    });
  });

崩溃发生没有客户端尝试获取磁贴(因为我在调试器中看不到任何HTTP请求;最后一个是get-capabilities请求)。

有关可能导致此问题的任何提示?

1 个答案:

答案 0 :(得分:1)

首先,请注意ol.layer.Tile没有url选项。理想情况下,GetCapabilities响应会通告已具有密钥的服务URL。由于您尝试访问的服务器不具备此功能,因此您必须调整从GetCapabilities响应获得的result

result.OperationsMetadata.GetTile.DCP.HTTP.Get[0].href += 'key=my_key_goes_here&'

第二个也是更严重的问题是GetCapabilities响应通告了不正确的比例分母和起源。要解决这些问题,您必须再次调整结果:

result.Contents.TileMatrixSet[0].TileMatrix.forEach(function(m) {
  m.ScaleDenominator *= 111319.49079327358;
  m.TopLeftCorner = m.TopLeftCorner.reverse();
});

应用这些调整后,您可以将result传递给ol.source.WMTS.optionsFromCapabilities,然后您将获得正确的地图。

我强烈建议您联系服务提供商(联系信息也可以在GetCapabilities响应中找到),并告诉他们GetCapabilities响应的问题。