123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201 |
- /*global define*/
- define([
- '../Core/defaultValue',
- '../Core/defined',
- '../Core/defineProperties',
- '../Core/destroyObject',
- '../Core/DeveloperError',
- '../Core/Event'
- ], function(
- defaultValue,
- defined,
- defineProperties,
- destroyObject,
- DeveloperError,
- Event) {
- "use strict";
- /**
- * A collection of {@link DataSource} instances.
- * @alias DataSourceCollection
- * @constructor
- */
- var DataSourceCollection = function() {
- this._dataSources = [];
- this._dataSourceAdded = new Event();
- this._dataSourceRemoved = new Event();
- };
- defineProperties(DataSourceCollection.prototype, {
- /**
- * Gets the number of data sources in this collection.
- * @memberof DataSourceCollection.prototype
- * @type {Number}
- * @readonly
- */
- length : {
- get : function() {
- return this._dataSources.length;
- }
- },
- /**
- * An event that is raised when a data source is added to the collection.
- * Event handlers are passed the data source that was added.
- * @memberof DataSourceCollection.prototype
- * @type {Event}
- * @readonly
- */
- dataSourceAdded : {
- get : function() {
- return this._dataSourceAdded;
- }
- },
- /**
- * An event that is raised when a data source is removed from the collection.
- * Event handlers are passed the data source that was removed.
- * @memberof DataSourceCollection.prototype
- * @type {Event}
- * @readonly
- */
- dataSourceRemoved : {
- get : function() {
- return this._dataSourceRemoved;
- }
- }
- });
- /**
- * Adds a data source to the collection.
- *
- * @param {DataSource} dataSource The data source to add.
- */
- DataSourceCollection.prototype.add = function(dataSource) {
- //>>includeStart('debug', pragmas.debug);
- if (!defined(dataSource)) {
- throw new DeveloperError('dataSource is required.');
- }
- //>>includeEnd('debug');
- this._dataSources.push(dataSource);
- this._dataSourceAdded.raiseEvent(this, dataSource);
- };
- /**
- * Removes a data source from this collection, if present.
- *
- * @param {DataSource} dataSource The data source to remove.
- * @param {Boolean} [destroy=false] Whether to destroy the data source in addition to removing it.
- * @returns {Boolean} true if the data source was in the collection and was removed,
- * false if the data source was not in the collection.
- */
- DataSourceCollection.prototype.remove = function(dataSource, destroy) {
- destroy = defaultValue(destroy, false);
- var index = this._dataSources.indexOf(dataSource);
- if (index !== -1) {
- this._dataSources.splice(index, 1);
- this._dataSourceRemoved.raiseEvent(this, dataSource);
- if (destroy && typeof dataSource.destroy === 'function') {
- dataSource.destroy();
- }
- return true;
- }
- return false;
- };
- /**
- * Removes all data sources from this collection.
- *
- * @param {Boolean} [destroy=false] whether to destroy the data sources in addition to removing them.
- */
- DataSourceCollection.prototype.removeAll = function(destroy) {
- destroy = defaultValue(destroy, false);
- var dataSources = this._dataSources;
- for (var i = 0, len = dataSources.length; i < len; ++i) {
- var dataSource = dataSources[i];
- this._dataSourceRemoved.raiseEvent(this, dataSource);
- if (destroy && typeof dataSource.destroy === 'function') {
- dataSource.destroy();
- }
- }
- dataSources.length = 0;
- };
- /**
- * Checks to see if the collection contains a given data source.
- *
- * @param {DataSource} dataSource The data source to check for.
- * @returns {Boolean} true if the collection contains the data source, false otherwise.
- */
- DataSourceCollection.prototype.contains = function(dataSource) {
- return this.indexOf(dataSource) !== -1;
- };
- /**
- * Determines the index of a given data source in the collection.
- *
- * @param {DataSource} dataSource The data source to find the index of.
- * @returns {Number} The index of the data source in the collection, or -1 if the data source does not exist in the collection.
- */
- DataSourceCollection.prototype.indexOf = function(dataSource) {
- return this._dataSources.indexOf(dataSource);
- };
- /**
- * Gets a data source by index from the collection.
- *
- * @param {Number} index the index to retrieve.
- */
- DataSourceCollection.prototype.get = function(index) {
- //>>includeStart('debug', pragmas.debug);
- if (!defined(index)) {
- throw new DeveloperError('index is required.');
- }
- //>>includeEnd('debug');
- return this._dataSources[index];
- };
- /**
- * Returns true if this object was destroyed; otherwise, false.
- * If this object was destroyed, it should not be used; calling any function other than
- * <code>isDestroyed</code> will result in a {@link DeveloperError} exception.
- *
- * @returns {Boolean} true if this object was destroyed; otherwise, false.
- *
- * @see DataSourceCollection#destroy
- */
- DataSourceCollection.prototype.isDestroyed = function() {
- return false;
- };
- /**
- * Destroys the resources held by all data sources in this collection. Explicitly destroying this
- * object allows for deterministic release of WebGL resources, instead of relying on the garbage
- * collector. Once this object is destroyed, it should not be used; calling any function other than
- * <code>isDestroyed</code> will result in a {@link DeveloperError} exception. Therefore,
- * assign the return value (<code>undefined</code>) to the object as done in the example.
- *
- * @returns {undefined}
- *
- * @exception {DeveloperError} This object was destroyed, i.e., destroy() was called.
- *
- * @see DataSourceCollection#isDestroyed
- *
- * @example
- * dataSourceCollection = dataSourceCollection && dataSourceCollection.destroy();
- */
- DataSourceCollection.prototype.destroy = function() {
- this.removeAll(true);
- return destroyObject(this);
- };
- return DataSourceCollection;
- });
|