UrlTemplateImageryProvider

new Cesium.UrlTemplateImageryProvider (options)

通过使用指定的 URL 模板请求图块来提供图像。
Name Type Description
options UrlTemplateImageryProvider.ConstructorOptions 描述初始化选项的对象
Example:
// Access Natural Earth II imagery, which uses a TMS tiling scheme and Geographic (EPSG:4326) project
const tms = new Cesium.UrlTemplateImageryProvider({
    url : Cesium.buildModuleUrl('Assets/Textures/NaturalEarthII') + '/{z}/{x}/{reverseY}.jpg',
    credit : '© Analytical Graphics, Inc.',
    tilingScheme : new Cesium.GeographicTilingScheme(),
    maximumLevel : 5
});
// Access the CartoDB Positron basemap, which uses an OpenStreetMap-like tiling scheme.
const positron = new Cesium.UrlTemplateImageryProvider({
    url : 'http://{s}.basemaps.cartocdn.com/light_all/{z}/{x}/{y}.png',
    credit : 'Map tiles by CartoDB, under CC BY 3.0. Data by OpenStreetMap, under ODbL.'
});
// Access a Web Map Service (WMS) server.
const wms = new Cesium.UrlTemplateImageryProvider({
   url : 'https://programs.communications.gov.au/geoserver/ows?tiled=true&' +
         'transparent=true&format=image%2Fpng&exceptions=application%2Fvnd.ogc.se_xml&' +
         'styles=&service=WMS&version=1.1.1&request=GetMap&' +
         'layers=public%3AMyBroadband_Availability&srs=EPSG%3A3857&' +
         'bbox={westProjected}%2C{southProjected}%2C{eastProjected}%2C{northProjected}&' +
         'width=256&height=256',
   rectangle : Cesium.Rectangle.fromDegrees(96.799393, -43.598214999057824, 153.63925700000001, -9.2159219997013)
});
// Using custom tags in your template url.
const custom = new Cesium.UrlTemplateImageryProvider({
   url : 'https://yoururl/{Time}/{z}/{y}/{x}.png',
   customTags : {
       Time: function(imageryProvider, x, y, level) {
           return '20171231'
       }
   }
});
See:

Members

当此图像提供程序处于活动状态时,获得要显示的功劳。通常,这用于说明图像的来源。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: undefined

defaultAlpha : Number|undefined

此提供程序的默认 alpha 混合值,0.0 表示完全透明,1.0 表示完全不透明。
Default Value: undefined

defaultBrightness : Number|undefined

此提供程序的默认亮度。 1.0 使用未修改的图像颜色。小于 1.0 会使图像更暗,而大于 1.0 会使图像更亮。
Default Value: undefined

defaultContrast : Number|undefined

此提供程序的默认对比度。 1.0 使用未修改的图像颜色。小于 1.0 会降低对比度,而大于 1.0 会增加对比度。
Default Value: undefined

defaultDayAlpha : Number|undefined

此提供程序的地球日侧的默认 alpha 混合值,0.0 表示完全透明,1.0 表示完全不透明。
Default Value: undefined

defaultGamma : Number|undefined

应用于此提供程序的默认伽马校正。 1.0 使用未修改的图像颜色。
Default Value: undefined

defaultHue : Number|undefined

此提供程序的默认色调(以弧度为单位)。 0.0 使用未修改的图像颜色。
Default Value: undefined
应用于此提供程序的默认纹理放大过滤器。
Default Value: undefined
应用于此提供程序的默认纹理缩小过滤器。
Default Value: undefined

defaultNightAlpha : Number|undefined

此提供程序的地球夜晚的默认 alpha 混合值,0.0 表示完全透明,1.0 表示完全不透明。
Default Value: undefined

defaultSaturation : Number|undefined

此提供程序的默认饱和度。 1.0 使用未修改的图像颜色。小于 1.0 会降低饱和度,而大于 1.0 会增加饱和度。
Default Value: undefined

enablePickFeatures : Boolean

获取或设置一个值,该值指示是否启用特征选择。如果为 true, UrlTemplateImageryProvider#pickFeatures 将请求 options.pickFeaturesUrl 并尝试解释响应中包含的功能。如果为 false, UrlTemplateImageryProvider#pickFeatures 将立即返回 undefined(表示没有可选功能)而不与服务器通信。如果您知道您的数据源不支持选择功能,或者您不希望此提供程序的功能可供选择,请将此属性设置为 false。
Default Value: true
获取图像提供程序遇到异步错误时引发的事件。通过订阅该事件,您将收到错误通知,并有可能从中恢复。事件侦听器被传递一个 TileProviderError 实例。

readonly hasAlphaChannel : Boolean

获取一个值,该值指示此图像提供程序提供的图像是否包含 Alpha 通道。如果此属性为 false,则 Alpha 通道(如果存在)将被忽略。如果此属性为真,则任何没有 alpha 通道的图像都将被视为其 alpha 在任何地方都是 1.0。当此属性为 false 时,内存使用量和纹理上传时间会减少。在 ImageryProvider#ready 返回 true 之前不应调用此函数。
Default Value: true

readonly maximumLevel : Number|undefined

获取可以请求的最大细节级别,如果没有限制,则为 undefined。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: undefined

readonly minimumLevel : Number

获取可以请求的最低详细级别。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: 0

readonly pickFeaturesUrl : String

获取用于选择特征的 URL 模板。如果未指定此属性,则 UrlTemplateImageryProvider#pickFeatures 将立即返回 undefined,表示未选择任何特征。 URL 模板支持 UrlTemplateImageryProvider#url 属性支持的所有关键字,以及以下内容:
  • {i} :选取位置的像素列(水平坐标),其中最西端的像素为 0。
  • {j} :选取位置的像素行(垂直坐标),其中最北端的像素为 0。
  • {reverseI} :选取位置的像素列(水平坐标),其中最东端的像素为 0。
  • {reverseJ} :选取位置的像素行(垂直坐标),其中最南端的像素为 0。
  • {longitudeDegrees} :所选位置的经度,以度为单位。
  • {latitudeDegrees} :所选位置的纬度,以度为单位。
  • {longitudeProjected} :切片方案投影坐标中选取位置的经度。
  • {latitudeProjected} :切片方案投影坐标中选取位置的纬度。
  • {format} :获取要素信息的格式,在 GetFeatureInfoFormat 中指定。
获取此提供程序使用的代理。
Default Value: undefined
获取一个值,该值指示提供程序是否已准备好使用。

readonly readyPromise : Promise.<Boolean>

当提供者准备好使用时,获取一个解析为 true 的承诺。
获取此实例提供的图像的矩形(以弧度为单位)。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: tilingScheme.rectangle
获取瓦片丢弃策略。如果未定义,丢弃策略负责通过其 shouldDiscardImage 函数过滤掉'丢失的'图块。如果此函数返回未定义,则不过滤任何图块。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: undefined

readonly tileHeight : Number

获取每个图块的高度,以像素为单位。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: 256
获取每个图块的宽度,以像素为单位。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: 256
获取此提供程序使用的切片方案。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Default Value: new WebMercatorTilingScheme()
获取用于请求切片的 URL 模板。它有以下关键字:
  • {z} :平铺方案中的平铺级别。零级是四叉树金字塔的根。
  • {x} :平铺方案中的平铺 X 坐标,其中 0 是最西边的平铺。
  • {y} :切片方案中的切片 Y 坐标,其中 0 是最北端的切片。
  • {s} :可用的子域之一,用于克服浏览器对每个主机同时请求数的限制。
  • {reverseX} :平铺方案中的平铺 X 坐标,其中 0 是最东边的平铺。
  • {reverseY} :切片方案中的切片 Y 坐标,其中 0 是最南端的切片。
  • {reverseZ} :平铺方案中平铺的级别,其中级别零是四叉树金字塔的最大级别。为了使用 reverseZ,必须定义 maximumLevel。
  • {westDegrees} :以大地角度表示的瓦片的西部边缘。
  • {southDegrees} :以大地角度表示的瓷砖的南边。
  • {eastDegrees} :以大地度计的瓦片的东边。
  • {northDegrees} :以大地度为单位的瓦片的北边缘。
  • {westProjected} :在切片方案的投影坐标中切片的西部边缘。
  • {southProjected} :切片方案投影坐标中切片的南边。
  • {eastProjected} :切片方案投影坐标中切片的东边。
  • {northProjected} :在切片方案的投影坐标中切片的北边。
  • {width} :每个图块的宽度(以像素为单位)。
  • {height} :每个图块的高度(以像素为单位)。

readonly urlSchemeZeroPadding : Object

获取每个平铺坐标的 URL 方案零填充。格式为'000',其中每个坐标将在左侧填充零以匹配传递的零字符串的宽度。例如设置: urlSchemeZeroPadding : { '{x}' : '0000'} 将导致 'x' 值为 12 以在生成的 URL 中为 {x} 返回字符串 '0012'。它有以下关键字:
  • {z} :平铺方案中平铺级别的零填充。
  • {x} :平铺方案中平铺 X 坐标的零填充。
  • {y} :平铺方案中平铺 Y 坐标的零填充。
  • {reverseX} :平铺方案中平铺 reverseX 坐标的零填充。
  • {reverseY} :平铺方案中平铺 reverseY 坐标的零填充。
  • {reverseZ} :平铺方案中平铺的 reverseZ 坐标的零填充。

Methods

getTileCredits (x, y, level) Array.< Credit >

获取显示给定磁贴时要显示的积分。
Name Type Description
x Number 平铺 X 坐标。
y Number 瓦片 Y 坐标。
level Number 瓷砖级别;
Returns:
显示磁贴时要显示的学分。
Throws:
  • DeveloperError : 在图像提供程序准备好之前,不得调用 getTileCredits

pickFeatures (x, y, level, longitude, latitude) Promise.<Array.< ImageryLayerFeatureInfo >>|undefined

异步确定哪些要素(如果有)位于图块内的给定经度和纬度处。在 ImageryProvider#ready 返回 true 之前不应调用此函数。
Name Type Description
x Number 平铺 X 坐标。
y Number 瓦片 Y 坐标。
level Number 瓷砖级别。
longitude Number 选择要素的经度。
latitude Number 选择要素的纬度。
Returns:
异步拾取完成时将解决的拾取特征的承诺。解析的值是 ImageryLayerFeatureInfo 实例的数组。如果在给定位置未找到任何特征,则该数组可能为空。如果不支持拾取,它也可能是未定义的。
重新初始化此实例。支持重新初始化已在使用的实例,但不建议这样做,因为图像提供者提供的现有切片将不会更新。
Name Type Description
options Promise.<Object> | Object 可以传递给 UrlTemplateImageryProvider 构造函数的任何选项。

requestImage (x, y, level, request ) Promise.< ImageryTypes >|undefined

请求给定图块的图像。在 UrlTemplateImageryProvider#ready 返回 true 之前,不应调用此函数。
Name Type Description
x Number 平铺 X 坐标。
y Number 瓦片 Y 坐标。
level Number 瓷砖级别。
request Request 可选 请求对象。仅供内部使用。
Returns:
对图像的承诺,当图像可用时将解析,或者如果对服务器的活动请求过多,则未定义,并且应稍后重试请求。

Type Definitions

Cesium.UrlTemplateImageryProvider.ConstructorOptions

UrlTemplateImageryProvider 构造函数的初始化选项
Properties:
Name Type Attributes Default Description
options Promise.<Object> | Object <optional>
具有以下属性的对象:
url Resource | String 用于请求磁贴的 URL 模板。它有以下关键字:
  • {z} :平铺方案中的平铺级别。零级是四叉树金字塔的根。
  • {x} :平铺方案中的平铺 X 坐标,其中 0 是最西边的平铺。
  • {y} :切片方案中的切片 Y 坐标,其中 0 是最北端的切片。
  • {s} :可用的子域之一,用于克服浏览器对每个主机同时请求数的限制。
  • {reverseX} :平铺方案中的平铺 X 坐标,其中 0 是最东边的平铺。
  • {reverseY} :切片方案中的切片 Y 坐标,其中 0 是最南端的切片。
  • {reverseZ} :平铺方案中平铺的级别,其中级别零是四叉树金字塔的最大级别。为了使用 reverseZ,必须定义 maximumLevel。
  • {westDegrees} :以大地角度表示的瓦片的西部边缘。
  • {southDegrees} :以大地角度表示的瓷砖的南边。
  • {eastDegrees} :以大地度计的瓦片的东边。
  • {northDegrees} :以大地度为单位的瓦片的北边缘。
  • {westProjected} :在切片方案的投影坐标中切片的西部边缘。
  • {southProjected} :切片方案投影坐标中切片的南边。
  • {eastProjected} :切片方案投影坐标中切片的东边。
  • {northProjected} :在切片方案的投影坐标中切片的北边。
  • {width} :每个图块的宽度(以像素为单位)。
  • {height} :每个图块的高度(以像素为单位)。
pickFeaturesUrl Resource | String <optional>
用于选择功能的 URL 模板。如果未指定此属性,则 UrlTemplateImageryProvider#pickFeatures 将立即返回 undefined,表示未选择任何特征。 URL 模板支持 url 参数支持的所有关键字,以及以下内容:
  • {i} :选取位置的像素列(水平坐标),其中最西端的像素为 0。
  • {j} :选取位置的像素行(垂直坐标),其中最北端的像素为 0。
  • {reverseI} :选取位置的像素列(水平坐标),其中最东端的像素为 0。
  • {reverseJ} :选取位置的像素行(垂直坐标),其中最南端的像素为 0。
  • {longitudeDegrees} :所选位置的经度,以度为单位。
  • {latitudeDegrees} :所选位置的纬度,以度为单位。
  • {longitudeProjected} :切片方案投影坐标中选取位置的经度。
  • {latitudeProjected} :切片方案投影坐标中选取位置的纬度。
  • {format} :获取要素信息的格式,在 GetFeatureInfoFormat 中指定。
urlSchemeZeroPadding Object <optional>
获取每个平铺坐标的 URL 方案零填充。格式为'000',其中每个坐标将在左侧填充零以匹配传递的零字符串的宽度。例如设置: urlSchemeZeroPadding : { '{x}' : '0000'} 将导致 'x' 值为 12 以在生成的 URL 中为 {x} 返回字符串 '0012'。它传递的对象具有以下关键字:
  • {z} :平铺方案中平铺级别的零填充。
  • {x} :平铺方案中平铺 X 坐标的零填充。
  • {y} :平铺方案中平铺 Y 坐标的零填充。
  • {reverseX} :平铺方案中平铺 reverseX 坐标的零填充。
  • {reverseY} :平铺方案中平铺 reverseY 坐标的零填充。
  • {reverseZ} :平铺方案中平铺的 reverseZ 坐标的零填充。
subdomains String | Array.<String> <optional>
'abc' 用于 URL 模板中 {s} 占位符的子域。如果此参数是单个字符串,则字符串中的每个字符都是一个子域。如果是数组,则数组中的每个元素都是一个子域。
credit Credit | String <optional>
'' 数据源的功劳,显示在画布上。
minimumLevel Number <optional>
0 图像提供者支持的最低详细程度。指定时请注意,最小级别的图块数量很少,例如四个或更少。较大的数字可能会导致渲染问题。
maximumLevel Number <optional>
图像提供者支持的最大细节级别,如果没有限制,则未定义。
rectangle Rectangle <optional>
Rectangle.MAX_VALUE 图像覆盖的矩形,以弧度表示。
tilingScheme TilingScheme <optional>
WebMercatorTilingScheme 平铺方案指定如何将椭圆体表面分解为平铺。如果未提供此参数,则使用 WebMercatorTilingScheme
ellipsoid Ellipsoid <optional>
椭球体。如果指定了 tilingScheme,则忽略此参数,并使用切片方案的椭球代替。如果两个参数均未指定,则使用 WGS84 椭球。
tileWidth Number <optional>
256 图像图块的像素宽度。
tileHeight Number <optional>
256 图像图块的像素高度。
hasAlphaChannel Boolean <optional>
true 如果此图像提供程序提供的图像包含 alpha 通道,则为 true;否则为假。如果此属性为 false,则 Alpha 通道(如果存在)将被忽略。如果此属性为真,则任何没有 alpha 通道的图像都将被视为其 alpha 在任何地方都是 1.0。当此属性为 false 时,内存使用和纹理上传时间可能会减少。
getFeatureInfoFormats Array.< GetFeatureInfoFormat > <optional>
调用 UrlTemplateImageryProvider#pickFeatures 时在特定位置获取特征信息的格式。如果未指定此参数,则禁用特征拾取。
enablePickFeatures Boolean <optional>
true 如果为 true, UrlTemplateImageryProvider#pickFeatures 将请求 pickFeaturesUrl 并尝试解释响应中包含的功能。如果为 false, UrlTemplateImageryProvider#pickFeatures 将立即返回 undefined(表示没有可选功能)而不与服务器通信。如果您知道您的数据源不支持选择功能,或者您不希望此提供程序的功能可供选择,请将此属性设置为 false。请注意,这可以通过修改 UriTemplateImageryProvider#enablePickFeatures 属性来动态覆盖。
customTags Object <optional>
允许替换 URL 模板中的自定义关键字。对象必须有字符串作为键和函数作为值。