当前位置: 首页 > news >正文

经纬度坐标工具

LngLatUtil :用于计算里程数


import cn.hutool.core.util.ArrayUtil;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import lombok.Getter;
import lombok.Setter;import java.io.FileInputStream;
import java.io.Serializable;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Objects;public class LngLatUtil {/*** 地球半径,m*/public static final double EARTH_RADIUS = 6371393d;/*** 偏离参考弧度大小*/public static final double OFFSET_RADIANS = Math.PI * 0.25d;public static double getRand(double min, double max) {double v = Math.random() * (max - min) + min;DecimalFormat df = new DecimalFormat("#0.00");return Double.parseDouble(df.format(v));}public static double getOffset(Point p1, Point p2) {// 纬度之差double a = Math.toRadians(p1.lat) - Math.toRadians(p2.lat);// 经度之差double b = Math.toRadians(p1.lng) - Math.toRadians(p2.lng);// 计算两点距离的公式double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +Math.cos(p1.lat) * Math.cos(p2.lat) * Math.pow(Math.sin(b / 2), 2)));// 弧长乘地球半径, 返回单位: 米return s * EARTH_RADIUS;}public static Point offsetPoint(double lng, double lat, double offset, double radians) {Point point = new Point();if (offset > 0) {point.setLng(lng + offset * Math.sin(radians) * 180d / (Math.PI * EARTH_RADIUS * Math.cos(lat * Math.PI / 180d)));point.setLat(lat + offset * Math.cos(radians) / (Math.PI * EARTH_RADIUS / 180d));} else {point.setLng(lng);point.setLat(lng);}return point;}public static Point getNewPoint(Point samplePrev, Point sampleCur,int index) {double radians = 0d;if (Objects.nonNull(samplePrev)) {radians = getRadians(sampleCur, samplePrev);}radians = offsetRadians(radians);double offset;if(index > 0){offset = getRand(10, 50);}else{offset = getRand(150, 200);}return offsetPoint(sampleCur.lng, sampleCur.lat, offset, radians);}public static Point getNewPoint(Point prev, Point samplePrev, Point sampleCur) {double radians = 0d;if (Objects.nonNull(samplePrev)) {radians = getRadians(samplePrev, sampleCur);}radians = offsetRadians(radians);double offset = getRand(50, 100);if (Objects.isNull(prev)) {prev = sampleCur;}return offsetPoint(prev.lng, prev.lat, offset, radians);}public static double getRadians(Point p1, Point p2) {double y = Math.sin(p2.getLng() - p1.getLng()) * Math.cos(p2.getLat());double x = Math.cos(p1.getLat()) * Math.sin(p2.getLat()) - Math.sin(p1.getLat()) * Math.cos(p2.getLat()) * Math.cos(p2.getLng() - p1.getLng());return Math.atan2(y, x);}public static double offsetRadians(double radians) {double min = radians - OFFSET_RADIANS;double max = radians + OFFSET_RADIANS;return getRand(min, max);}@Getter@Setterpublic static class Point implements Serializable {private double lng;private double lat;}public static void main(String[] args) throws Exception {String path = "D:\\Desktop\\imei-data\\";FileInputStream fileInputStream = new FileInputStream(path + "4.json");byte[] bytes = new byte[1024];//每一次读取四个字节int readCount = 0;byte[] data = new byte[0];while ((readCount = fileInputStream.read(bytes)) != -1) {byte[] read = new byte[readCount];System.arraycopy(bytes, 0, read, 0, readCount);data = ArrayUtil.addAll(data, read);}String s = new String(data);List<Point> testData = JSONObject.parseArray(s, Point.class);Point samplePrev = null;List<Double[]> lines = new ArrayList<>();List<Double[]> origin = new ArrayList<>();for (int i = 0; i < testData.size(); i++) {Point sampleCur = testData.get(i);origin.add(new Double[]{sampleCur.lng, sampleCur.lat});Point p = getNewPoint(samplePrev, sampleCur, i);lines.add(new Double[]{p.lng, p.lat});samplePrev = sampleCur;}
//        System.out.println(JSON.toJSONString(origin));System.out.println();System.out.println(JSON.toJSONString(lines));}
}

CoordinateTransformUtils : 坐标转换工具 BD09 、GCJ02、WGS84


/*** 百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系之间的转换的工具** @see 参考https://github.com/wandergis/coordtransform实现的Java版本* @author geosmart*/
public class CoordinateTransformUtils {static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;// πstatic double pi = 3.1415926535897932384626;// 长半轴static double a = 6378245.0;// 扁率static double ee = 0.00669342162296594323;/*** 百度坐标系(BD-09)转WGS坐标** @param lng 百度坐标纬度* @param lat 百度坐标经度* @return WGS84坐标数组*/public static double[] bd09towgs84(double lng, double lat) {double[] gcj = bd09togcj02(lng, lat);double[] wgs84 = gcj02towgs84(gcj[0], gcj[1]);return wgs84;}/*** WGS坐标转百度坐标系(BD-09)** @param lng WGS84坐标系的经度* @param lat WGS84坐标系的纬度* @return 百度坐标数组*/public static double[] wgs84tobd09(double lng, double lat) {double[] gcj = wgs84togcj02(lng, lat);double[] bd09 = gcj02tobd09(gcj[0], gcj[1]);return bd09;}/*** 火星坐标系(GCJ-02)转百度坐标系(BD-09)* 谷歌、高德——>百度** @param lng 火星坐标经度* @param lat 火星坐标纬度* @return 百度坐标数组*/public static double[] gcj02tobd09(double lng, double lat) {double z = Math.sqrt(lng * lng + lat * lat) + 0.00002 * Math.sin(lat * x_pi);double theta = Math.atan2(lat, lng) + 0.000003 * Math.cos(lng * x_pi);double bd_lng = z * Math.cos(theta) + 0.0065;double bd_lat = z * Math.sin(theta) + 0.006;return new double[]{bd_lng, bd_lat};}/*** 百度坐标系(BD-09)转火星坐标系(GCJ-02)* 百度——>谷歌、高德** @param bd_lon 百度坐标纬度* @param bd_lat 百度坐标经度* @return 火星坐标数组*/public static double[] bd09togcj02(double bd_lon, double bd_lat) {double x = bd_lon - 0.0065;double y = bd_lat - 0.006;double z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);double theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);double gg_lng = z * Math.cos(theta);double gg_lat = z * Math.sin(theta);return new double[]{gg_lng, gg_lat};}/*** WGS84转GCJ02(火星坐标系)** @param lng WGS84坐标系的经度* @param lat WGS84坐标系的纬度* @return 火星坐标数组*/public static double[] wgs84togcj02(double lng, double lat) {if (out_of_china(lng, lat)) {return new double[]{lng, lat};}double dlat = transformlat(lng - 105.0, lat - 35.0);double dlng = transformlng(lng - 105.0, lat - 35.0);double radlat = lat / 180.0 * pi;double magic = Math.sin(radlat);magic = 1 - ee * magic * magic;double sqrtmagic = Math.sqrt(magic);dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi);dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * pi);double mglat = lat + dlat;double mglng = lng + dlng;return new double[]{mglng, mglat};}/*** GCJ02(火星坐标系)转GPS84** @param lng 火星坐标系的经度* @param lat 火星坐标系纬度* @return WGS84坐标数组*/public static double[] gcj02towgs84(double lng, double lat) {if (out_of_china(lng, lat)) {return new double[]{lng, lat};}double dlat = transformlat(lng - 105.0, lat - 35.0);double dlng = transformlng(lng - 105.0, lat - 35.0);double radlat = lat / 180.0 * pi;double magic = Math.sin(radlat);magic = 1 - ee * magic * magic;double sqrtmagic = Math.sqrt(magic);dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi);dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * pi);double mglat = lat + dlat;double mglng = lng + dlng;return new double[]{lng * 2 - mglng, lat * 2 - mglat};}/*** 纬度转换** @param lng* @param lat* @return*/public static double transformlat(double lng, double lat) {double ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * Math.sqrt(Math.abs(lng));ret += (20.0 * Math.sin(6.0 * lng * pi) + 20.0 * Math.sin(2.0 * lng * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(lat * pi) + 40.0 * Math.sin(lat / 3.0 * pi)) * 2.0 / 3.0;ret += (160.0 * Math.sin(lat / 12.0 * pi) + 320 * Math.sin(lat * pi / 30.0)) * 2.0 / 3.0;return ret;}/*** 经度转换** @param lng* @param lat* @return*/public static double transformlng(double lng, double lat) {double ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * Math.sqrt(Math.abs(lng));ret += (20.0 * Math.sin(6.0 * lng * pi) + 20.0 * Math.sin(2.0 * lng * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(lng * pi) + 40.0 * Math.sin(lng / 3.0 * pi)) * 2.0 / 3.0;ret += (150.0 * Math.sin(lng / 12.0 * pi) + 300.0 * Math.sin(lng / 30.0 * pi)) * 2.0 / 3.0;return ret;}/*** 判断是否在国内,不在国内不做偏移** @param lng* @param lat* @return*/public static boolean out_of_china(double lng, double lat) {if (lng < 72.004 || lng > 137.8347) {return true;} else if (lat < 0.8293 || lat > 55.8271) {return true;}return false;}
}

相关文章:

经纬度坐标工具

LngLatUtil :用于计算里程数 import cn.hutool.core.util.ArrayUtil; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import lombok.Getter; import lombok.Setter;import java.io.FileInputStream; import java.io.Serializable; import java.t…...

如何使用伪元素::before和::after?

伪元素(::before和::after)是CSS中非常有用的特性&#xff0c;它们允许你在元素的内容之前或之后插入额外的内容&#xff0c;并且不需要在HTML结构中添加额外的标记。这样可以方便地在页面上添加装饰性元素、图标、或者样式效果。以下是使用伪元素的基本方法&#xff1a; 1、创…...

Visual Studio Code中对打开的脚本格式统一

什么是Language Server Protocol (LSP)? Language Server Protocol&#xff08;语言服务器协议&#xff0c;简称LSP&#xff09;是微软在2016年提出的一套统一的通讯协议方案。LSP定义了一套编辑器或者IDE与语言服务器&#xff08;Language Server&#xff09;之间使用的协议&…...

补充JDK源码-IDEA集成工具

在阅读JDK8源码的时候发现&#xff0c;只有一小部分常用包是存在源码及其注释的&#xff0c;而很多内部包是没有源码&#xff0c;class文件在阅读的时候对阅读者十分不友好。在网上搜集了很多资料都没有解决问题。 解决问题办法&#xff1a;参考文档。本文主要是根据这篇文章记…...

Git Submodule 更新子库失败 fatal: Unable to fetch in submodule path

编辑本地目录 .git/config 文件 在 [submodule “Assets/CommonModule”] 项下 加入 fetch refs/heads/:refs/remotes/origin/...

Springboot切面打印日志

切面打印完整日志,以下代码用于扫描RestController 注解修饰的接口,并打印相关日志 import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; impor…...

ubuntu上回环设备/dev/loop0占用100%清理

查看磁盘占用情况时&#xff1a; df -h/dev/loopn这些设备在Linux下被称为回环设备。 终端输入&#xff1a; sudo apt autoremove --purge snapd再次查看&#xff1a;...

List list=new ArrayList()抛出的ArrayIndexOutOfBoundsException异常

1.应用场景&#xff0c;今天生产日志监控到一下ArrayList 进行add 异常&#xff0c;具体日志如下&#xff1a; eptionHandler.handler(178): TXXYBUSSINESS|执行异常 java.util.concurrent.CompletionException: java.lang.ArrayIndexOutOfBoundsException: Index 1 out of bo…...

桶排序算法

桶排序算法 算法思想概述&#xff1a;桶排序的主要步骤如下&#xff1a; 算法goland实现&#xff1a;图解演示&#xff1a; 算法思想概述&#xff1a; 桶排序&#xff08;Bucket Sort&#xff09;是一种非比较性的排序算法&#xff0c;它将待排序的元素分到有限数量的桶&#…...

P8604 [蓝桥杯 2013 国 C] 危险系数

题目背景 抗日战争时期&#xff0c;冀中平原的地道战曾发挥重要作用。 题目描述 地道的多个站点间有通道连接&#xff0c;形成了庞大的网络。但也有隐患&#xff0c;当敌人发现了某个站点后&#xff0c;其它站点间可能因此会失去联系。 我们来定义一个危险系数 DF(x,y)&…...

Excel·VBA表格横向、纵向相互转换

如图&#xff1a;对图中区域 A1:M6 横向表格&#xff0c;转换成区域 A1:C20 纵向表格&#xff0c;即 B:M 列转换成每2列一组按行写入&#xff0c;并删除空行。同理&#xff0c;反向操作就是纵向表格转换成横向表格 目录 横向转纵向实现方法1转换结果 实现方法2转换结果 纵向转横…...

Leetcode-每日一题【剑指 Offer 06. 从尾到头打印链表】

题目 输入一个链表的头节点&#xff0c;从尾到头反过来返回每个节点的值&#xff08;用数组返回&#xff09;。 示例 1&#xff1a; 输入&#xff1a;head [1,3,2]输出&#xff1a;[2,3,1] 限制&#xff1a; 0 < 链表长度 < 10000 解题思路 1.题目要求我们从尾到头反过…...

LeetCode--HOT100题(22)

目录 题目描述&#xff1a;160. 相交链表&#xff08;简单&#xff09;题目接口解题思路代码 PS: 题目描述&#xff1a;160. 相交链表&#xff08;简单&#xff09; 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表…...

产品体系架构202308版

1.前言 当我们不断向前奔跑时&#xff0c;需要回头压实走过的路。不断扩张的同时把相应的内容沉淀下来&#xff0c;为后续的发展铺垫基石。 不知从何时起&#xff0c;产品的架构就面向了微服务/中台化/前后端分离/低代码化/分布式/智能化/运行可观测化的综合体&#xff0c;让…...

Linux systemctl 简单介绍与使用

在Linux下&#xff0c;systemctl是一个管理系统服务的命令。它提供了对systemd服务的控制和管理。 在系统中使用systemctl命令&#xff0c;您可以执行以下操作&#xff1a; 启动服务&#xff1a;systemctl start servicename停止服务&#xff1a;systemctl stop servicename重…...

恺英网络宣布:与华为鸿蒙系统展开合作,将开发多款手游

8月5日消息&#xff0c;恺英网络宣布旗下子公司盛和网络参加了华为开发者大会&#xff08;HDC.Together&#xff09;游戏服务论坛&#xff0c;并在华为鸿蒙生态游戏先锋合作启动仪式上进行了亮相。恺英网络表示&#xff0c;将逐步在HarmonyOS上开发多款游戏&#xff0c;利用Har…...

Vue CORS

使用Vue框架报错&#xff0c;客户端浏览器有CORS错误&#xff0c;怎么解决&#xff1f; 参考API Proxying During Development&#xff0c;可以新增或修改config/index.js下的proxyTable属性。 留意到 proxyTable的key值为/api&#xff0c;代表所有服务端域名都改成以/api开头…...

Godot 4 源码分析 - 文件读入编码处理

今天需要读入xml文件进行处理&#xff0c;结果读入一个带中文的文件时&#xff0c;出错了。当然程序还能运行&#xff0c;但编译器一直报错&#xff0c;而且XML解析也不正确 单步调试发现读入的内容出现乱码&#xff0c;具体逻辑&#xff1a; String FileAccess::get_as_text…...

Linux 中使用 verdaccio 搭建私有npm 服务器

安装 Node Linux中安装Node 安装verdaccio npm i -g verdaccio安装完成 输入verdaccio,出现下面信息代表安装成功&#xff0c;同时输入verdaccio后verdaccio已经处于运行状态&#xff0c;当然这种启动时暂时的&#xff0c;我们需要通过pm2让verdaccio服务常驻 ygiZ2zec61wsg…...

C++入门之stl六大组件--stack和queue源码深度剖析及模拟实现

目录 前言 一、stack的介绍和使用 1.stack的介绍 2.stack的使用 3.stack的模拟实现 二、queue的介绍和使用 1.queue的介绍 2.queue的使用 3.queue的模拟实现 三、priority_queue的介绍和使用 1.priority_queue的介绍 2.priority_queue的使用 3.priority_queue的模…...

知新研学 |AlignMamba:AlignMamba:通过局部和全局跨模态对齐增强多模态 Mamba 技术

导言 多模态表示融合是整合和理解不同模态&#xff08;如音频、视频、语言&#xff09;信息的关键技术&#xff0c;对视觉语言理解和音视频分析等应用至关重要。然而&#xff0c;实现有效的跨模态融合面临两大挑战&#xff1a;一是传统的Transformer架构虽然能捕捉动态交互&am…...

C#并行编程进阶:除了Task和Parallel,你还需要学会用PerformanceCounter做资源熔断

C#并行编程中的资源熔断机制&#xff1a;用PerformanceCounter构建自适应系统 当你在深夜部署一个高负载数据处理服务时&#xff0c;最可怕的不是代码报错——而是系统在默默崩溃。我曾经历过这样的时刻&#xff1a;一个看似完美的并行处理管道&#xff0c;在凌晨三点突然吞噬了…...

Linux 文件系统深度解析:ext4、XFS、inode、硬链接 vs 软链接 原理与实战

前言&#xff1a;为什么要深入理解文件系统&#xff1f; 在 Linux 系统中&#xff0c;文件系统是连接用户数据与物理存储介质的桥梁。每一行代码、每一张图片、每一条日志最终都会被文件系统转化为磁盘上数以亿计的比特位。然而&#xff0c;大多数开发者对文件系统的认知停留在…...

Autoware Docker部署实战:从环境配置到镜像拉取全解析

1. Autoware与Docker环境部署概述 自动驾驶开发环境搭建一直是让开发者头疼的问题&#xff0c;尤其是像Autoware这样的大型开源框架。传统本地安装方式需要处理大量依赖关系&#xff0c;稍有不慎就会陷入"依赖地狱"。而Docker容器化部署正好能解决这个痛点——它把整…...

如何用ControlNet-Union-SDXL-1.0实现多条件图像生成?解锁12种创意控制方案

如何用ControlNet-Union-SDXL-1.0实现多条件图像生成&#xff1f;解锁12种创意控制方案 【免费下载链接】controlnet-union-sdxl-1.0 项目地址: https://ai.gitcode.com/hf_mirrors/xinsir/controlnet-union-sdxl-1.0 ControlNet-Union-SDXL-1.0是一款革命性的多条件控…...

PCIE差分对走线设计的关键规范与实战技巧

1. PCIE差分对走线设计的核心规范 PCIE&#xff08;Peripheral Component Interconnect Express&#xff09;作为当前主流的高速串行总线标准&#xff0c;其差分对走线设计直接决定了信号完整性和系统稳定性。在实际项目中&#xff0c;我遇到过不少因为差分对设计不当导致的信号…...

2026大模型训练全景,从底座到上线,决定AI体验的完整链路

在人工智能飞速发展的2026年&#xff0c;大众对大模型的认知早已不再停留在“参数越大越强”的简单层面。我们日常使用AI助手时感受到的流畅对话、精准指令响应、高效工具调用&#xff0c;甚至稳定可靠的输出风格&#xff0c;背后都不是单一的预训练环节在支撑&#xff0c;而是…...

Windows下OpenClaw安装教程:一键部署Kimi-VL-A3B-Thinking镜像

Windows下OpenClaw安装教程&#xff1a;一键部署Kimi-VL-A3B-Thinking镜像 1. 为什么选择OpenClawKimi-VL组合 上周我在整理电脑上的图片素材时&#xff0c;突然冒出一个想法&#xff1a;如果能有个AI助手帮我自动分类这些图片&#xff0c;还能根据内容生成描述文字该多好。经…...

保姆级教程:用cam_lidar_calibration搞定激光雷达与相机标定(附避坑指南)

从零实现激光雷达与相机高精度标定&#xff1a;cam_lidar_calibration实战全解析 当激光雷达的点云遇上相机的像素&#xff0c;如何让它们"说同一种语言"&#xff1f;传感器标定就像给两个陌生人做翻译&#xff0c;而外参标定决定了翻译的准确性。今天我们要拆解的ca…...

Tesseract安装遇阻:Download error与Send Request Error的终极解决方案#附语言包下载

1. 遇到Tesseract安装错误的真实场景 上周帮同事配置OCR开发环境时&#xff0c;又遇到了熟悉的红色错误弹窗&#xff1a;"Download error Status of equ: Send Request Error"。这个报错我见过太多次了——无论是三年前第一次用Tesseract&#xff0c;还是后来在不同公…...