这是我的版本。但它没有用。显示画布,但不响应拖轮和缩放。
var layer = new ol.layer.Image({
source: new ol.source.ImageCanvas({
canvasFunction: function(){
var canvas = document.createElement('canvas');
var context = canvas.getContext('2d');
var image = new Image();
canvas.setAttribute('width', attachment.width);
canvas.setAttribute('height', attachment.height);
image.onload = function(){
context.drawImage(image, 0, 0);
};
image.src = attachment.src;
return canvas;
},
projection: view.getProjection()
})
});
答案 0 :(得分:3)
我找到答案!只需使用ol.source.ImageStatic和imageLoadFunction:
var layer = new ol.layer.Image({
source : new ol.source.ImageStatic({
imageExtent : view.getProjection().getExtent(),
size : [attachment.width, attachment.height],
imageLoadFunction : function(image){
image.getImage().src = attachment.src;
},
projection : view.getProjection(),
url : ''
})
});
答案 1 :(得分:0)
这有效(真实代码):
var projection = ol.proj.get('EPSG:3857');
var bing = new ol.layer.Tile({
source: new ol.source.BingMaps({
imagerySet: 'Aerial',
key: 'yourBingKey'
})
});
var minLon = -40.145761184967;
var minLat = -12.838585358413;
var maxLon = -40.13793299178;
var maxLat = -12.830532582642;
var extent = new ol.extent.applyTransform([minLon, minLat, maxLon, maxLat], ol.proj.getTransform("EPSG:4326","EPSG:3857"));
var src = "";
var pngImageBase64Layer = new ol.layer.Image({
source: new ol.source.ImageStatic({
imageExtent: extent,
imageLoadFunction : function(image){
image.getImage().src = src;
}
})
});
var map = new ol.Map({
layers: [bing, pngImageBase64Layer],
target: document.getElementById('map'),
view: new ol.View({
center: ol.proj.fromLonLat([-40.135,-12.83]),
projection: projection,
zoom: 14
})
});