如何将base64解码图像添加到openlayer地图?

时间:2015-07-10 14:51:41

标签: javascript html5 openlayers-3

这是我的版本。但它没有用。显示画布,但不响应拖轮和缩放。

               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()
                })
            });

2 个答案:

答案 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 
        })
    });