Merge remote-tracking branch 'openlayers/master' into vector-api

This commit is contained in:
Tom Payne
2013-12-13 21:35:29 +01:00
3 changed files with 65 additions and 76 deletions

View File

@@ -173,12 +173,12 @@
/** /**
* @typedef {Object} olx.control.DefaultsOptions * @typedef {Object} olx.control.DefaultsOptions
* @property {boolean|undefined} attribution Attribution. * @property {boolean|undefined} attribution Attribution. Default is `true`.
* @property {olx.control.AttributionOptions|undefined} attributionOptions * @property {olx.control.AttributionOptions|undefined} attributionOptions
* Attribution options. * Attribution options.
* @property {boolean|undefined} logo Logo. * @property {boolean|undefined} logo Logo. Default is `true`.
* @property {olx.control.LogoOptions|undefined} logoOptions Logo options. * @property {olx.control.LogoOptions|undefined} logoOptions Logo options.
* @property {boolean|undefined} zoom Zoom. * @property {boolean|undefined} zoom Zoom. Default is `true`.
* @property {olx.control.ZoomOptions|undefined} zoomOptions Zoom options. * @property {olx.control.ZoomOptions|undefined} zoomOptions Zoom options.
* @todo stability experimental * @todo stability experimental
*/ */
@@ -213,9 +213,10 @@
/** /**
* @typedef {Object} olx.control.ScaleLineOptions * @typedef {Object} olx.control.ScaleLineOptions
* @property {string|undefined} className CSS Class name. Default is `ol-scale-line`. * @property {string|undefined} className CSS Class name. Default is `ol-scale-line`.
* @property {number|undefined} minWidth Minimum width in pixels. * @property {number|undefined} minWidth Minimum width in pixels. Default is `64`.
* @property {Element|undefined} target Target. * @property {Element|undefined} target Target.
* @property {ol.control.ScaleLineUnits|undefined} units Units. * @property {ol.control.ScaleLineUnits|undefined} units Units.
* Default is `ol.control.ScaleLineUnits.METRIC`.
* @todo stability experimental * @todo stability experimental
*/ */
@@ -295,20 +296,20 @@
* Interactions for the map. Default is `true` for all options. * Interactions for the map. Default is `true` for all options.
* @typedef {Object} olx.interaction.DefaultsOptions * @typedef {Object} olx.interaction.DefaultsOptions
* @property {boolean|undefined} altShiftDragRotate Whether Alt-Shift-drag * @property {boolean|undefined} altShiftDragRotate Whether Alt-Shift-drag
* rotate is desired. * rotate is desired. Default is `true`.
* @property {boolean|undefined} doubleClickZoom Whether double click zoom is * @property {boolean|undefined} doubleClickZoom Whether double click zoom is
* desired. * desired. Default is `true`.
* @property {boolean|undefined} dragPan Whether drag-pan is desired. * @property {boolean|undefined} dragPan Whether drag-pan is desired. Default is `true`.
* @property {boolean|undefined} keyboard Whether keyboard interaction is * @property {boolean|undefined} keyboard Whether keyboard interaction is
* desired. * desired. Default is `true`.
* @property {boolean|undefined} mouseWheelZoom Whether mousewheel zoom is * @property {boolean|undefined} mouseWheelZoom Whether mousewheel zoom is
* desired. * desired. Default is `true`.
* @property {boolean|undefined} shiftDragZoom Whether Shift-drag zoom is * @property {boolean|undefined} shiftDragZoom Whether Shift-drag zoom is
* desired. * desired. Default is `true`.
* @property {boolean|undefined} touchPan Whether touch pan is * @property {boolean|undefined} touchPan Whether touch pan is
* desired. * desired. Default is `true`.
* @property {boolean|undefined} touchRotate Whether touch rotate is desired. * @property {boolean|undefined} touchRotate Whether touch rotate is desired. Default is `true`.
* @property {boolean|undefined} touchZoom Whether touch zoom is desired. * @property {boolean|undefined} touchZoom Whether touch zoom is desired. Default is `true`.
* @property {number|undefined} zoomDelta Zoom delta. * @property {number|undefined} zoomDelta Zoom delta.
* @property {number|undefined} zoomDuration Zoom duration. * @property {number|undefined} zoomDuration Zoom duration.
* @todo stability experimental * @todo stability experimental
@@ -493,14 +494,14 @@
/** /**
* @typedef {Object} olx.source.MapGuideOptions * @typedef {Object} olx.source.MapGuideOptions
* @property {string|undefined} url The mapagent url. * @property {string|undefined} url The mapagent url.
* @property {number|undefined} metersPerUnit The meters-per-unit value. * @property {number|undefined} metersPerUnit The meters-per-unit value. Default is `1`.
* @property {ol.Extent|undefined} extent Extent.. * @property {ol.Extent|undefined} extent Extent.
* @property {boolean|undefined} useOverlay If true, will use * @property {boolean|undefined} useOverlay If `true`, will use
* GETDYNAMICMAPOVERLAYIMAGE. * `GETDYNAMICMAPOVERLAYIMAGE`.
* @property {ol.proj.ProjectionLike} projection Projection. * @property {ol.proj.ProjectionLike} projection Projection.
* @property {number|undefined} ratio Ratio. 1 means image requests are the size * @property {number|undefined} ratio Ratio. `1` means image requests are the size
* of the map viewport, 2 means twice the size of the map viewport, and so * of the map viewport, `2` means twice the size of the map viewport, and so
* on. * on. Default is `1`.
* @property {Array.<number>|undefined} resolutions Resolutions. If specified, * @property {Array.<number>|undefined} resolutions Resolutions. If specified,
* requests will be made for these resolutions only. * requests will be made for these resolutions only.
* @property {Object|undefined} params Additional parameters. * @property {Object|undefined} params Additional parameters.
@@ -544,9 +545,9 @@
* `1.3.0` by default. `WIDTH`, `HEIGHT`, `BBOX` and `CRS` (`SRS` for WMS * `1.3.0` by default. `WIDTH`, `HEIGHT`, `BBOX` and `CRS` (`SRS` for WMS
* version < 1.3.0) will be set dynamically. * version < 1.3.0) will be set dynamically.
* @property {ol.proj.ProjectionLike} projection Projection. * @property {ol.proj.ProjectionLike} projection Projection.
* @property {number|undefined} ratio Ratio. 1 means image requests are the size * @property {number|undefined} ratio Ratio. `1` means image requests are the size
* of the map viewport, 2 means twice the size of the map viewport, and so * of the map viewport, `2` means twice the size of the map viewport, and so
* on. * on. Default is `1.5`.
* @property {Array.<number>|undefined} resolutions Resolutions. If specified, * @property {Array.<number>|undefined} resolutions Resolutions. If specified,
* requests will be made for these resolutions only. * requests will be made for these resolutions only.
* @property {string|undefined} url WMS service URL. * @property {string|undefined} url WMS service URL.

View File

@@ -103,15 +103,6 @@ ol.ObjectAccessor.prototype.transform = function(from, to) {
}; };
/**
* @enum {string}
*/
ol.ObjectProperty = {
ACCESSORS: 'ol_accessors_',
BINDINGS: 'ol_bindings_'
};
/** /**
* Base class implementing KVO (Key Value Observing). * Base class implementing KVO (Key Value Observing).
@@ -129,6 +120,12 @@ ol.Object = function(opt_values) {
*/ */
this.values_ = {}; this.values_ = {};
/**
* @private
* @type {Object.<string, ol.ObjectAccessor>}
*/
this.accessors_ = {};
/** /**
* Lookup of beforechange listener keys. * Lookup of beforechange listener keys.
* @type {Object.<string, goog.events.Key>} * @type {Object.<string, goog.events.Key>}
@@ -136,6 +133,12 @@ ol.Object = function(opt_values) {
*/ */
this.beforeChangeListeners_ = {}; this.beforeChangeListeners_ = {};
/**
* @private
* @type {Object.<string, goog.events.Key>}
*/
this.listeners_ = {};
if (goog.isDef(opt_values)) { if (goog.isDef(opt_values)) {
this.setValues(opt_values); this.setValues(opt_values);
} }
@@ -173,16 +176,6 @@ ol.Object.capitalize = function(str) {
}; };
/**
* @param {ol.Object} obj Object.
* @return {Object.<string, ol.ObjectAccessor>} Accessors.
*/
ol.Object.getAccessors = function(obj) {
return obj[ol.ObjectProperty.ACCESSORS] ||
(obj[ol.ObjectProperty.ACCESSORS] = {});
};
/** /**
* @param {string} key Key name. * @param {string} key Key name.
* @return {string} Change name. * @return {string} Change name.
@@ -205,16 +198,6 @@ ol.Object.getGetterName = function(key) {
}; };
/**
* @param {ol.Object} obj Object.
* @return {Object.<string, goog.events.Key>} Listeners.
*/
ol.Object.getListeners = function(obj) {
return obj[ol.ObjectProperty.BINDINGS] ||
(obj[ol.ObjectProperty.BINDINGS] = {});
};
/** /**
* @param {string} key String. * @param {string} key String.
* @return {string} Setter name. * @return {string} Setter name.
@@ -261,8 +244,7 @@ ol.Object.prototype.bindTo = function(key, target, opt_targetKey) {
// listen for change:targetkey events // listen for change:targetkey events
var eventType = ol.Object.getChangeEventType(targetKey); var eventType = ol.Object.getChangeEventType(targetKey);
var listeners = ol.Object.getListeners(this); this.listeners_[key] = goog.events.listen(target, eventType, function() {
listeners[key] = goog.events.listen(target, eventType, function() {
this.notifyInternal_(key); this.notifyInternal_(key);
}, undefined, this); }, undefined, this);
@@ -273,8 +255,7 @@ ol.Object.prototype.bindTo = function(key, target, opt_targetKey) {
undefined, this); undefined, this);
var accessor = new ol.ObjectAccessor(target, targetKey); var accessor = new ol.ObjectAccessor(target, targetKey);
var accessors = ol.Object.getAccessors(this); this.accessors_[key] = accessor;
accessors[key] = accessor;
this.notifyInternal_(key); this.notifyInternal_(key);
return accessor; return accessor;
}; };
@@ -312,14 +293,16 @@ ol.Object.prototype.createBeforeChangeListener_ = function(key, targetKey) {
*/ */
ol.Object.prototype.get = function(key) { ol.Object.prototype.get = function(key) {
var value; var value;
var accessors = ol.Object.getAccessors(this); var accessors = this.accessors_;
if (accessors.hasOwnProperty(key)) { if (accessors.hasOwnProperty(key)) {
var accessor = accessors[key]; var accessor = accessors[key];
var target = accessor.target; var target = accessor.target;
var targetKey = accessor.key; var targetKey = accessor.key;
var getterName = ol.Object.getGetterName(targetKey); var getterName = ol.Object.getGetterName(targetKey);
if (target[getterName]) { var getter = /** @type {function(): *|undefined} */
value = target[getterName](); (goog.object.get(target, getterName));
if (goog.isDef(getter)) {
value = getter.call(target);
} else { } else {
value = target.get(targetKey); value = target.get(targetKey);
} }
@@ -336,7 +319,7 @@ ol.Object.prototype.get = function(key) {
* @return {Array.<string>} List of property names. * @return {Array.<string>} List of property names.
*/ */
ol.Object.prototype.getKeys = function() { ol.Object.prototype.getKeys = function() {
var accessors = ol.Object.getAccessors(this); var accessors = this.accessors_;
var keysObject; var keysObject;
if (goog.object.isEmpty(this.values_)) { if (goog.object.isEmpty(this.values_)) {
if (goog.object.isEmpty(accessors)) { if (goog.object.isEmpty(accessors)) {
@@ -372,7 +355,7 @@ ol.Object.prototype.getProperties = function() {
for (key in this.values_) { for (key in this.values_) {
properties[key] = this.values_[key]; properties[key] = this.values_[key];
} }
for (key in ol.Object.getAccessors(this)) { for (key in this.accessors_) {
properties[key] = this.get(key); properties[key] = this.get(key);
} }
return properties; return properties;
@@ -387,7 +370,7 @@ ol.Object.prototype.getProperties = function() {
* @todo stability experimental * @todo stability experimental
*/ */
ol.Object.prototype.notify = function(key) { ol.Object.prototype.notify = function(key) {
var accessors = ol.Object.getAccessors(this); var accessors = this.accessors_;
if (accessors.hasOwnProperty(key)) { if (accessors.hasOwnProperty(key)) {
var accessor = accessors[key]; var accessor = accessors[key];
var target = accessor.target; var target = accessor.target;
@@ -420,15 +403,17 @@ ol.Object.prototype.notifyInternal_ = function(key) {
ol.Object.prototype.set = function(key, value) { ol.Object.prototype.set = function(key, value) {
this.dispatchEvent( this.dispatchEvent(
new ol.ObjectEvent(ol.ObjectEventType.BEFOREPROPERTYCHANGE, key)); new ol.ObjectEvent(ol.ObjectEventType.BEFOREPROPERTYCHANGE, key));
var accessors = ol.Object.getAccessors(this); var accessors = this.accessors_;
if (accessors.hasOwnProperty(key)) { if (accessors.hasOwnProperty(key)) {
var accessor = accessors[key]; var accessor = accessors[key];
var target = accessor.target; var target = accessor.target;
var targetKey = accessor.key; var targetKey = accessor.key;
var setterName = ol.Object.getSetterName(targetKey);
value = accessor.from(value); value = accessor.from(value);
if (target[setterName]) { var setterName = ol.Object.getSetterName(targetKey);
target[setterName](value); var setter = /** @type {function(*)|undefined} */
(goog.object.get(target, setterName));
if (goog.isDef(setter)) {
setter.call(target, value);
} else { } else {
target.set(targetKey, value); target.set(targetKey, value);
} }
@@ -445,12 +430,14 @@ ol.Object.prototype.set = function(key, value) {
* @todo stability experimental * @todo stability experimental
*/ */
ol.Object.prototype.setValues = function(values) { ol.Object.prototype.setValues = function(values) {
var key, value, setterName; var key;
for (key in values) { for (key in values) {
value = values[key]; var value = values[key];
setterName = ol.Object.getSetterName(key); var setterName = ol.Object.getSetterName(key);
if (this[setterName]) { var setter = /** @type {function(*)|undefined} */
this[setterName](value); (goog.object.get(this, setterName));
if (goog.isDef(setter)) {
setter.call(this, value);
} else { } else {
this.set(key, value); this.set(key, value);
} }
@@ -465,14 +452,13 @@ ol.Object.prototype.setValues = function(values) {
* @todo stability experimental * @todo stability experimental
*/ */
ol.Object.prototype.unbind = function(key) { ol.Object.prototype.unbind = function(key) {
var listeners = ol.Object.getListeners(this); var listeners = this.listeners_;
var listener = listeners[key]; var listener = listeners[key];
if (listener) { if (listener) {
delete listeners[key]; delete listeners[key];
goog.events.unlistenByKey(listener); goog.events.unlistenByKey(listener);
var value = this.get(key); var value = this.get(key);
var accessors = ol.Object.getAccessors(this); delete this.accessors_[key];
delete accessors[key];
this.values_[key] = value; this.values_[key] = value;
} }
@@ -490,7 +476,7 @@ ol.Object.prototype.unbind = function(key) {
* @todo stability experimental * @todo stability experimental
*/ */
ol.Object.prototype.unbindAll = function() { ol.Object.prototype.unbindAll = function() {
for (var key in ol.Object.getListeners(this)) { for (var key in this.listeners_) {
this.unbind(key); this.unbind(key);
} }
}; };

View File

@@ -10,6 +10,8 @@ goog.require('goog.events.EventTarget');
* and unregistration. * and unregistration.
* @constructor * @constructor
* @extends {goog.events.EventTarget} * @extends {goog.events.EventTarget}
* @suppress {checkStructDictInheritance}
* @struct
* @todo stability experimental * @todo stability experimental
*/ */
ol.Observable = function() { ol.Observable = function() {