地图动态标绘--B/S应用(二)

2024-02-25 10:58
文章标签 动态 应用 地图 标绘

本文主要是介绍地图动态标绘--B/S应用(二),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:Sniper

动态标绘广泛应用于电力、通信和应急等多个行业和领域。它可以用形象生动的矢量符号描述各种业务对象,表示各种资源,还可以动态渲染业务进度和流程。

在地图动态标绘–B/S应用(一)这篇博客中我们介绍了在B/S应用中使用SuperMap iServer和SuperMap iClient实现关于动态标绘的数据发布、使用标绘控件和面板以及编辑标号等功能。那么今天我们介绍下标绘态势图保存、加载、上传以及下载的操作。

一、态势图的保存和加载

首先我们需要知道的是,再客户端绘制成功的态势图,可以保存在服务器中,也可以保存在本地。对服务器中态势图的相关操作就是态势图的保存和加载。

首先,我们可以在iServer的动态标绘服务中看到当前服务器保存的态势图,本地服务地址为:
http://iserverihost:8090/iserver/services/plot-jingyong/rest/plot/smlInfos
态势图列表

态势图文件在服务器中的物理存储路径为发布的plot文件同级目录下的SmlFile目录下,即:
服务器态势图本地文件

打开态势图文件可以看到,实际上态势图文件中存储的是json格式的标绘符号信息,如下:
这里写图片描述

加载态势图的时候,iClient会读取到态势图中的内容并绘制到地图上。需要注意的是,态势图文件本身不包含坐标信息,其中的坐标值是地图坐标系中的值。暂时不支持投影转换。

那么如何用iClient的代码来实现保存和载入态势图呢?
1、按照上一篇文章中描述的那样,添加标绘图层,添加标绘绘制控件和编辑控件,定义态势标绘总控类,获取获取态势数据管理接口,绘制标绘符号。这里只贴出来定义总控类和获取获取态势数据管理接口的代码,其余代码请参考地图动态标绘–B/S应用(一)。

//总控类
plotting = new SuperMap.Plotting(map, serverUrl);
//获取获取态势数据管理接口
sitManager = plotting.getSitDataManager();

2、保存态势图

sitManager.saveSmlFile();

这里非常简单,就是使用态势数据管理类,调用saveSmlFile方法。但需要注意的是,如果当前服务器中没有保存态势图,则会新建一个名为situationMap的态势图文件。如果服务器中已经有了situationMap,则覆盖。

3、另存态势图

sitManager.saveAsSmlFile("yourSituationMap");

将当前绘制的符号保存到一个名为yourSituationMap的态势图文件中,同样的道理,如果已经存在yourSituationMap,就会覆盖原文件。

4、加载态势图

        //加载态势图function loadSimulationMap() {function success() {var sitDataLayers = sitManager.getSitDataLayers();plottingEdits = [];drawGraphicObjects = [];for (var i = 0; i < sitDataLayers.length; i++) {plottingEdits.push(sitDataLayers[i].plottingEdit);drawGraphicObjects.push(sitDataLayers[i].drawGraphicObject);stylePanel.addEditLayer(sitDataLayers[i]);}plotPanel.setDrawFeature(drawGraphicObjects[0]);}function fail() {console.log("error");}var select = document.getElementById("SLT");for (var i = 0; i < select.children.length; i++) {if (select.children[i].selected) {//打开指定的已发布态势图文件到指定图层,未指定图层则加载到this.activeLayer。sitManager.openSmlFileOnServer(select.children[i].value, success, fail);}}}

这里是创建一个select标签,从标签中获取要加载的态势图名称,然后读取态势图文件,将其中的标绘符号渲染出来。

二、态势图的上传和下载

态势图的下载就是将当前服务器上的态势图文件保存到本地,同时也可以将本地的态势图文件上传到服务器。下载的态势图中的数据结构和服务器中存储的一样,上传的态势图保存在服务器中的相应位置。
下面我们来看一下怎么通过代码来实现上传和下载的操作:

1、下载

//服务地址
var serverUrl = "http://localhost:8090/iserver/services/plot-jingyong/rest/plot/";
//从服务器上获取指定的态势文件的下载地址
var result = sitManager.downloadSmlFileURL(downliadFileName);
//组织url
var downloadUrl = serverUrl + result;
//打开新页面下载
window.open(downloadUrl);

下载下来的态势图如图所示,是一个以态势图名称命名的没有后缀名的文件。
下载下来的态势图文件

用nodepad++打开该文件可以看到,其中的文件格式和服务器中保存的一样:
nodepad++打开

2、上传

        function fileFilter(){//上传文件var file = document.getElementById('smlFile');file.setAttribute("accept",".sml");}

这里使用fileupLoad.js来上传文件,fileupLoad.js可以在 iServer目录\iClient\forJavaScript\examples\js中获取。

       //上传态势图文件。function uploadSmlFile( ){function sucess(){getSMLInfos();}function fail(){console.log("todo something if faied");}//要上传到服务器的态势图文件的div的id。//成功回调函数//失败回掉函数sitManager.uploadSmlFile('smlFile', sucess, fail);}

上传后的态势图,就可以在iServer的服务页面中看到。

到这里关于态势标绘图的保存、加载、上传、下载的操作已经全部介绍完毕了。那么关于标绘符号的SQL查询、几何查询等功能,我们下一篇再讲~

这篇关于地图动态标绘--B/S应用(二)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/745253

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Python中yield的用法和实际应用示例

《Python中yield的用法和实际应用示例》在Python中,yield关键字主要用于生成器函数(generatorfunctions)中,其目的是使函数能够像迭代器一样工作,即可以被遍历,但不会... 目录python中yield的用法详解一、引言二、yield的基本用法1、yield与生成器2、yi

Python多线程应用中的卡死问题优化方案指南

《Python多线程应用中的卡死问题优化方案指南》在利用Python语言开发某查询软件时,遇到了点击搜索按钮后软件卡死的问题,本文将简单分析一下出现的原因以及对应的优化方案,希望对大家有所帮助... 目录问题描述优化方案1. 网络请求优化2. 多线程架构优化3. 全局异常处理4. 配置管理优化优化效果1.

从基础到高阶详解Python多态实战应用指南

《从基础到高阶详解Python多态实战应用指南》这篇文章主要从基础到高阶为大家详细介绍Python中多态的相关应用与技巧,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、多态的本质:python的“鸭子类型”哲学二、多态的三大实战场景场景1:数据处理管道——统一处理不同数据格式

Python利用GeoPandas打造一个交互式中国地图选择器

《Python利用GeoPandas打造一个交互式中国地图选择器》在数据分析和可视化领域,地图是展示地理信息的强大工具,被将使用Python、wxPython和GeoPandas构建的交互式中国地图行... 目录技术栈概览代码结构分析1. __init__ 方法:初始化与状态管理2. init_ui 方法:

Java Stream 的 Collectors.toMap高级应用与最佳实践

《JavaStream的Collectors.toMap高级应用与最佳实践》文章讲解JavaStreamAPI中Collectors.toMap的使用,涵盖基础语法、键冲突处理、自定义Map... 目录一、基础用法回顾二、处理键冲突三、自定义 Map 实现类型四、处理 null 值五、复杂值类型转换六、处理