news 2026/4/23 20:42:07

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/4/23 11:20:49

I/O重定向程序

从标准输入拷贝文件或从指定磁盘文件拷贝到标准输出。#include <sys/types.h> #include <sys/stat.h> #include <fcntl.h> #include <unistd.h> #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <string.h&…

作者头像 李华
网站建设 2026/4/23 11:21:29

AI 办公提效的关键是什么?5 个可复用工作流(含 Prompt 模板)

随着人工智能相关工具越来越多&#xff0c;很多打工人心里其实都有一个差不多的感觉&#xff1a;AI 好像已经渗透进了各种办公场景&#xff0c;过去要求的职场技能开始加上了AI的标签&#xff0c;逐渐演变成为职场的 AI 技能。真正在办公中使用AI之后&#xff0c;你就会发现技能…

作者头像 李华
网站建设 2026/4/23 9:53:41

开发工具类——获取唯一标识号

问题&#xff1a;现在有一批货物需要编号0000-9999&#xff0c;使用普通随机可能会重复获取 解决方案&#xff1a;根据当年当天的时间为依据&#xff0c;一年内不会重复的4位数&#xff0c;利用年日时分秒的组合&#xff0c;通过哈希算法生成固定4位数字。 import java.time.L…

作者头像 李华
网站建设 2026/4/23 9:52:49

腾讯云渠道商:轻量服务器低成本托管小型网站的 5 个关键实践

一、引言 随着云计算普及&#xff0c;越来越多的用户选择腾讯云轻量应用服务器托管小型网站。但服务器运维直接影响网站稳定性和安全性。本文结合行业实践&#xff0c;总结低成本托管小型网站的 5 个关键实践&#xff0c;帮助您高效管理云服务器。 二、5 大关键运维实践&#…

作者头像 李华
网站建设 2026/4/23 11:19:11

页面加载性能手动检查指南

在软件测试领域&#xff0c;页面加载性能直接影响用户体验和业务转化率。作为测试从业者&#xff0c;手动检查能深入定位瓶颈&#xff0c;避免依赖自动化工具的局限性。本文系统介绍手动检查的核心方法、工具使用和优化策略&#xff0c;帮助测试人员高效评估Web应用性能。 一、…

作者头像 李华
网站建设 2026/4/23 9:54:20

车载智能洗手器设计与实现

车载智能洗手器设计与实现 一、设计背景与意义 车载场景中&#xff0c;驾乘人员在长途行驶、户外露营或接触污渍后&#xff0c;存在手部清洁需求&#xff0c;但传统车载清洁依赖瓶装水纸巾&#xff0c;存在浪费水资源、清洁不彻底、操作不便等问题。现有便携洗手器多为手动按压…

作者头像 李华