我正在尝试从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请求)。
有关可能导致此问题的任何提示?
答案 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响应的问题。