cesium如何自定义此级别下无图片

时间: 2023-10-06 09:05:21 浏览: 38
要自定义Cesium中某个级别下无图片,可以通过以下步骤实现: 1. 在Cesium中加载对应的切片地图服务图层。 2. 找到需要自定义的级别,记录其级别号。 3. 通过Cesium的TileProvider接口和CustomMapTileProvider类,创建自定义瓦片提供者。 4. 在CustomMapTileProvider类中重写requestTileGeometry方法,判断当前请求的瓦片是否为需要自定义的级别,如果是则返回空的Geometry对象,即可实现无图片的效果。 以下是示例代码: ```javascript var viewer = new Cesium.Viewer('cesiumContainer'); // 加载切片地图服务图层 var imageryProvider = new Cesium.UrlTemplateImageryProvider({ url: 'http://server.com/{z}/{x}/{y}.png', credit: 'Map Data © OpenStreetMap contributors' }); viewer.imageryLayers.addImageryProvider(imageryProvider); // 自定义瓦片提供者 var customProvider = new CustomMapTileProvider({ url: 'http://server.com/{z}/{x}/{y}.png', credit: 'Map Data © OpenStreetMap contributors' }); viewer.scene.globe.tileProvider = customProvider; // 自定义瓦片提供者类 function CustomMapTileProvider(options) { this._url = options.url; this._credit = options.credit; } CustomMapTileProvider.prototype.requestTileGeometry = function(x, y, level, throttleRequests) { if (level === 10) { // 当前级别为10,返回空的Geometry对象 return new Cesium.Geometry({ attributes: new Cesium.GeometryAttributes(), primitiveType: Cesium.PrimitiveType.TRIANGLES }); } // 请求瓦片数据 var url = this._url.replace('{z}', level).replace('{x}', x).replace('{y}', y); return Cesium.Resource.fetchArrayBuffer(url, throttleRequests) .then(function(data) { // 解析瓦片数据 var image = new window.Image(); image.src = URL.createObjectURL(new Blob([data], { type: 'image/png' })); return Cesium.GeoTIFF.readFromImage(image); }); }; CustomMapTileProvider.prototype.getTileCredits = function(x, y, level) { return this._credit; }; ``` 在以上代码中,我们通过CustomMapTileProvider类创建了自定义瓦片提供者,并重写了requestTileGeometry方法,在级别为10时返回空的Geometry对象,从而实现了无图片的效果。

相关推荐

最新推荐

recommend-type

cesium环境配置说明.docx

基于cesium开发基础环境配置与搭建,描述过程简洁易懂,希望能帮助有需要的人,欢迎下载。
recommend-type

Cesium 动态Polyline绘制

Cesium 用Entity绘制polyline,如果使用CallbackProperty方法进行动态绘制,depthFailMaterial属性将失效。 从官方github上的issue找了替代的方法。 动态Primitive线的绘制 // 绘制方法 this._...
recommend-type

Cesium高程提取代码(分多种情况)

不采用鼠标点击的被动式获取方式,通过插值等等方式获取离散点,借助cesium的api获取直线、范围面的高程,只需要经纬度坐标即可,分不同情况调用不同接口,放上代码与截图说明
recommend-type

typora.zip

typora.zip
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

解释这行代码 c = ((double)rand() / RAND_MAX) * (a + b - fabs(a - b)) + fabs(a - b);

这行代码是用于生成 a 和 b 之间的随机数。首先,它使用 rand() 函数生成一个 [0,1) 之间的随机小数,然后将这个小数乘以 a、b 范围内的差值,再加上 a 和 b 中的较小值。这可以确保生成的随机数大于等于 a,小于等于 b,而且不会因为 a 和 b 之间的差距过大而导致难以生成足够多的随机数。最后,使用 fabs() 函数来确保计算结果是正数。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依