1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- /*global define*/
- define([
- '../Core/defined',
- '../Core/DeveloperError',
- '../Core/loadImage',
- '../ThirdParty/when'
- ], function(
- defined,
- DeveloperError,
- loadImage,
- when) {
- "use strict";
- /**
- * Asynchronously loads six images and creates a cube map. Returns a promise that
- * will resolve to a {@link CubeMap} once loaded, or reject if any image fails to load.
- *
- * @exports loadCubeMap
- *
- * @param {Context} context The context to use to create the cube map.
- * @param {Object} urls The source of each image, or a promise for each URL. See the example below.
- * @param {Boolean} [allowCrossOrigin=true] Whether to request the image using Cross-Origin
- * Resource Sharing (CORS). CORS is only actually used if the image URL is actually cross-origin.
- * Data URIs are never requested using CORS.
- * @returns {Promise} a promise that will resolve to the requested {@link CubeMap} when loaded.
- *
- * @exception {DeveloperError} context is required.
- * @exception {DeveloperError} urls is required and must have positiveX, negativeX, positiveY, negativeY, positiveZ, and negativeZ properties.
- *
- * @see {@link http://www.w3.org/TR/cors/|Cross-Origin Resource Sharing}
- * @see {@link http://wiki.commonjs.org/wiki/Promises/A|CommonJS Promises/A}
- *
- * @example
- * Cesium.loadCubeMap(context, {
- * positiveX : 'skybox_px.png',
- * negativeX : 'skybox_nx.png',
- * positiveY : 'skybox_py.png',
- * negativeY : 'skybox_ny.png',
- * positiveZ : 'skybox_pz.png',
- * negativeZ : 'skybox_nz.png'
- * }).then(function(cubeMap) {
- * // use the cubemap
- * }).otherwise(function(error) {
- * // an error occurred
- * });
- *
- * @private
- */
- var loadCubeMap = function(context, urls, allowCrossOrigin) {
- //>>includeStart('debug', pragmas.debug);
- if (!defined(context)) {
- throw new DeveloperError('context is required.');
- }
- if ((!defined(urls)) ||
- (!defined(urls.positiveX)) ||
- (!defined(urls.negativeX)) ||
- (!defined(urls.positiveY)) ||
- (!defined(urls.negativeY)) ||
- (!defined(urls.positiveZ)) ||
- (!defined(urls.negativeZ))) {
- throw new DeveloperError('urls is required and must have positiveX, negativeX, positiveY, negativeY, positiveZ, and negativeZ properties.');
- }
- //>>includeEnd('debug');
- // PERFORMANCE_IDEA: Given the size of some cube maps, we should consider tiling them, which
- // would prevent hiccups when uploading, for example, six 4096x4096 textures to the GPU.
- //
- // Also, it is perhaps acceptable to use the context here in the callbacks, but
- // ideally, we would do it in the primitive's update function.
- var facePromises = [
- loadImage(urls.positiveX, allowCrossOrigin),
- loadImage(urls.negativeX, allowCrossOrigin),
- loadImage(urls.positiveY, allowCrossOrigin),
- loadImage(urls.negativeY, allowCrossOrigin),
- loadImage(urls.positiveZ, allowCrossOrigin),
- loadImage(urls.negativeZ, allowCrossOrigin)
- ];
- return when.all(facePromises, function(images) {
- return context.createCubeMap({
- source : {
- positiveX : images[0],
- negativeX : images[1],
- positiveY : images[2],
- negativeY : images[3],
- positiveZ : images[4],
- negativeZ : images[5]
- }
- });
- });
- };
- return loadCubeMap;
- });
|