Scale StaticImage image to imageExtent
The imageSize property was only used to determine the scale. It's usage was never documented nor tested nor shown in an example, so I removed it because I considered its presence a bug.
This commit is contained in:
@@ -4935,7 +4935,6 @@ olx.source.StamenOptions.prototype.url;
|
|||||||
* @typedef {{attributions: (Array.<ol.Attribution>|undefined),
|
* @typedef {{attributions: (Array.<ol.Attribution>|undefined),
|
||||||
* crossOrigin: (null|string|undefined),
|
* crossOrigin: (null|string|undefined),
|
||||||
* imageExtent: (ol.Extent),
|
* imageExtent: (ol.Extent),
|
||||||
* imageSize: (ol.Size|undefined),
|
|
||||||
* imageLoadFunction: (ol.ImageLoadFunctionType|undefined),
|
* imageLoadFunction: (ol.ImageLoadFunctionType|undefined),
|
||||||
* logo: (string|olx.LogoOptions|undefined),
|
* logo: (string|olx.LogoOptions|undefined),
|
||||||
* projection: ol.proj.ProjectionLike,
|
* projection: ol.proj.ProjectionLike,
|
||||||
@@ -4974,14 +4973,6 @@ olx.source.ImageStaticOptions.prototype.crossOrigin;
|
|||||||
olx.source.ImageStaticOptions.prototype.imageExtent;
|
olx.source.ImageStaticOptions.prototype.imageExtent;
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Size of the image in pixels.
|
|
||||||
* @type {ol.Size|undefined}
|
|
||||||
* @api stable
|
|
||||||
*/
|
|
||||||
olx.source.ImageStaticOptions.prototype.imageSize;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Optional function to load an image given a URL.
|
* Optional function to load an image given a URL.
|
||||||
* @type {ol.TileLoadFunctionType|undefined}
|
* @type {ol.TileLoadFunctionType|undefined}
|
||||||
|
|||||||
@@ -35,7 +35,7 @@ ol.Image = function(extent, resolution, pixelRatio, attributions, src,
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @private
|
* @private
|
||||||
* @type {Image}
|
* @type {HTMLCanvasElement|Image|HTMLVideoElement}
|
||||||
*/
|
*/
|
||||||
this.image_ = new Image();
|
this.image_ = new Image();
|
||||||
if (crossOrigin) {
|
if (crossOrigin) {
|
||||||
@@ -44,7 +44,7 @@ ol.Image = function(extent, resolution, pixelRatio, attributions, src,
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* @private
|
* @private
|
||||||
* @type {Object.<number, Image>}
|
* @type {Object.<number, (HTMLCanvasElement|Image|HTMLVideoElement)>}
|
||||||
*/
|
*/
|
||||||
this.imageByContext_ = {};
|
this.imageByContext_ = {};
|
||||||
|
|
||||||
@@ -142,6 +142,14 @@ ol.Image.prototype.load = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {HTMLCanvasElement|Image|HTMLVideoElement} image Image.
|
||||||
|
*/
|
||||||
|
ol.Image.prototype.setImage = function(image) {
|
||||||
|
this.image_ = image;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Discards event handlers which listen for load completion or errors.
|
* Discards event handlers which listen for load completion or errors.
|
||||||
*
|
*
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ goog.require('goog.events');
|
|||||||
goog.require('goog.events.EventType');
|
goog.require('goog.events.EventType');
|
||||||
goog.require('ol.Image');
|
goog.require('ol.Image');
|
||||||
goog.require('ol.ImageLoadFunctionType');
|
goog.require('ol.ImageLoadFunctionType');
|
||||||
|
goog.require('ol.ImageState');
|
||||||
goog.require('ol.extent');
|
goog.require('ol.extent');
|
||||||
goog.require('ol.proj');
|
goog.require('ol.proj');
|
||||||
goog.require('ol.source.Image');
|
goog.require('ol.source.Image');
|
||||||
@@ -26,12 +27,6 @@ ol.source.ImageStatic = function(options) {
|
|||||||
|
|
||||||
var imageExtent = options.imageExtent;
|
var imageExtent = options.imageExtent;
|
||||||
|
|
||||||
var resolution, resolutions;
|
|
||||||
if (options.imageSize !== undefined) {
|
|
||||||
resolution = ol.extent.getHeight(imageExtent) / options.imageSize[1];
|
|
||||||
resolutions = [resolution];
|
|
||||||
}
|
|
||||||
|
|
||||||
var crossOrigin = options.crossOrigin !== undefined ?
|
var crossOrigin = options.crossOrigin !== undefined ?
|
||||||
options.crossOrigin : null;
|
options.crossOrigin : null;
|
||||||
|
|
||||||
@@ -42,16 +37,34 @@ ol.source.ImageStatic = function(options) {
|
|||||||
goog.base(this, {
|
goog.base(this, {
|
||||||
attributions: attributions,
|
attributions: attributions,
|
||||||
logo: options.logo,
|
logo: options.logo,
|
||||||
projection: ol.proj.get(options.projection),
|
projection: ol.proj.get(options.projection)
|
||||||
resolutions: resolutions
|
|
||||||
});
|
});
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @private
|
* @private
|
||||||
* @type {ol.Image}
|
* @type {ol.Image}
|
||||||
*/
|
*/
|
||||||
this.image_ = new ol.Image(imageExtent, resolution, 1, attributions,
|
this.image_ = new ol.Image(imageExtent, undefined, 1, attributions,
|
||||||
options.url, crossOrigin, imageLoadFunction);
|
options.url, crossOrigin, imageLoadFunction);
|
||||||
|
|
||||||
|
goog.events.listen(this.image_, goog.events.EventType.CHANGE, function() {
|
||||||
|
if (this.image_.getState() == ol.ImageState.LOADED) {
|
||||||
|
var image = this.image_.getImage();
|
||||||
|
var resolution = ol.extent.getHeight(imageExtent) / image.height;
|
||||||
|
var pxWidth = Math.ceil(ol.extent.getWidth(imageExtent) / resolution);
|
||||||
|
var pxHeight = Math.ceil(ol.extent.getHeight(imageExtent) / resolution);
|
||||||
|
if (pxWidth !== image.width || pxHeight !== image.height) {
|
||||||
|
var canvas = /** @type {HTMLCanvasElement} */
|
||||||
|
(document.createElement('canvas'));
|
||||||
|
canvas.width = pxWidth;
|
||||||
|
canvas.height = pxHeight;
|
||||||
|
var context = canvas.getContext('2d');
|
||||||
|
context.drawImage(image, 0, 0, canvas.width, canvas.height);
|
||||||
|
this.image_.setImage(canvas);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, false, this);
|
||||||
|
|
||||||
goog.events.listen(this.image_, goog.events.EventType.CHANGE,
|
goog.events.listen(this.image_, goog.events.EventType.CHANGE,
|
||||||
this.handleImageChange, false, this);
|
this.handleImageChange, false, this);
|
||||||
|
|
||||||
|
|||||||
@@ -14,14 +14,32 @@ describe('ol.source.ImageStatic', function() {
|
|||||||
|
|
||||||
describe('#getImage', function() {
|
describe('#getImage', function() {
|
||||||
|
|
||||||
|
it('scales image to fit imageExtent', function(done) {
|
||||||
|
var source = new ol.source.ImageStatic({
|
||||||
|
url: 'spec/ol/source/images/12-655-1583.png',
|
||||||
|
imageExtent: [
|
||||||
|
-13629027.891360067, 4539747.983913189,
|
||||||
|
-13619243.951739565, 4559315.863154193],
|
||||||
|
projection: projection
|
||||||
|
});
|
||||||
|
|
||||||
|
source.on('imageloadend', function(event) {
|
||||||
|
expect(image.getImage().width).to.be(128);
|
||||||
|
expect(image.getImage().height).to.be(256);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
|
||||||
|
var image = source.getImage(extent, resolution, pixelRatio, projection);
|
||||||
|
image.load();
|
||||||
|
});
|
||||||
|
|
||||||
it('triggers image load events', function(done) {
|
it('triggers image load events', function(done) {
|
||||||
var source = new ol.source.ImageStatic({
|
var source = new ol.source.ImageStatic({
|
||||||
url: 'spec/ol/source/images/12-655-1583.png',
|
url: 'spec/ol/source/images/12-655-1583.png',
|
||||||
imageExtent: [
|
imageExtent: [
|
||||||
-13629027.891360067, 4539747.983913189,
|
-13629027.891360067, 4539747.983913189,
|
||||||
-13619243.951739565, 4549531.923533691],
|
-13619243.951739565, 4549531.923533691],
|
||||||
projection: projection,
|
projection: projection
|
||||||
imageSize: [256, 256]
|
|
||||||
});
|
});
|
||||||
|
|
||||||
var imageloadstart = sinon.spy();
|
var imageloadstart = sinon.spy();
|
||||||
|
|||||||
BIN
test_rendering/spec/ol/layer/expected/image-scaled.png
Normal file
BIN
test_rendering/spec/ol/layer/expected/image-scaled.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 1.1 KiB |
@@ -82,6 +82,31 @@ describe('ol.rendering.layer.Image', function() {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
describe('single image layer - scaled', function() {
|
||||||
|
var source;
|
||||||
|
|
||||||
|
beforeEach(function() {
|
||||||
|
source = new ol.source.ImageStatic({
|
||||||
|
url: 'spec/ol/data/tiles/osm/5/5/12.png',
|
||||||
|
imageExtent: ol.proj.transformExtent(
|
||||||
|
[-123, 37, -122, 38], 'EPSG:4326', 'EPSG:3857')
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(function() {
|
||||||
|
disposeMap(map);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('renders correctly', function(done) {
|
||||||
|
map = createMap('canvas');
|
||||||
|
waitForImages([source], {}, function() {
|
||||||
|
expectResemble(map, 'spec/ol/layer/expected/image-scaled.png',
|
||||||
|
IMAGE_TOLERANCE, done);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
goog.require('goog.object');
|
goog.require('goog.object');
|
||||||
|
|||||||
Reference in New Issue
Block a user