安卓/java后台使用测量方法

2024-09-04 12:58

本文主要是介绍安卓/java后台使用测量方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题来源

在JS上很难进行全面而细致的交集运算,所以转到后台执行。同时JTS是优秀的拓扑运算开源组件,故本文使用JTS作为工具,而出于安卓考虑,使用了低版本的JTS。(jts-1.13.jar)

后台的方法

核心就是WKTReader的读取,以及各类Geometry的应用。
/*** 获取中心点* @param wkt 熟知文本* @return [x,y]* @throws ParseException*/public static double[] getCentroid(String wkt) throws ParseException{WKTReader reader = new WKTReader();double[] result = new double[2];Geometry geom = reader.read(wkt);Point centroid = geom.getCentroid();if(!centroid.isEmpty() && centroid.isValid()){result[0] = centroid.getX();result[1] = centroid.getY();}else{throw new IllegalArgumentException("没有有效的中心点");}return result;}/*** 求交集* @param wkt 熟知文本* @param polys 内部集* @throws ParseException */public static String getPolyWithInteraction(String wkt, String[] polys) throws ParseException{GeometryFactory gf = new GeometryFactory();GeometryTransformer gt = new GeometryTransformer();WKTReader reader = new WKTReader();Geometry geom = reader.read(wkt);String type = geom.getGeometryType();if("Polygon".equals(type)){Polygon polygon = (Polygon)geom;int num_rings = polys.length;List<LinearRing> holes = new ArrayList<LinearRing>();for(int i=0;i<num_rings;i++){Polygon interaction = (Polygon)polygon.intersection(reader.read(polys[i]));holes.add((LinearRing)gt.transform(interaction.getExteriorRing()));}Polygon final_geom = gf.createPolygon((LinearRing)polygon.getExteriorRing(), holes.toArray(new LinearRing[num_rings]));return final_geom.toText();}return null;}/*** 计算距离特定点的距离* @param centerX    中心点 经度* @param centerY	 中心点 纬度* @param locationX	  当前经度* @param locationY	  当前纬度* @return*/private static double getDistance(double[] centre,double locationX,double locationY){double centreX = centre[0];double centreY = centre[1];int r =  6362790;double x1 = centreX   * Math.PI/180;double x2 = locationX * Math.PI/180;double y1 = centreY   * Math.PI/180;double y2 = locationY * Math.PI/180;double dx = Math.abs(x1-x2);/*double dy = Math.abs(y1-y2);*/double temp = Math.cos(y1) * Math.cos(y2) * Math.cos(dx) + Math.sin( y1 ) * Math.sin(y2);return r *Math.acos(temp);}


这篇关于安卓/java后台使用测量方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot启动报错的11个高频问题排查与解决终极指南

《SpringBoot启动报错的11个高频问题排查与解决终极指南》这篇文章主要为大家详细介绍了SpringBoot启动报错的11个高频问题的排查与解决,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一... 目录1. 依赖冲突:NoSuchMethodError 的终极解法2. Bean注入失败:No qu

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

使用Java实现通用树形结构构建工具类

《使用Java实现通用树形结构构建工具类》这篇文章主要为大家详细介绍了如何使用Java实现通用树形结构构建工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录完整代码一、设计思想与核心功能二、核心实现原理1. 数据结构准备阶段2. 循环依赖检测算法3. 树形结构构建4. 搜索子

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

springboot报错Invalid bound statement (not found)的解决

《springboot报错Invalidboundstatement(notfound)的解决》本文主要介绍了springboot报错Invalidboundstatement(not... 目录一. 问题描述二.解决问题三. 添加配置项 四.其他的解决方案4.1 Mapper 接口与 XML 文件不匹配

GORM中Model和Table的区别及使用

《GORM中Model和Table的区别及使用》Model和Table是两种与数据库表交互的核心方法,但它们的用途和行为存在著差异,本文主要介绍了GORM中Model和Table的区别及使用,具有一... 目录1. Model 的作用与特点1.1 核心用途1.2 行为特点1.3 示例China编程代码2. Tab

MySQL新增字段后Java实体未更新的潜在问题与解决方案

《MySQL新增字段后Java实体未更新的潜在问题与解决方案》在Java+MySQL的开发中,我们通常使用ORM框架来映射数据库表与Java对象,但有时候,数据库表结构变更(如新增字段)后,开发人员可... 目录引言1. 问题背景:数据库与 Java 实体不同步1.1 常见场景1.2 示例代码2. 不同操作

SpringBoot使用OkHttp完成高效网络请求详解

《SpringBoot使用OkHttp完成高效网络请求详解》OkHttp是一个高效的HTTP客户端,支持同步和异步请求,且具备自动处理cookie、缓存和连接池等高级功能,下面我们来看看SpringB... 目录一、OkHttp 简介二、在 Spring Boot 中集成 OkHttp三、封装 OkHttp

JavaScript错误处理避坑指南

《JavaScript错误处理避坑指南》JavaScript错误处理是编程过程中不可避免的部分,它涉及到识别、捕获和响应代码运行时可能出现的问题,本文将详细给大家介绍一下JavaScript错误处理的... 目录一、错误类型:三大“杀手”与应对策略1. 语法错误(SyntaxError)2. 运行时错误(R

使用Python实现获取网页指定内容

《使用Python实现获取网页指定内容》在当今互联网时代,网页数据抓取是一项非常重要的技能,本文将带你从零开始学习如何使用Python获取网页中的指定内容,希望对大家有所帮助... 目录引言1. 网页抓取的基本概念2. python中的网页抓取库3. 安装必要的库4. 发送HTTP请求并获取网页内容5. 解