UNPKG

openlayers

Version:

Build tools and sources for developing OpenLayers based mapping applications

235 lines (199 loc) 5.91 kB
goog.provide('ol.source.Image'); goog.require('ol'); goog.require('ol.Image'); goog.require('ol.array'); goog.require('ol.events.Event'); goog.require('ol.extent'); goog.require('ol.proj'); goog.require('ol.reproj.Image'); goog.require('ol.source.Source'); /** * @classdesc * Abstract base class; normally only used for creating subclasses and not * instantiated in apps. * Base class for sources providing a single image. * * @constructor * @extends {ol.source.Source} * @param {ol.SourceImageOptions} options Single image source options. * @api */ ol.source.Image = function(options) { ol.source.Source.call(this, { attributions: options.attributions, extent: options.extent, logo: options.logo, projection: options.projection, state: options.state }); /** * @private * @type {Array.<number>} */ this.resolutions_ = options.resolutions !== undefined ? options.resolutions : null; ol.DEBUG && console.assert(!this.resolutions_ || ol.array.isSorted(this.resolutions_, function(a, b) { return b - a; }, true), 'resolutions must be null or sorted in descending order'); /** * @private * @type {ol.reproj.Image} */ this.reprojectedImage_ = null; /** * @private * @type {number} */ this.reprojectedRevision_ = 0; }; ol.inherits(ol.source.Image, ol.source.Source); /** * @return {Array.<number>} Resolutions. */ ol.source.Image.prototype.getResolutions = function() { return this.resolutions_; }; /** * @protected * @param {number} resolution Resolution. * @return {number} Resolution. */ ol.source.Image.prototype.findNearestResolution = function(resolution) { if (this.resolutions_) { var idx = ol.array.linearFindNearest(this.resolutions_, resolution, 0); resolution = this.resolutions_[idx]; } return resolution; }; /** * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @param {number} pixelRatio Pixel ratio. * @param {ol.proj.Projection} projection Projection. * @return {ol.ImageBase} Single image. */ ol.source.Image.prototype.getImage = function(extent, resolution, pixelRatio, projection) { var sourceProjection = this.getProjection(); if (!ol.ENABLE_RASTER_REPROJECTION || !sourceProjection || !projection || ol.proj.equivalent(sourceProjection, projection)) { if (sourceProjection) { projection = sourceProjection; } return this.getImageInternal(extent, resolution, pixelRatio, projection); } else { if (this.reprojectedImage_) { if (this.reprojectedRevision_ == this.getRevision() && ol.proj.equivalent( this.reprojectedImage_.getProjection(), projection) && this.reprojectedImage_.getResolution() == resolution && this.reprojectedImage_.getPixelRatio() == pixelRatio && ol.extent.equals(this.reprojectedImage_.getExtent(), extent)) { return this.reprojectedImage_; } this.reprojectedImage_.dispose(); this.reprojectedImage_ = null; } this.reprojectedImage_ = new ol.reproj.Image( sourceProjection, projection, extent, resolution, pixelRatio, function(extent, resolution, pixelRatio) { return this.getImageInternal(extent, resolution, pixelRatio, sourceProjection); }.bind(this)); this.reprojectedRevision_ = this.getRevision(); return this.reprojectedImage_; } }; /** * @abstract * @param {ol.Extent} extent Extent. * @param {number} resolution Resolution. * @param {number} pixelRatio Pixel ratio. * @param {ol.proj.Projection} projection Projection. * @return {ol.ImageBase} Single image. * @protected */ ol.source.Image.prototype.getImageInternal = function(extent, resolution, pixelRatio, projection) {}; /** * Handle image change events. * @param {ol.events.Event} event Event. * @protected */ ol.source.Image.prototype.handleImageChange = function(event) { var image = /** @type {ol.Image} */ (event.target); switch (image.getState()) { case ol.Image.State.LOADING: this.dispatchEvent( new ol.source.Image.Event(ol.source.Image.EventType.IMAGELOADSTART, image)); break; case ol.Image.State.LOADED: this.dispatchEvent( new ol.source.Image.Event(ol.source.Image.EventType.IMAGELOADEND, image)); break; case ol.Image.State.ERROR: this.dispatchEvent( new ol.source.Image.Event(ol.source.Image.EventType.IMAGELOADERROR, image)); break; default: // pass } }; /** * Default image load function for image sources that use ol.Image image * instances. * @param {ol.Image} image Image. * @param {string} src Source. */ ol.source.Image.defaultImageLoadFunction = function(image, src) { image.getImage().src = src; }; /** * @classdesc * Events emitted by {@link ol.source.Image} instances are instances of this * type. * * @constructor * @extends {ol.events.Event} * @implements {oli.source.ImageEvent} * @param {string} type Type. * @param {ol.Image} image The image. */ ol.source.Image.Event = function(type, image) { ol.events.Event.call(this, type); /** * The image related to the event. * @type {ol.Image} * @api */ this.image = image; }; ol.inherits(ol.source.Image.Event, ol.events.Event); /** * @enum {string} */ ol.source.Image.EventType = { /** * Triggered when an image starts loading. * @event ol.source.Image.Event#imageloadstart * @api */ IMAGELOADSTART: 'imageloadstart', /** * Triggered when an image finishes loading. * @event ol.source.Image.Event#imageloadend * @api */ IMAGELOADEND: 'imageloadend', /** * Triggered if image loading results in an error. * @event ol.source.Image.Event#imageloaderror * @api */ IMAGELOADERROR: 'imageloaderror' };