当前位置: 首页 > news >正文

cesium 实现万级管网数据渲染,及pickImageryLayerFeatures原生方法改写

🚀 个人简介:某大型测绘遥感企业资深Webgis开发工程师,软件设计师(中级)、CSDN优质创作者
💟 作 者:柳晓黑胡椒❣️
📝 专 栏:vue实践
🌈 若有帮助,还请关注点赞收藏,不行的话我再努努力💪💪💪

  • 需求背景
  • 解决效果
  • getFeatureInfo

需求背景

在用 geoserver 渲染图层时,会自动触发 GetFeatureInfo ,与服务器通信,在万级海量数据渲染下,这个性能消耗就可以感受到了
需要考虑的点:
1.通过enablePickFeatures,关闭cesium自身调用geoserver服务 (开始的10多秒 -> 毫秒级别 )
2.需要对照cesium源码,模拟pickImageryLayerFeatures拾取wms服务图层模拟,实现pickFeatures 条用服务方法
在这里插入图片描述

解决效果

在这里插入图片描述
在这里插入图片描述

getFeatureInfo

const getFeatureInfo = async (movement) => {
  console.time('点击时间')
  const screenPosition = movement.position;
  const ray = viewer.camera.getPickRay(screenPosition);
  const terrainIntersection = viewer.scene.globe.pick(ray, viewer.scene);
  const cartographic = Cesium.Cartographic.fromCartesian(terrainIntersection);
  const longitude = Cesium.Math.toDegrees(cartographic.longitude); // 经度
  const latitude = Cesium.Math.toDegrees(cartographic.latitude);  // 纬度
  const pickedTile = viewer.scene.globe._surface._tilesToRender
  const level = pickedTile[0].data.imagery[0].readyImagery.level
  const offset = 265 - 15 * level
  const deltaLat = offset / 111320;
  const deltaLon = offset / 111320;
  const maxx = Math.max.apply(null,[longitude - deltaLon,longitude + deltaLon])
  const minx = Math.min.apply(null,[longitude - deltaLon,longitude + deltaLon])
  const maxy = Math.max.apply(null,[ latitude - deltaLat,latitude + deltaLat])
  const miny = Math.min.apply(null,[ latitude - deltaLat,latitude + deltaLat])
  const bbox = [minx, miny, maxx, maxy].join()
  const allTypeNameArr = ['zhsw:basic_waterwork', "zhsw:basic_pipeline", "zhsw:basic_pump", "zhsw:basic_node", "zhsw:basic_valve", "zhsw:basic_reservoir"]
  const typeNameArr = viewer.imageryLayers._layers.map(item => item.imageryProvider.layers).reverse().filter(item => allTypeNameArr.includes(item))
  const promiseArr = typeNameArr.map(typeName => wfsGetFeaturei({
    service: 'WFS',
    version: '1.0.0',
    request: 'GetFeature',
    outputFormat: 'application/json',
    srs: 'EPSG:4326',
    maxFeatures: 5,
    typeName,
    x: 128,
    y: 128,
    width: 256,
    height: 256,
    bbox,
    viewparams:`planId:${globalStore.planObj.id};regionId:${globalStore.planObj.regionId}`,
  }))
  const dataArr = await Promise.all(promiseArr)
  let data = []
  dataArr.some(item => {
    data = item.data.features
    return item.data.features.length
  })
  return data
  console.timeEnd('点击时间')
}

相关文章:

  • 模型蒸馏实战qwen2.5系列模型
  • Android Room 框架测试模块源码深度剖析(五)
  • 汇编基础知识
  • 压测实战 | 微信小程序商城 “双 11” 的压测实践
  • 开源文档管理系统 Paperless-ngx
  • Java学习------内部类
  • 4G模组Air780EPM:解锁物联网时代的硬件接口奥秘!
  • 【eNSP实战】(续)一个AC多个VAP的实现—将隧道转发改成直接转发
  • 有了大模型为何还需要Agent智能体
  • Mysql-经典实战案例(3): pt-archiver 实现 MySQL 千万级大表分库分表(上)
  • 设计模式之外观模式:原理、实现与应用
  • 设备物联网无线交互控制,ESP32无线联动方案,产品智能化响应
  • OpenCV计算摄影学(23)艺术化风格化处理函数stylization()
  • 【Android Studio】解决遇到的一些问题
  • Vue3项目中可以尝试封装那些组件
  • SpringSecurity——如何实现验证码登录页面
  • 内存回收异常导致OOM的问题
  • Android中的Wifi框架系列
  • JS中的变量提升
  • OpenCV 图像双线性插值
  • 国家主席习近平同普京总统共见记者
  • 北上广深均宣布下调个人住房公积金贷款利率
  • 习近平抵达莫斯科对俄罗斯进行国事访问并出席纪念苏联伟大卫国战争胜利80周年庆典
  • 上海明后天将迎强风大雨,陆地最大阵风7~9级
  • 重庆动物园大熊猫被游客扔玻璃瓶,相同地方曾被扔可乐瓶
  • 老人刷老年卡乘车被要求站着?公交公司致歉:涉事司机停职