• 因项目需要,但网上一直没有找到合适的坐标转换方法,特别是js转换的,故咬咬牙,自己改写了,以备不时之需。
  • 其中js版是根据java版改的,如有问题,还请指正,目前js版亲测过百度坐标转原始坐标OK。

1、Java版:

package com.maple.util;
import java.math.BigDecimal;/*** 功能:提供坐标偏移公共类*/
public class CoordinateUtil {static double a = 6378245.0;static double ee = 0.00669342162296594323;static double pi = 3.14159265358979324;static double x_pi = 3.14159265358979324 * 3000.0 / 180.0;/*** GCJ02(国家局、高德、谷歌)转换为百度坐标** @param x* @param y* @return double[2] xy*/public static double[] bd_encrypt(double x, double y) {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[] xy = new double[2];xy[0] = new BigDecimal(z * Math.cos(theta) + 0.0065).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();xy[1] = new BigDecimal(z * Math.sin(theta) + 0.006).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();return xy;}/*** 百度坐标转换为GCJ02(国家局、高德、谷歌)** @param x* @param y* @return double[2] xy*/public static double[] bd_decrypt(double x, double y) {x = x - 0.0065;y = y - 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[] xy = new double[2];xy[0] = new BigDecimal(z * Math.cos(theta)).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();xy[1] = new BigDecimal(z * Math.sin(theta)).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();return xy;}private static double transLat(double x, double y) {double ret = -100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(x > 0 ? x : -x);ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(y * pi) + 40.0 * Math.sin(y / 3.0 * pi)) * 2.0 / 3.0;ret += (160.0 * Math.sin(y / 12.0 * pi) + 320 * Math.sin(y * pi / 30.0)) * 2.0 / 3.0;return ret;}private static double transLon(double x, double y) {double ret = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(x > 0 ? x : -x);ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(x * pi) + 40.0 * Math.sin(x / 3.0 * pi)) * 2.0 / 3.0;ret += (150.0 * Math.sin(x / 12.0 * pi) + 300.0 * Math.sin(x / 30.0 * pi)) * 2.0 / 3.0;return ret;}private static boolean outOfChina(double x, double y) {if (x < 72.004 || x > 137.8347)return true;if (y < 0.8293 || y > 55.8271)return true;return false;}/*** 原始坐标(WGS84)转换为GCJ02(国家局、高德、谷歌)** @param x* @param y* @return double[2] xy*/public static double[] WgsToGcj(double x, double y) {double[] gcjLoc = new double[2];if (outOfChina(x, y)) {gcjLoc[0] = x;gcjLoc[1] = y;return gcjLoc;}double dLat = transLat(x - 105.0, y - 35.0);double dLon = transLon(x - 105.0, y - 35.0);double radLat = y / 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);dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);gcjLoc[1] = new BigDecimal(y + dLat).setScale(14, BigDecimal.ROUND_HALF_UP).doubleValue();gcjLoc[0] = new BigDecimal(x + dLon).setScale(14, BigDecimal.ROUND_HALF_UP).doubleValue();return gcjLoc;}/*** GCJ02(国家局、高德、谷歌)转换为原始坐标(WGS84)** @param x* @param y* @return double[2] xy*/public static double[] GcjToWgs(double x, double y) {double[] wgLoc = new double[2];double wgX = x, wgY = y;double dX, dY;double[] currGcLoc = new double[2];int maxCount = 100;int count = 0;while (true) {currGcLoc = WgsToGcj(wgX, wgY);dX = x - currGcLoc[0];dY = y - currGcLoc[1];if (Math.abs(dY) < 1e-5 && Math.abs(dX) < 1e-5) {  // 1e-6 ~ centimeter level accuracy// Result of experiment://   Most of the time 2 iterations would be enough for an 1e-8 accuracy (milimeter level).//wgLoc[0] = new BigDecimal(wgX).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();wgLoc[1] = new BigDecimal(wgY).setScale(6, BigDecimal.ROUND_HALF_UP).doubleValue();break;}wgX += dX;wgY += dY;if (count > maxCount) {//超过100次计算未满足条件,返回0wgLoc[0] = 0;wgLoc[1] = 0;break;}count++;}return wgLoc;}public static double EARTH_RADIUS = 6378137;private static double rad(double d) {return d * Math.PI / 180.0;}/*** 根据两点间经纬度坐标(double值),计算两点间距离,单位为米** @param lng1* @param lat1* @param lng2* @param lat2* @return*/public static double getDistance(double lng1, double lat1, double lng2, double lat2) {double radLat1 = rad(lat1);double radLat2 = rad(lat2);double a = radLat1 - radLat2;double b = rad(lng1) - rad(lng2);double s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));s = s * EARTH_RADIUS;s = Math.round(s * 10000) / 10000;return s;}
}

2、js版:

/*** @author lyr* @date 2019/6/24* @Description: 坐标转换公共方法*/
const a = 6378245.0;
const ee = 0.00669342162296594323;
const pi = 3.14159265358979324;
const x_pi = 3.14159265358979324 * 3000.0 / 180.0;
const EARTH_RADIUS = 6378137;/*** GCJ02(国家局、高德、谷歌)转换为百度坐标*/
export function bd_encrypt(x,y) {let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi);let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi);let xy = [];xy[0] = z * Math.cos(theta) + 0.0065;xy[1] = z * Math.sin(theta) + 0.006;return xy;
}/*** 百度坐标转换为GCJ02(国家局、高德、谷歌)*/
export function bd_decrypt(x,y) {x = x - 0.0065;y = y - 0.006;let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);let xy = [];xy[0] = z * Math.cos(theta);xy[1] = z * Math.sin(theta);return xy;
}/*** GCJ02(国家局、高德、谷歌)转换为原始坐标(WGS84)*/
export function GcjToWgs(x,y) {let wgLoc = [];let wgX = x, wgY = y;let dX, dY;let currGcLoc = [];let maxCount = 100;let count = 0;while (true) {currGcLoc = WgsToGcj(wgX, wgY);dX = x - currGcLoc[0];dY = y - currGcLoc[1];if (Math.abs(dY) < 1e-5 && Math.abs(dX) < 1e-5) {  // 1e-6 ~ centimeter level accuracywgLoc[0] = wgX;wgLoc[1] = wgY;break;}wgX += dX;wgY += dY;if (count > maxCount) {//超过100次计算未满足条件,返回0wgLoc[0] = 0;wgLoc[1] = 0;break;}count++;}return wgLoc;
}/*** 原始坐标(WGS84)转换为GCJ02(国家局、高德、谷歌)*/
export function WgsToGcj(x,y) {let gcjLoc = [];if (outOfChina(x, y)) {gcjLoc[0] = x;gcjLoc[1] = y;return gcjLoc;}let dLat = transLat(x - 105.0, y - 35.0);let dLon = transLon(x - 105.0, y - 35.0);let radLat = y / 180.0 * pi;let magic = Math.sin(radLat);magic = 1 - ee * magic * magic;let sqrtMagic = Math.sqrt(magic);dLat = (dLat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * pi);dLon = (dLon * 180.0) / (a / sqrtMagic * Math.cos(radLat) * pi);gcjLoc[1] = y + dLat;gcjLoc[0] = x + dLon;return gcjLoc;
}export function transLat(x,y) {let ret = -100.0 + 2.0 * x + 3.0 * y + 0.2 * y * y + 0.1 * x * y + 0.2 * Math.sqrt(x > 0 ? x : -x);ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(y * pi) + 40.0 * Math.sin(y / 3.0 * pi)) * 2.0 / 3.0;ret += (160.0 * Math.sin(y / 12.0 * pi) + 320 * Math.sin(y * pi / 30.0)) * 2.0 / 3.0;return ret;
}export function transLon(x,y) {let ret = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(x > 0 ? x : -x);ret += (20.0 * Math.sin(6.0 * x * pi) + 20.0 * Math.sin(2.0 * x * pi)) * 2.0 / 3.0;ret += (20.0 * Math.sin(x * pi) + 40.0 * Math.sin(x / 3.0 * pi)) * 2.0 / 3.0;ret += (150.0 * Math.sin(x / 12.0 * pi) + 300.0 * Math.sin(x / 30.0 * pi)) * 2.0 / 3.0;return ret;
}export function outOfChina(x,y) {if (x < 72.004 || x > 137.8347)return true;if (y < 0.8293 || y > 55.8271)return true;return false;
}export function rad(d) {return d * Math.PI / 180.0;
}/*** 根据两点间经纬度坐标(double值),计算两点间距离,单位为米*/
export function getDistance(lng1,lat1,lng2,lat2) {let radLat1 = rad(lat1);let radLat2 = rad(lat2);let a = radLat1 - radLat2;let b = rad(lng1) - rad(lng2);let s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) +Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)));s = s * EARTH_RADIUS;s = Math.round(s * 10000) / 10000;return s;
}

3、npm方式

安装:
npm install coordtransform
使用:
let coordtransform=require('coordtransform');
//国测局坐标(火星坐标,比如高德地图在用),百度坐标,wgs84坐标(谷歌国外以及绝大部分国外在线地图使用的坐标)
//百度经纬度坐标转国测局坐标
var bd09togcj02 = coordtransform.bd09togcj02(116.404, 39.915);
//国测局坐标转百度经纬度坐标
var gcj02tobd09 = coordtransform.gcj02tobd09(116.404, 39.915);
//wgs84转国测局坐标
var wgs84togcj02 = coordtransform.wgs84togcj02(116.404, 39.915);
//国测局坐标转wgs84坐标
var gcj02towgs84 = coordtransform.gcj02towgs84(116.404, 39.915);
console.log(bd09togcj02);
console.log(gcj02tobd09);
console.log(wgs84togcj02);
console.log(gcj02towgs84);
//result
//bd09togcj02:   [ 116.39762729119315, 39.90865673957631 ]
//gcj02tobd09:   [ 116.41036949371029, 39.92133699351021 ]
//wgs84togcj02:  [ 116.41024449916938, 39.91640428150164 ]
//gcj02towgs84:  [ 116.39775550083061, 39.91359571849836 ]

各种坐标之间的转换方法汇总相关推荐

  1. gps两点距离 php,PHP应用:PHP计算百度地图两个GPS坐标之间距离的方法

    <PHP应用:PHP计算百度地图两个GPS坐标之间距离的方法>要点: 本文介绍了PHP应用:PHP计算百度地图两个GPS坐标之间距离的方法,希望对您有用.如果有疑问,可以联系我们. 本文实 ...

  2. java代码中fastjson生成字符串和解析字符串的方法和javascript文件中字符串和json数组之间的转换方法...

    1.java代码中fastjson生成字符串和解析字符串的方法 List<TemplateFull> templateFulls = new ArrayList<TemplateFu ...

  3. oracle如何计算2个坐标的距离,百度地图两个坐标之间的距离计算

    /** * 计算两组经纬度坐标 之间的距离 * params :lat1 纬度1: lng1 经度1: lat2 纬度2: lng2 经度2: len_type (1:m or 2:km); * re ...

  4. U3D屏幕坐标,世界坐标,像素坐标之间的关系

    U3D屏幕坐标,世界坐标,像素坐标之间的关系 U3D中,屏幕坐标和世界坐标单位一样,二者之间是直接的一一对应关系,不受屏幕分辨率影响.默认情况下屏幕空间画布的左下角坐标是世界原点(0,0,0),这种情 ...

  5. php 地图 距离,PHP计算百度地图两个GPS坐标之间距离的方法

    这篇文章主要介绍了PHP计算百度地图两个GPS坐标之间距离的方法,是针对百度地图接口开发的典型应用,需要的朋友可以参考下 本文实例讲述了PHP计算百度地图两个GPS坐标之间距离的方法.分享给大家供大家 ...

  6. python fromhex_Python hexstring-list-str之间的转换方法

    在Python操作数据内容时,多数情况下可能遇到下面3种类型的数据处理: hexstring 如:'1C532145697A8B6F' str 如:'\x1C\x53\x21\x45\x69\x7A\ ...

  7. [转载] python hex转字符串_Python hexstring-list-str之间的转换方法

    参考链接: Python hex() 在Python操作数据内容时,多数情况下可能遇到下面3种类型的数据处理: hexstring 如:'1C532145697A8B6F' str 如:'\x1C\x ...

  8. python汉字转到ascii码_python中ASCII码字符与int之间的转换方法

    ASCII码转换为int:ord('A') 65 int转为ASCII码:chr(65) 'A' 题目内容: 实现一个凯撒密码的变种算法,对输入字符串进行加解密处理 把字母a-z分别循环对应为相距13 ...

  9. linux音频文件格式转换,Linux下常见音频格式之间的转换方法

    下面简单介绍下Linux环境常见音频格式之间的转换方法: MP3 相关工具: lame OGG 相关工具: vorbis-tools APE 相关工具: mac FLAC 相关工具: flac WAV ...

  10. 经纬度和坐标之间怎么相互转换

    经纬度和坐标之间的相互转换 经纬度转坐标 代码 坐标转经纬度 经纬度转坐标 经纬度(Latitude and Longitude)和坐标(Cartesian coordinate system)之间的 ...

最新文章

  1. java -d32_java11教程--JDK 10删除和不推荐的功能和选项-2
  2. c语言 unlink,unlink 漏洞笔记
  3. 2019年陕西高考分数线出炉
  4. 算法练习5---快速排序Java版
  5. Java 8 - Interface Default Method接口默认方法
  6. 中国电子计算机大学竞赛安徽分赛,我院学子喜获第十二届全国大学生数学竞赛安徽赛区15项一等奖...
  7. 五一小长假|不得不说的一些话
  8. commons-fileupload的ServletFileUpload类
  9. 任意切换线程的工具类
  10. 干货 | 一文掌握常用的机器学习模型
  11. 洛克菲勒的38封信pdf下载_洛克菲勒写给儿子的38封信:要有竞争的决心
  12. 计算机开机自检时,电脑开机启动时出现DHCP自检怎么办
  13. [sphinx]中文语言模型训练
  14. 淘淘商城---8.9
  15. 天池大赛——天猫用户复购预测
  16. JavaScript大体学习思路
  17. 洧 誰 理 夲 亾 と 杺
  18. Blender 建模风扇(UV贴图、图像纹理、环境纹理、伽玛、Cycles渲染)
  19. 夜游项目如何促进文旅经济的发展
  20. error C2065: “IDD_DIALOG1”: 未声明的标识符 .

热门文章

  1. 支付宝小程序获取用户手机号php,小程序登录、获取用户信息、手机号
  2. VPS搭建HTTP代理
  3. 我们在电脑房里上计算机课英语,英语复习1
  4. 实现 API 调用接口
  5. 计算机术语中 1gb等于 mb.,GB、MB、KB分别是什么意思,大小分别是多少?
  6. Windows10开启虚拟化
  7. java对接PayPal支付 (添加物流跟踪信息)
  8. SuperMap 三维模型数据制作
  9. DB2 执行SQL报错: DB2 SQL Error: SQLCODE=-1585, SQLSTATE=54048
  10. 企业级数据服务总线规划