openLayer加载ArcGIS切片

OpenLayer中加载ArcGIS服务提供了最常用的TileArcGISRest方法,实际上我们从浏览器的network捕捉的每次的请求链接亦或者看其源码,都会发现,它实际上调取了arcserver的REST API中的export接口,对于普通的服务来说确实足够了,但是对于地图服务内容比较多的服务,使用export的方法,会加大服务器的承担量,会出现加载等待的情况。

 所以我们需要做切片,并调取切片地址,调取切片我们使用XYZ方式

下面是方法

   import TileLayer from "ol/layer/Tile";
   import {XYZ} from "ol/source";
   import TileGrid from "ol/tilegrid/TileGrid";


    let newLayer = new TileLayer({
                    source: new XYZ({
                        url: `${url}/tile/{z}/{y}/{x}`,
                        tileGrid: new TileGrid(_tileInfo),
                        projection: 'EPSG:4528',
                    })
                });

如果使用的是我博客OpenLayer对容器Map自定义坐标系中的方法,其中的 projection只需要声明即可,因为你已经在容器中进行了注册

其中的tileGrid参数一定要填,其中的_tileInfo需要自己去配置,我是自定义的切片方案,下面是我的配置大概结构

 tileInfo: {
      tileSize: 256,
      origin: [34876800, 10002100],
      extent: [4033632.0624805965, 3941793.1294050445, 40415464.86271994, 4009201.8967805225],
      resolutions: [
        132.29193125052919,
        76.351460927313525,
        38.175730463656762,
        19.087865231828381,
        9.543932616046483,
        4.7719663078909491,
        2.3859831539454746,
        1.1929915769727373,
        0.59649578861866059,
        0.14912394722081113
      ]
    }

其中的resolutions需要降序排列,其具体的值,需要自己去你所发布的arcserver详细页面去查看

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Vue加载ArcGIS地图服务,您需要使用OpenLayers库。以下是一些步骤: 1. 安装OpenLayers 您需要先安装OpenLayers库。您可以使用npm来安装它,命令如下: ``` npm install ol ``` 2. 导入OpenLayers 在Vue组件中,您需要导入OpenLayers库。您可以在组件的script部分添加以下代码: ``` import ol from 'ol' import Map from 'ol/Map' import View from 'ol/View' import TileLayer from 'ol/layer/Tile' import XYZ from 'ol/source/XYZ' ``` 3. 创建地图 在Vue组件的methods部分,您可以创建一个createMap函数,其中包含创建地图的代码。以下是一个示例代码: ``` createMap() { let map = new Map({ target: 'map', view: new View({ center: [0, 0], zoom: 2 }) }); let layer = new TileLayer({ source: new XYZ({ url: 'http://server.arcgisonline.com/ArcGIS/rest/services/World_Street_Map/MapServer/tile/{z}/{y}/{x}' }) }); map.addLayer(layer); } ``` 在上面的代码中,我们首先创建一个地图对象,然后创建一个瓦片图层,并将其添加到地图对象中。在瓦片图层的source属性中,我们指定了ArcGIS地图服务的URL。 4. 在模板中添加地图 在Vue组件的template部分,您可以添加一个div元素来显示地图。以下是一个示例代码: ``` <template> <div> <div id="map"></div> </div> </template> ``` 在上面的代码中,我们添加了一个id为“map”的div元素,它将用于显示地图。 5. 调用createMap函数 最后,在Vue组件的mounted部分,您可以调用createMap函数来创建地图。以下是一个示例代码: ``` mounted() { this.createMap(); } ``` 在上面的代码中,我们在组件挂载后调用createMap函数。 这就是在Vue加载ArcGIS地图服务的基本步骤。您可以根据自己的需求进行修改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值