/*
* Copyright 2003-2006, 2009, 2017, 2020 United States Government, as represented
* by the Administrator of the National Aeronautics and Space Administration.
* All rights reserved.
*
* The NASAWorldWind/WebWorldWind platform is licensed under the Apache License,
* Version 2.0 (the "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License
* at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed
* under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
* CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*
* NASAWorldWind/WebWorldWind also contains the following 3rd party Open Source
* software:
*
* ES6-Promise – under MIT License
* libtess.js – SGI Free Software License B
* Proj4 – under MIT License
* JSZip – under MIT License
*
* A complete listing of 3rd Party software notices and licenses included in
* WebWorldWind can be found in the WebWorldWind 3rd-party notices and licenses
* PDF found in code directory.
*/
/**
* @exports RestTiledImageLayer
*/
define([
'../error/ArgumentError',
'../geom/Location',
'../util/Logger',
'../geom/Sector',
'../layer/TiledImageLayer',
'../util/LevelRowColumnUrlBuilder',
'../util/WWUtil'
],
function (ArgumentError,
Location,
Logger,
Sector,
TiledImageLayer,
LevelRowColumnUrlBuilder,
WWUtil) {
"use strict";
/**
* Constructs a tiled image layer that uses a REST interface to retrieve its imagery.
* @alias RestTiledImageLayer
* @constructor
* @augments TiledImageLayer
* @classdesc Displays a layer whose imagery is retrieved using a REST interface.
* See [LevelRowColumnUrlBuilder]{@link LevelRowColumnUrlBuilder} for a description of the REST interface.
* @param {String} serverAddress The server address of the tile service. May be null, in which case the
* current origin is used (see window.location).
* @param {String} pathToData The path to the data directory relative to the specified server address.
* May be null, in which case the server address is assumed to be the full path to the data directory.
* @param {String} displayName The display name to associate with this layer.
* @param {{}} configuration The tiled image layer configuration. May have the following properties:
* <ul>
* <li>sector {Sector}, default is full sphere</li>
* <li>levelZerotTileDelta {Location}, default is 45, 45</li>
* <li>numLevels {Number}, default is 5</li>
* <li>imageFormat {String}, default is image/jpeg</li>
* <li>tileWidth {Number}, default is 256</li>
* <li>tileHeight {Number}, default is 256</li>
* </ul>
* The specified default is used for any property not specified.
*/
var RestTiledImageLayer = function (serverAddress, pathToData, displayName, configuration) {
var cachePath = WWUtil.urlPath(serverAddress + "/" + pathToData);
TiledImageLayer.call(this,
(configuration && configuration.sector) || Sector.FULL_SPHERE,
(configuration && configuration.levelZeroTileDelta) || new Location(45, 45),
(configuration && configuration.numLevels) || 5,
(configuration && configuration.imageFormat) || "image/jpeg",
cachePath,
(configuration && configuration.tileWidth) || 256,
(configuration && configuration.tileHeight) || 256);
this.displayName = displayName;
this.pickEnabled = false;
this.urlBuilder = new LevelRowColumnUrlBuilder(serverAddress, pathToData);
};
RestTiledImageLayer.prototype = Object.create(TiledImageLayer.prototype);
return RestTiledImageLayer;
});