SueperMap iMobile for android中在线数据对接大全

2024-02-25 08:58

本文主要是介绍SueperMap iMobile for android中在线数据对接大全,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

作者:xinxin

       在SuperMap产品中,数据源可以分为文件型数据源、数据库型数据源和在线数据源,SuperMap iMobile for Android可以对接文件型数据源和在线数据源,文件型数据源目前主要支持UDB格式,这个是加载本地数据,比较简单,不作过多介绍。在线数据源也分很多种,比如有SuperMap iServer发布的rest、wmts、wms服务和天地图服务等。下面将分享iMobile for android对接各种常用在线数据。

1、 iserver发布的服务

1) Rest地图服务
Iserver服务器发布rest地图服务后,使用iMobile for android来对接,关键代码如下:

String url = "http://supermap.com.cn:8090/iserver/services/map-changchun/rest/maps/%E9%95%BF%E6%98%A5%E5%B8%82%E5%8C%BA%E5%9B%BE";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.Rest);
info.setAlias("iserver_rest");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

2) OGC服务
(1) 打开wmts服务,关键代码如下:

String url = "http://supermap.com.cn:8090/iserver/services/map-china400/wmts-china";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OGC);
info.setDriver("WMTS");
info.setAlias("iserver_wmts");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

(2) 打开wms服务,关键代码如下:
方法一:

String url = "http://supermap.com.cn:8090/iserver/services/map-world/wms130/World";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OGC);
info.setDriver("WMS");
info.setAlias("iserver_wms");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

方法二:

DatasourceConnectionInfo info03 = new DatasourceConnectionInfo();
info03.setAlias("gkdm");
// 设置地图服务地址()
info03.setServer("http://support.supermap.com.cn:8090/iserver/services/map-china400/wms130/China");
// 设置引擎类型
info03.setEngineType(EngineType.OGC);
// 设置驱动名称
info03.setDriver("WMS");
// 设置WMS服务的版本号
info03.setWebVersion("1.3.0");
info03.setWebVisibleLayers("0");
info03.setWebCoordinate("EPSG:3857");
info03.setWebFormat("image/png");
Rectangle2D rect01 = new Rectangle2D(-2.0037508342789248E7, -2.003750834278914E7,2.0037508342789244E7, 2.0037508342789087E7);
info03.setWebBBox(rect01);
info03.setWebExtendParam("");
Datasource datasource2 = workspace.getDatasources().open(info03);
if (datasource2==null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

(3) 打开wfs服务,关键代码如下:

String url = "http://support.supermap.com.cn:8090/iserver/services/data-world/wfs100/utf-8";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OGC);
info.setDriver("WFS");
info.setAlias("iserver_wfs");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

(4) 打开wcs服务,关键代码如下:

String url = "http://support.supermap.com.cn:8090/iserver/services/data-jingjin/wcs111";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OGC);
info.setDriver("WCS");
info.setAlias("iserver_wcs");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

2、 超图云

超图云是由超图公司发布的一个在线服务,打开超图云的关键代码:

String url = "http://t2.supermapcloud.com/";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.SuperMapCloud);
info.setAlias("supermapcloud");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

3、 天地图

天地图其实是标准的OGC服务,主要有wmts服务和wms服务,目前打开天地图前需要需要到天地图官网申请一个移动的key值。
1) 打开wmts服务
(1) 经纬度服务

String url = "http://t0.tianditu.gov.cn/img_c/wmts?tk=855df38010df4353447beb0c0808d9a6";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OGC);
info.setDriver("WMTS");
info.setAlias("tianditu_wmts");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

(2) 平面投影服务

String url = "http://t0.tianditu.gov.cn/img_w/wmts?dpi=96&tk=855df38010df4353447beb0c0808d9a6&topleftcornerexchange=1";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OGC);
info.setDriver("WMTS");
info.setAlias("tianditu_wmts");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

2)打开wms服务
与打开wmts服务类似,只需将info.setDriver(“WMTS”)换成info.setDriver(“WMS”),这里不再赘述。
备注:打开天地图的平面投影坐标系还需要带一个topleftcornerexchange参数,保证数据加载到地图能正常渲染显示;其中dpi=96参数是解决和其它数据叠加偏移问题。

4、 百度地图

关键代码如下:

String url = "http://map.baidu.com";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.BaiDu);
info.setAlias("baidu");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

5、 Google地图

关键代码如下:

String url = "http://www.google.cn/maps";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.GoogleMaps);
info.setAlias("googlemaps");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

6、 OpenStreetMaps

关键代码如下:

String url = "http://openstreetmap.org";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.OpenStreetMaps);
info.setAlias("openstreetmaps");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

7、 BingMaps

关键代码如下:

String url = "http://cn.bing.com/maps";
Workspace workspace = new Workspace();
DatasourceConnectionInfo info = new DatasourceConnectionInfo();
info.setServer(url);
info.setEngineType(EngineType.BingMaps);
info.setAlias("bingmaps");
Datasource datasource = workspace.getDatasources().open(info);
if (datasource == null){Toast.makeText(this,"数据源打开失败",Toast.LENGTH_SHORT).show();return;
}

这篇关于SueperMap iMobile for android中在线数据对接大全的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

电力系统中的A类在线监测装置—APView400

随着电力系统的日益复杂和人们对电能质量要求的提高,电能质量在线监测装置在电力系统中得到广泛应用。目前,市场上的在线监测装置主要分为A类和B类两种类型,A类和B类在线监测装置主要区别在于应用场景、技术参数、通讯协议和扩展性。选择时应根据实际需求和应用场景综合考虑,并定期维护和校准。电能质量在线监测装置是用于实时监测电力系统中的电能质量参数的设备。 APView400电能质量A类在线监测装置以其多核

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo