acgis api for js 3.x,加载天地图超过18层级不展示问题处理

1、修改图层的金字塔层级数据,使能访问到18层级以下。

2、调整getTileUrl方法,当层级大于18时,直接return,不调用服务接口;

3、修改init.js文件,在方法_onExtentChangeHandler中会调用_cleanUpRemovedImages方法删除瓦片数据,修改该方法,当层级大于18时不执行_cleanUpRemovedImages方法即能达到放大瓦片效果。

在基于ArcGIS API for JavaScript 4.x 的环境中加载B3MD格式的3D模型,你需要使用`SceneView`和`Scene`组件,并利用Esri提供的一些工具库。以下是基本步骤: 1. **环境设置**: - 确保已经包含ESRI JavaScript API,包括`esri-loader`用于异步加载资源。 ```javascript require(["esri/Map", "esri/views/SceneView", "esri/layers/B3DMLayer"], function(Map, SceneView, B3DMLayer) { // ... }); ``` 2. **创建场景视图**: 创建一个新的`SceneView`实例,指定容器元素和其他初始配置选项。 ```javascript const sceneView = new SceneView({ container: "myContainerId", map: new Map({ basemap: "dark-gray" }), camera: { position: [0, 0, 50], heading: 0, tilt: 0 }, }); ``` 3. **加载B3MD文件**: 使用`B3DMLayer`并调用`load()`方法来加载模型。B3MD文件通常是一个JSON描述,所以需要先解析它。 ```javascript let b3dmUrl = "path/to/your/b3dm/model.b3dm"; const urlPromise = new Promise((resolve, reject) => { esriLoader.load(b3dmUrl) .then(response => resolve(response)) .catch(reject); }); urlPromise.then(response => { const b3dmLayer = new B3DMLayer({ id: "modelLayer", data: response, }); sceneView.layer.add(b3dmLayer); }); ``` 4. **添加到视图**: 当模型数据加载完成后,将其添加到`SceneView`的`layer`属性。 注意: - `B3DMLayer`支持的文件格式通常是`.b3dm`,而不是`.json`,所以在URL上不需要加扩展名。 - 需要考虑网络延迟和错误处理,因为大文件可能会导致加载时间较长。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值