news 2026/6/10 11:32:49

SuperMap iClient for OpenLayers如何实现对影像服务设置图层掩膜

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SuperMap iClient for OpenLayers如何实现对影像服务设置图层掩膜

作者:Carlo

文章目录

  • 业务背景
  • 实现步骤
  • 关键代码解析
    • 1. 初始化地图和图层
    • 2. 查询掩膜边界数据
    • 3. 掩膜操作核心方法
    • 完整代码实现

业务背景

在地理信息系统(GIS)应用中,影像服务通常提供高分辨率的遥感影像或地图底图。但在实际业务场景中,我们经常需要限制影像的显示范围,只展示特定区域内的影像数据。这种需求常见于:

  • 行政区划展示:只显示某个省/市范围内的影像;
  • 重点区域突出:在全局影像上突出显示特定区域;
  • 数据保密:只公开部分区域的影像数据;
  • 性能优化:减少不必要区域的影像加载

图层掩膜技术就是解决这类问题的有效方案,它通过矢量边界来控制影像的显示范围。

实现步骤

  • 准备掩膜数据:获取用于定义显示范围的矢量边界(如行政区划面)。
  • 创建影像图层:加载SuperMap影像服务。
  • 应用掩膜:将矢量边界设置为影像图层的掩膜。
  • 动态控制:提供掩膜的添加和移除功能。

关键代码解析

1. 初始化地图和图层

// 创建OpenLayers地图实例varmap=newol.Map({target:'map',view:newol.View({projection:'EPSG:4326',center:[110,19.2],minZoom:1,zoom:8.5})});// 添加地图服务(作为底图)varlayer=newol.layer.Tile({source:newol.source.TileSuperMapRest({url:'https://iserver.supermap.io/iserver/services/map-world/rest/maps/World',wrapX:true})});map.addLayer(layer);// 添加影像服务图层(叠加显示)varvectorLayer=newol.layer.Tile({zIndex:90,source:newol.source.ImageTileSuperMapRest({url:'您的影像服务地址',projection:'EPSG:4326',collectionId:'sample'})});map.addLayer(vectorLayer);

2. 查询掩膜边界数据

// 构建查询参数,从中国省份数据中查找特定区域,此处查找海南省varparam=newol.supermap.QueryBySQLParameters({queryParams:{name:'Province_R@China',// 数据源名称attributeFilter:'SMID = 3'// 查询条件(这里示例查询ID为3的省份)}});// 执行查询获取掩膜边界newol.supermap.QueryService('https://iserver.supermap.io/iserver/services/map-ChinaProvinces/rest/maps/ChinaProvinces').queryBySQL(param,function(serviceResult){// 将查询结果转换为OpenLayers可用的要素格式sichuanFeature=newol.format.GeoJSON().readFeatures(serviceResult.result.recordsets[0].features)[0];// 应用掩膜ol.supermap.Util.setMask(vectorLayer,sichuanFeature);});

3. 掩膜操作核心方法

// 添加掩膜函数functionaddMask(){ol.supermap.Util.setMask(vectorLayer,sichuanFeature);}// 移除掩膜函数functionremoveMask(){ol.supermap.Util.unsetMask(vectorLayer);}

完整代码实现

<!--*********************************************************************Copyright©2000-2025SuperMap Software Co.Ltd.All rights reserved.*********************************************************************--><!--*********************************************************************该示例需要引入*ol-mapbox-style(https://github.com/openlayers/ol-mapbox-style)*********************************************************************--><!DOCTYPEhtml><html><head><meta charset="UTF-8"/><title data-i18n="resources.title_mask"></title><style type="text/css">.editPane{position:absolute;top:50px;right:50px;text-align:center;background:#fff;z-index:1000;}</style></head><body style="margin: 0; overflow: hidden; background: #fff; width: 100%; height: 100%; position: absolute; top: 0"><divclass="panel panel-primary editPane"id="editPane"style="z-index: 99999"><divclass="panel-heading"><h5class="panel-title text-center"data-i18n="resources.btn_operate"></h5></div><divclass="panel-body"id="params"><p></p><div align="right"class="button-group"><input type="button"id="btn1"class="btn btn-primary"data-i18n="[value]resources.text_input_value_addMask"onclick="addMask()"/><input type="button"id="btn2"class="btn btn-primary"data-i18n="[value]resources.text_input_value_removeMask"onclick="removeMask()"/></div></div></div><div id="map"style="width: 100%; height: 100%"></div><script type="text/javascript"include="bootstrap,widgets"src="../js/include-web.js"></script><script type="text/javascript"include="ol-mapbox-style"src="../../dist/ol/include-ol.js"></script><script type="text/javascript">varsichuanFeature;varprojection='EPSG:4326';varmap=newol.Map({target:'map',view:newol.View({projection:projection,center:[110,19.2],minZoom:1,zoom:8.5})});//添加地图服务,作为底图varlayer=newol.layer.Tile({source:newol.source.TileSuperMapRest({url:'https://iserver.supermap.io/iserver/services/map-world/rest/maps/World',wrapX:true})});map.addLayer(layer);//添加影像服务,叠加显示varvectorLayer=newol.layer.Tile({zIndex:90,source:newol.source.ImageTileSuperMapRest({url:'https://iserver.supermap.io/iserver/services/imageservice-hainan/restjsr',projection:projection,collectionId:'sample'})});map.addLayer(vectorLayer);//添加掩膜functionaddMask(){if(!sichuanFeature){varparam=newol.supermap.QueryBySQLParameters({queryParams:{name:'Province_R@China',attributeFilter:'SMID = 3'}});//从中国省份地图查找到海南省,作为掩膜矢量要素newol.supermap.QueryService('https://iserver.supermap.io/iserver/services/map-ChinaProvinces/rest/maps/ChinaProvinces').queryBySQL(param,function(serviceResult){sichuanFeature=newol.format.GeoJSON().readFeatures(serviceResult.result.recordsets[0].features)[0];//为图层设置掩膜ol.supermap.Util.setMask(vectorLayer,sichuanFeature);});return;}else{ol.supermap.Util.setMask(vectorLayer,sichuanFeature);}}//移除掩膜functionremoveMask(){ol.supermap.Util.unsetMask(vectorLayer);}</script></body></html>

效果展示

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 19:48:23

2026跨境电商必看:Etsy保号防封全攻略

Etsy作为全球领先的手工艺品和创意商品销售平台&#xff0c;吸引了成千上万的卖家。但当你刚准备大干一场&#xff0c;Etsy新店24小时就封了&#xff1f;上架第一个产品&#xff0c;店直接没了&#xff1f;本文将带你了解常见的封号原因&#xff0c;并提供实操干货&#xff0c;…

作者头像 李华
网站建设 2026/6/10 11:23:07

Adobe Flash Player 一款轻量级浏览器插件

Adobe Flash Player 是一款轻量级浏览器插件&#xff0c;具有丰富的 Internet 应用运行时间&#xff0c;提供持续的迷人用户体验、绝妙的音频/视频回放效果和刺激的游戏。新日志&#xff1a; v32.0.0.465 (2020-12-08) • 分类功能修正注意&#xff1a;新版本的浏览器不支持 Fl…

作者头像 李华
网站建设 2026/6/10 11:22:43

SCI制图——Origin信号处理:FFT变换与滤波降噪

一、为什么实验数据需要降噪与频域分析&#xff1f;在理想状态下&#xff0c;我们期望获得的仪器数据是一条光滑、流畅且规律明显的曲线&#xff0c;能够完美地反映变量之间的物理或化学关系。然而现实中的实验环境往往充满着不可避免的干扰&#xff0c;在采集数据时会受到各种…

作者头像 李华
网站建设 2026/5/30 17:21:46

django+Pythonuniapp的新闻视频资讯小程序

文章目录Django Python Uniapp 新闻视频资讯小程序摘要技术栈组合核心功能模块数据交互与 API 设计跨平台适配性能优化部署与扩展系统设计与实现的思路主要技术与实现手段源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;Django Python …

作者头像 李华
网站建设 2026/6/5 10:42:13

django+Python企业微信的问卷调查系统的设计与实现

文章目录系统背景与目标技术架构核心功能模块创新点与优势应用效果系统设计与实现的思路主要技术与实现手段源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统背景与目标 随着企业数字化转型加速&#xff0c;传统纸质问卷调查效率低、数…

作者头像 李华
网站建设 2026/6/10 10:29:24

GPU并行计算架构在AI与科学计算中的性能优势

最初被设计用于图像渲染的图形处理器&#xff08;GPU&#xff09;&#xff0c;因其架构具备高度并行状态&#xff0c;所以在通用计算范畴呈现出卓越性能。现代的GPU一般含有数千个计算核心&#xff0c;这些计算核心能够同时处理大量的数据线程&#xff0c;而这种特性刚好符合人…

作者头像 李华