基于Java的百度AOI数据解析与转换的实现方法

目录

前言

一、AOI数据结构简介

1、官网的实例接口

2、响应参数介绍

二、Java对AOI数据的解析

1、数据解析流程图

2、数据解析实现

3、AOI数据解析成果

三、总结


前言

        在当今信息化社会,地理信息数据在城市规划、交通管理、商业选址等领域扮演着越来越重要的角色。AOI(Area of Interest,兴趣面)数据作为地理信息数据的重要组成部分,能够提供区域状地理实体的详细边界信息,对于相关领域的研究和应用具有重要价值。百度地图作为地图服务提供商,其提供的AOI数据因其覆盖范围广、精度高、更新及时等特点,受到了众多企业和研究机构的青睐。然而,如何高效地解析和转换AOI数据,以便更好地满足不同应用场景的需求,成为了一个亟待解决的问题。基于Java的AOI数据解析与转换的实现方法,正是为了解决这一问题而提出的。

        Java作为一种成熟且广泛应用的编程语言,具有跨平台、面向对象、安全性高等特点,非常适合用于开发各种类型的应用程序。在地理信息数据处理领域,Java也有着广泛的应用,许多地理信息系统(GIS)软件和工具都是基于Java开发的。因此,利用Java来实现AOI数据的解析与转换,不仅能够充分发挥Java的优势,还能够方便地与现有的GIS系统进行集成和扩展。首先,基于Java的AOI数据解析与转换的实现方法需要对AOI数据的格式和结构有深入的了解。百度AOI数据通常以JSON格式提供,包含AOI的名称、类型、边界坐标等信息。其次,实现AOI数据的转换功能是该方法的核心部分。根据不同的应用场景需求,可能需要将AOI数据转换为其他格式,如GIS软件常用的Shapefile格式、KML、GeoJSON格式等,将转换后的数据为第三方服务平台提供数据输入。在Java中,可以使用一些开源的GIS库,如Geotools、JTS Topology Suite等,来实现AOI数据的转换。这些库提供了丰富的地理信息数据处理功能,可以方便地将AOI数据转换为所需的格式。此外,为了提高AOI数据解析与转换的效率和准确性,还可以采用一些优化策略。例如,可以对AOI数据进行预处理,去除重复或冗余的数据;在解析过程中,可以采用多线程技术来提高处理速度;在转换过程中,可以对数据进行适当的简化和优化,以减少数据量和提高转换效率。同时,还可以结合一些GIS分析工具和算法,对转换后的AOI数据进行进一步的分析和处理,以提取更有价值的信息。

        基于Java的AOI数据解析与转换的实现方法,不仅能够为用户提供一个高效、灵活、可靠的解决方案,还能够促进AOI数据在各个领域的应用和发展。通过该方法,用户可以更加方便地获取和转换AOI数据,从而更好地满足自身的需求,推动相关领域的研究和进步。未来,随着技术的不断发展和需求的不断变化,该方法也将不断完善和优化,为地理信息数据处理领域的发展做出更大的贡献。

一、AOI数据结构简介

        作为AOI数据的来源,本节将重点对AOI的数据结构进行深入的介绍。受文章当时的调用API接口的限制,文章介绍的数据以当时的百度API接口为准,如当前您参考的对应接口有所变化,请参考对应的API接口。为了让大家对地图厂商提供的AOI数据有一个简单的认识,这里以百度地图为例,将对百度地图中的AOI数据及其结构进行简单的讲解。

1、官网的实例接口

        首先我们打开地图的官网地址,在打开的地图检索栏中输入待查询的地方。首先我们以一个小区为例,如“璞丽景园”,点击查询按钮后,打开如下界面:

        在地图中我们可以很明显的看到,不仅在左边的检索结果展示窗口中列出了目标小区的地址信息:"湖南省长沙市岳麓区映日路与看云路111号", 于此同时,在地图中也会同步将小区的矢量范围进行展示,是一个常见的polygon面。请大家注意,这里的Polygon面就是本文的主角,AOI(兴趣面数据)。以上是以一个城市居民小区为例介绍了如何进行数据检索以及数据可视化。为了区分不同的数据类型,下面我们选取附近的“岳麓山国家重点风景名胜区”,输入关键字后,点击详细即可看到景区的基本信息以及AOI数据,

        与之前的城市小区信息一样,在界面中不仅展示出地点的信息,同时还在地图上展示了空间边界信息。到此,请注意,我们将实力功能和界面进行简要的介绍。

2、响应参数介绍

        在了解了地址信息如何查询之后,接下来结合API的响应接口,具体来看一下获取的详情接口的属性字段信息,为后续的数据解析和空间挖掘打下坚实的基础,因此本小节将从响应参数的介绍为切入点,逐一向大家解析。在地图的数据返回接口中,以下的接口是返回目标地址的包含AOI数据的响应信息。

        上面的给出的图谱展示的只是一个粗略的结构,真实的信息比上面给出的更多更丰富。大家可以在百度地图上体验相关查询接口,并查阅具体接口的响应参数。简单来讲,详情JSON 数据中,contentavocadoresult 是三个不同的属性,它们各自代表不同的信息:

content 属性

  • 代表内容信息:这个属性包含了与景点相关的各种详细内容信息。它可能包括景点的介绍、特色、历史背景、游客评价等。这些信息有助于用户了解景点的各个方面,为游客提供决策参考。例如,它可能会描述景点的自然风光、文化价值、游客体验等。

avocado 属性

  • 代表卡片信息:这个属性包含了与景点相关的卡片信息。卡片通常用于展示特定类型的内容或功能模块,如图片墙、电话号码、导航信息等。这些卡片可以为用户提供快速访问特定功能或信息的途径,增强用户体验。例如,它可能会包含一个图片墙卡片,展示景点的精美图片;或者一个电话卡片,提供景点的联系电话。

result 属性

  • 代表结果信息:这个属性包含了与请求结果相关的信息。它通常用于表示请求的处理结果,如授权信息、状态码等。这些信息对于开发者或系统来说很重要,因为它们可以用来判断请求是否成功,以及如何处理后续的逻辑。例如,它可能会包含一个授权令牌,表示用户有权限访问某些数据或功能。

        这三个属性在 JSON 数据中各自承担着不同的角色,共同构成了对景点信息的全面描述。使用notepad的json格式化查询器可以看到如下结构:

        返回的信息参数非常多,但是这里主要讲解空间信息,所以主要看ext/detail_info/guoke_geo/geo字段就是我们需要的AOI空间范围数据,如下图中红色框中的内容,是一串非常长的字符串。请记住这个属性,在后面的解析和转换中会继续用得到。

        以上就是对相关AOI的查询接口以及数据属性的详细介绍,下面我们使用Java语言对获取到的AOI数据进行解析和转换。 

二、Java对AOI数据的解析

        在了解了AOI的查询接口以及返回参数的属性信息之后,本节我们将使用JAVA语言对获取到的AOI数据进行解析。首先介绍数据解析的具体流程,然后介绍具体的解析实现,最后将解析得到的结果转换成GeoJSON,然后在Qgis软件中进行预览,验证我们的结果。

1、数据解析流程图

        为了实现对获取的AOI数据进行解析,首先将获取的面边界信息进行内存加载,然后调用转换逻辑,将坐标值进行拼接解析,然后解析得到的坐标。此时的坐标是墨卡托坐标,类似于12571261.302597,3250490.205730这种的值,然后需要调用墨卡托坐标转经纬度坐标方法将值进行转换,然后将得到的百度经纬度坐标转为WGS84坐标,此时就得到对应的WGS84坐标,然后根据转换的坐标值,调用GeoTools的polygon创建方法构建一个面,然后调用FeatureJSON来得到JSON构建对象,最后生成GeoJSON数据后,在Qgis等客户端工具中进行查看。

2、数据解析实现

        首先来分享一段解析得到的AOI矢量边界信息,如下:

        在进行正式的坐标解析时,需要去掉一些信息,这里我们将-1之前的字符进行过滤掉,后面的才是我们需要的空间矢量数据。

4|12566456.116665,3253264.180375;12566801.580670,3253687.136888|1-12566456.1166646,3253456.6396633,12566457.4438543,3253451.9993111,12566457.8641464,3253450.5485102

        最后我们调用公共的方法来实现墨卡托坐标转bd的经纬度坐标。其中解析的方法如下:

/**
* -解析Jeo数据
* @param mocator
*/
public static List<String> parseJeo(String mocator) {
	List<String> mocatorList = new ArrayList<String>();
	if (null == mocator)
		return null;
	/* 拆分数据 */
	String[] geos = mocator.split("\\|");
	int n = Integer.parseInt(geos[0]);
	String center = geos[1];
	String polylineMoca = geos[2]; // 墨卡托坐标
	String[] plm = polylineMoca.split("\\;");
	/* 获取墨卡托边界 */
	String geo = null;
	if (n == 4) {
		for (int i = 0; i < plm.length; i++) {
			String[] geoPaths = plm[i].split("\\-");
			if (geoPaths[0].equals("1")) {
				geo = geoPaths[1];
			}
		}
	}
	// 墨卡托坐标解析
	String[] geoPolyline = geo.split("\\,");
	for (int i = 0; i < geoPolyline.length; i += 2) {
		mocatorList.add(geoPolyline[i] + "#" + geoPolyline[i + 1]);
	}
	return mocatorList;
}

        墨卡托坐标转经纬度坐标的方法如下:

/**
* -墨卡托坐标转经纬度坐标
* @param x
* @param y
* @return
*/
public static Map<String, Double> convertMC2LL(Double x, Double y) {
	Double[] cF = null;
	x = Math.abs(x);
	y = Math.abs(y);
	for (int cE = 0; cE < MCBAND.length; cE++) {
		if (y >= MCBAND[cE]) {
			cF = MC2LL[cE];
			break;
		}
	}
	Map<String, Double> location = converter(x, y, cF);
	location.put("lng", location.get("x"));
	location.remove("x");
	location.put("lat", location.get("y"));
	location.remove("y");
	return location;
}

         最后,我们基于GeoTools将上面转换的经纬度坐标值转换成geometry并最终转换成GeoJSON数据,并可以在gis软件上进行展示和渲染。转换和生成GeoJSON的具体方法如下:

public static void main(String[] args) {
	String objId = "3cf5bd92df7340f1f7eafc6e"; 
	String path = "E:/baidu_aio/" + objId + ".txt";
	try {
		System.out.println(path);
		String geoStr = new String(Files.readAllBytes(Paths.get(path)), "UTF-8");
		List<String> mocatorList = parseJeo(geoStr);
		StringBuilder sb = new StringBuilder(1024);
			
		// 获取GeometryFactory实例
	    GeometryFactory geometryFactory = JTSFactoryFinder.getGeometryFactory(null);
	    Coordinate[] coords = {};
	    if(mocatorList != null && mocatorList.size() > 0) {
	        coords = new Coordinate[mocatorList.size()];
	    }
		for (int i = 0; i < mocatorList.size(); i++) {
			String[] coordinate = mocatorList.get(i).split("\\#");
			Map<String, Double> location = convertMC2LL(Double.parseDouble(coordinate[0]),
						Double.parseDouble(coordinate[1]));
			Double lng = location.get("lng");
			Double lat = location.get("lat");
			String coord = lng + "," + lat;
			sb.append(coord);
			if (i < mocatorList.size() - 1) {
				sb.append(";");
			}
			double[] tempBd284 = CoordinateTransformUtil.bd09towgs84(lng, lat);
			coords[i] = new Coordinate(tempBd284[0], tempBd284[1]);
		}
		// 使用坐标点创建线性环(LinearRing),这是多边形的第一个也是唯一一个环
	    LinearRing shell = geometryFactory.createLinearRing(coords);
	    Polygon polygon = geometryFactory.createPolygon(shell, null);
        // 创建SimpleFeatureType
	    SimpleFeatureTypeBuilder builder = new SimpleFeatureTypeBuilder();
	    builder.setName("PolygonFeature");
	    builder.setCRS(DefaultGeographicCRS.WGS84);
	    builder.add("geometry", Polygon.class);
	    SimpleFeatureType featureType = builder.buildFeatureType();

	    // 创建SimpleFeature
	    SimpleFeatureBuilder featureBuilder = new SimpleFeatureBuilder(featureType);
        //指定唯一的ID
	    SimpleFeature feature = featureBuilder.buildFeature(null, new Object[]{polygon});

	    // 创建FeatureJSON对象,用于将几何对象转换为GeoJSON
	    FeatureJSON featureJSON = new FeatureJSON();
        // 将SimpleFeature对象转换为GeoJSON字符串
        StringWriter writer = new StringWriter();
        featureJSON.writeFeature(feature, writer);
        String geoJSON = writer.toString();
        System.out.println(geoJSON);
	} catch (IOException e) {
		e.printStackTrace();
	}
}

        这样我们就实现了对AOI数据进行解析,同时实现将墨卡托坐标转为经纬度坐标。同时调用GeoTools来生成polygon并生成了对应的GeoJSON数据。下面就可以来看一下成果,看一下GeoJSON加载的效果。 

3、AOI数据解析成果

        在经过以上的数据解析之后,在IDE的运行调试界面运行上面的程序,可以得到以下的GeoJSON数据,结果如下所示:

        然后在磁盘中新建一个geojson文件,将上图红框中的geojson数据复制到对应的geojson文件中,如下图所示,这样就实现了geojson数据的生成:

         最后将得到的geojson数据叠加到地图中,就可以看到其位置是否准确。

        可以看到,将geojson数据与底图进行融合后,成功的在遥感影像中进行了展示,统一空间位置贴合准确,位置没有偏移,说明转换结果良好,符合我们的预期。 

三、总结

        以上就是本文的主要内容,本文将重点介绍基于Java的百度AOI数据解析与转换的实现方法。基于Java的AOI数据解析与转换的实现方法,不仅能够为用户提供一个高效、灵活、可靠的解决方案,还能够促进AOI数据在各个领域的应用和发展。通过该方法,用户可以更加方便地获取和转换AOI数据,从而更好地满足自身的需求,推动相关领域的研究和进步。未来,随着技术的不断发展和需求的不断变化,该方法也将不断完善和优化,为地理信息数据处理领域的发展做出更大的贡献。行文仓促,难免有许多不足之处,如有不足,在此恳请各位专家博主在评论区或者私信指出,不胜感激。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/954341.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度学习中的学习率调度器(scheduler)分析并作图查看各方法差异

文章目录 1. 指数衰减调度器&#xff08;Exponential Decay Scheduler&#xff09;工作原理适用场景实现示例 2. 余弦退火调度器&#xff08;Cosine Annealing Scheduler&#xff09;工作原理适用场景实现示例 3. 步长衰减调度器&#xff08;Step Decay Scheduler&#xff09;工…

IPSEC实验

实验要求 某小型企业为扩大网络规模&#xff0c;设立分公司&#xff0c;今日要求分公司能够访问主公司对应的资源&#xff0c;为此很是苦恼 为满足其跨区域访问对端网络的要求&#xff0c;现要求使用IPSEC搭建隧道使得分公司能够与主公司通讯 实验拓扑 该公司与分公司拓扑大…

[c语言日寄]精英怪:三子棋(tic-tac-toe)3命慢通[附免费源码]

哈喽盆友们&#xff0c;今天带来《c语言》游戏中[三子棋boss]速通教程&#xff01;我们的目标是一边编写博文&#xff0c;一边快速用c语言实现三子棋游戏。准备好瓜子&#xff0c;我们计时开始&#xff01; 前期规划 在速通中&#xff0c;我们必须要有清晰的前期规划&#xf…

TensorFlow DAY3: 高阶 API(Keras,Estimator)(完)

TensorFlow 作为深度学习框架&#xff0c;当然是为了帮助我们更便捷地构建神经网络。所以&#xff0c;本次实验将会了解如何使用 TensorFlow 来构建神经网络&#xff0c;并学会 TensorFlow 构建神经网络的重要函数和方法。 知识点 Keras 顺序模型Keras 函数模型Keras 模型存储…

数据结构(Java版)第九期:LinkedList与链表

专栏&#xff1a;数据结构(Java版) 个人主页&#xff1a;手握风云 目录 一、LinkedList的模拟实现 1.1. 头插法 1.2. 尾插法 1.3. 插入中间节点 1.4. 删除某个节点 1.5. 删除所有为key的元素 二、LinkedList的使用 2.1. 什么是LinkedList 2.2. LinkedList的使⽤ 三、…

ubuntu18.04开发环境下samba服务器的搭建

嵌入式linux的发展很快&#xff0c;最近准备在一个新项目上采用新一代的linux核心板&#xff0c;发现linux内核的版本已经更新到5.4以上甚至6.0以上&#xff1b;之前常用的linux内核版本是2.6.4&#xff0c;虽然在某些项目上还能用但是明显跟不上时代的步伐了&#xff0c;所以要…

【优先算法】滑动窗口--(结合例题讲解解题思路)(C++)

目录 1. 例题1&#xff1a;最大连续1的个数 1.1 解题思路 1.2代码实现 1.3 错误示范如下&#xff1a;我最开始写了一种&#xff0c;但是解答错误&#xff0c;请看&#xff0c;给大家做个参考 2. 将 x 减到 0 的最小操作数 2.1解题思路 2.2代码实现 1. 例题1&#xff…

数据结构二叉树-C语言

数据结构二叉树-C语言 1.树1.1树的概念与结构1.2树的相关术语1.3树的表示1.4树形结构实际运用场景 2.二叉树2.1概念与结构2.2特殊的二叉树2.2.1满二叉树2.2.2完全二叉树 2.3二叉树存储结构2.3.1顺序结构2.3.2链式结构 3.实现顺序结构的二叉树4.实现链式结构二叉树4.1前中后序遍…

Qt/C++进程间通信:QSharedMemory 使用详解(附演示Demo)

在开发跨进程应用程序时&#xff0c;进程间通信&#xff08;IPC&#xff09;是一个关键问题。Qt 框架提供了多种 IPC 技术&#xff0c;其中 QSharedMemory 是一种高效的共享内存方式&#xff0c;可以实现多个进程之间快速交换数据。本文将详细讲解 QSharedMemory 的概念、用法及…

【vue3项目使用 animate动画效果】

vue3项目使用 animate动画效果 前言一、下载或安装npm 安装 二、引入组件三、复制使用四、完整使用演示总结 前言 提示&#xff1a;干货篇&#xff0c;不废话&#xff0c;点赞收藏&#xff0c;用到会后好找藕~ 点击这里&#xff0c;直接看官网哦 &#x1f449; 官网地址&#…

Android 15应用适配指南:所有应用的行为变更

Android系统版本适配&#xff0c;一直是影响App上架Google Play非常重要的因素。 当前Google Play政策规定 新应用和应用更新 必须以 Android 14&#xff08;API 级别 34&#xff09;为目标平台&#xff0c;才能提交到Google Play。现有应用 必须以 Android 13&#xff08;AP…

qml TargetDirection详解

1、概述 TargetDirection是QML&#xff08;Qt Modeling Language&#xff09;中一个用于指定粒子系统中粒子移动方向的类型。它允许粒子朝向一个目标点移动&#xff0c;这个目标点可以是QML界面上的一个具体位置&#xff0c;也可以是另一个QML元素的中心。TargetDirection通常…

Linux C 使用ZBar库解析二维码和条形码

1. 编译zbar库 下载 zbar 库源码&#xff0c;这里需要注意下&#xff0c;如果识别的二维码中有中文的话&#xff0c;会出现乱码&#xff0c;一般二维码里中文为UTF-8编码&#xff0c;zbar会默认给你把UTF-8转换为ISO8859-1。有两种解决办法&#xff0c;一是自己再转换一下编码…

金融项目实战 06|Python实现接口自动化——日志、实名认证和开户接口

目录 一、日志封装及应用&#xff08;理解&#xff09; 二、认证开户接口脚本编写 1、代码编写 1️⃣api目录 2️⃣script目录 2、BeautifulSoup库 1️⃣简介及例子 2️⃣提取html数据工具封装 3、认证开户参数化 一、日志封装及应用&#xff08;理解&#xff09; &…

基于springboot+vue+微信小程序的宠物领养系统

基于springbootvue微信小程序的宠物领养系统 一、介绍 本项目利用SpringBoot、Vue和微信小程序技术&#xff0c;构建了一个宠物领养系统。 本系统的设计分为两个层面&#xff0c;分别为管理层面与用户层面&#xff0c;也就是管理者与用户&#xff0c;管理权限与用户权限是不…

【微服务】面试题 5、分布式系统理论:CAP 与 BASE 详解

分布式系统理论&#xff1a;CAP 与 BASE 详解 一、CAP 定理 背景与定义&#xff1a;1998 年由加州大学科学家埃里克布鲁尔提出&#xff0c;分布式系统存在一致性&#xff08;Consistency&#xff09;、可用性&#xff08;Availability&#xff09;、分区容错性&#xff08;Part…

【Vue】Vue组件--上

目录 一、组件基础 二、组件的嵌套关系 1. 基础架构 2. 嵌套 三、组件注册方式 1. 局部注册&#xff1a; 2. 全局注册&#xff1a; 四、组件传递数据 1. 基础架构 2. 传递多值 3. 动态传递数据 五、组件传递多种数据类型 1. Number 2. Array 3. Object 六、组…

鸿蒙UI开发——键盘弹出避让模式设置

1、概 述 我们在鸿蒙开发时&#xff0c;不免会遇到用户输入场景&#xff0c;当用户准备输入时&#xff0c;会涉及到输入法的弹出&#xff0c;我们的界面针对输入法的弹出有两种避让模式&#xff1a;上抬模式、压缩模式。 下面针对输入法的两种避让模式的设置做简单介绍。 2、…

python Streamlit和AKShare 实现的股票数据查询系统

1. 系统概述 这是一个基于Streamlit和AKShare的股票数据查询系统&#xff0c;提供了便捷的股票数据查询和可视化功能。系统支持按板块筛选股票、多股票代码查询、数据导出等功能。 1.1 主要功能 股票代码直接输入查询按板块筛选和选择股票历史数据和实时行情查询财务报表数据…

蓝桥杯备赛:顺序表和单链表相关算法题详解(上)

目录 一.询问学号&#xff08;顺序表&#xff09; 1.题目来源&#xff1a; 2.解析与代码实现&#xff1a; &#xff08;1&#xff09;解析&#xff1a; &#xff08;2&#xff09;代码实现&#xff1a; 二.寄包柜&#xff08;顺序表&#xff09; 1.题目来源&#xff1a; …