leaflet 在线调用arcgis GP插值

调用GP插值服务主要分为两步
一.arcgis 制作 GP服务
1.arcmap版本需要和server版本一样, 不然gp服务无法使用
2.发布服务的时候选择“查看结果图层”,不然不能渲染到地图上(同理,模型构建器中需要把最后的结果设为参数,不然也无法渲染)
3.如果一直报错,但不知道哪有问题,打开arcgis manager ,点进调用的 gp 服务,里面有个 ”submitJob ***“ 的按钮,get或者post 的都可以,可以进入测试界面
二.js调用

import qs from 'qs' //引入qs用于格式化json格式
// qs插件的介绍
// https://blog.csdn.net/m0_45272038/article/details/120181018
setInterpolation(data) {
      this.queryParams.pollutantName = data
      this.getPointList().then((temp) => {
        const tempValue = 'overMultiple'
        // 先移除图层
        if (this.dynamicLayer) {
          map.removeLayer(this.dynamicLayer)
          this.dynamicLayer = null
        }
        this.GISServer.GPServer = 'http://39.101.202.131:6080/arcgis/rest/services/TRJC/TRJCInterpolation/GPServer/TRJCFinal'
        this.GISServer.mapServer = 'http://39.101.202.131:6080/arcgis/rest/services/TRJC/TRJCInterpolation/MapServer'

        if (tempValue && this.pollutantlist.length > 0 && data !== '') {
          this.lengendShow = true
          this.loading = true
          // 临时插值数据
          const tempJson = {
            'displayFieldName': '',
            'geometryType': 'esriGeometryPoint',
            'spatialReference': {
              'wkid': 4326,
              'latestWkid': 4326
            },
            'fields': [
              {
                'name': 'FID',
                'type': 'esriFieldTypeOID',
                'alias': 'FID'
              },
              {
                'name': 'name',
                'type': 'esriFieldTypeString',
                'alias': 'name',
                'length': 254
              },
              {
                'name': 'lon',
                'type': 'esriFieldTypeDouble',
                'alias': 'lon'
              },
              {
                'name': 'lat',
                'type': 'esriFieldTypeDouble',
                'alias': 'lat'
              },
              {
                'name': 'name11',
                'type': 'esriFieldTypeString',
                'alias': 'name11',
                'length': 254
              },
              {
                'name': 'teep',
                'type': 'esriFieldTypeDouble',
                'alias': 'teep'
              },
              {
                'name': 'va',
                'type': 'esriFieldTypeString',
                'alias': 'va',
                'length': 254
              },
              {
                'name': 'value1',
                'type': 'esriFieldTypeDouble',
                'alias': 'value1'
              },
              {
                'name': 'value2',
                'type': 'esriFieldTypeDouble',
                'alias': 'value2'
              },
              {
                'name': 'value3',
                'type': 'esriFieldTypeDouble',
                'alias': 'value3'
              },
              {
                'name': 'value4',
                'type': 'esriFieldTypeDouble',
                'alias': 'value4'
              },
              {
                'name': 'value5',
                'type': 'esriFieldTypeDouble',
                'alias': 'value5'
              },
              {
                'name': 'value6',
                'type': 'esriFieldTypeDouble',
                'alias': 'value6'
              }
            ],
            'features': [],
            'exceededTransferLimit': false
          }
          for (var i = 0; i < this.pollutantlist.length; i++) {
            if (this.pollutantlist[i].longitude && this.pollutantlist[i].latitude) {
              var feature = { 'geometry': { 'x': this.pollutantlist[i].longitude, 'y': this.pollutantlist[i].latitude, 'spatialReference': { 'wkid': 4326 }}, 'attributes': { 'value3': this.pollutantlist[i][tempValue], 'name': this.pollutantlist[i].regionName, 'lat': this.pollutantlist[i].latitude, 'lon': this.pollutantlist[i].longitude }}
              tempJson.features.push(feature)
            }
          }
          // 请求接口开始插值
          axios.post(this.GISServer.GPServer + '/submitJob?f=json',
            qs.stringify({ test: JSON.stringify(tempJson), Z: 'value3' })
            , {
              headers: {
                // 关键
                'Content-Type': 'application/x-www-form-urlencoded; charset=UTF-8'
              }
            }).then(res => {
            if (res.data.jobId) {
              this.getResult(res.data.jobId)
            } else {
              alert('提示', '计算失败!')
            }
          }).catch(err => { //
            console.log('请求失败:' + err.status + ',' + err.statusText)
          })
        }
      })
    },
    // 请求接口获取绘制好的插值图
    getResult(params) {
      axios.post(this.GISServer.GPServer + '/jobs/' + params + '?f=json').then(res => {
        if (res.data.jobStatus === 'esriJobSucceeded') {
          this.showResult(params)
        } else {
          this.getResult(params)
        }
      })
    },
    // 绘制插值图
    showResult(params) {
      var mapurl = this.GISServer.mapServer + '/jobs/' + params
      this.dynamicLayer = esri.dynamicMapLayer({ url: mapurl, opacity: 0.4, useCors: false, zIndex: 9999 })
      this.dynamicLayer.addTo(map)
    },

备注:
1.动态的参数需要在模型构建器中设置为模型参数,并在发布服务时将该参数设置为“用户自定义”;
2.参数具体格式可以参考模型中 Submit Job 中的参数格式
3.最好事先在 Submit Job 界面能够实现之后再进行前端代码开发

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Esri Leaflet 中点击获取 ArcGIS 服务属性,可以按照以下步骤进行操作: 1. 导入所需的库文件和样式表: ```html <!-- Esri Leaflet --> <link rel="stylesheet" href="https://unpkg.com/esri-leaflet/dist/esri-leaflet.css" /> <script src="https://unpkg.com/esri-leaflet"></script> <!-- Leaflet --> <link rel="stylesheet" href="https://unpkg.com/leaflet/dist/leaflet.css" /> <script src="https://unpkg.com/leaflet"></script> ``` 2. 创建地图容器: ```html <div id="map"></div> ``` 3. 初始化地图: ```javascript var map = L.map('map').setView([latitude, longitude], zoomLevel); ``` 其中,`latitude` 和 `longitude` 是地图的中心点坐标,`zoomLevel` 是缩放级别。 4. 添加 ArcGIS 服务图层: ```javascript var url = 'https://services.arcgis.com/{your-service-id}/arcgis/rest/services/{your-layer-name}/FeatureServer/{layer-index}'; var layer = L.esri.featureLayer({ url: url }).addTo(map); ``` 将 `{your-service-id}` 替换为 ArcGIS 服务的 ID,`{your-layer-name}` 替换为图层的名称,`{layer-index}` 替换为图层的索引。 5. 添加点击事件处理程序: ```javascript layer.on('click', function(event) { var feature = event.layer.feature; // 获取属性值 var attributes = feature.properties; // 处理属性值 // ... }); ``` 在点击图层要素时,会触发 `click` 事件,可以在事件处理程序中获取要素的属性值。 以上是在 Esri Leaflet 中点击获取 ArcGIS 服务属性的基本方法。你可以根据实际需求对属性值进行进一步处理或显示。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值