gps84转换gcj02公式_百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系之间的转换...

//定义一些常量

var x_PI = 3.14159265358979324 * 3000.0 / 180.0;

var PI = 3.1415926535897932384626;

var a = 6378245.0;

var ee = 0.00669342162296594323;

/**

* 百度坐标系 (BD-09) 与 火星坐标系 (GCJ-02)的转换

* 即 百度 转 谷歌、高德

* @param bd_lon

* @param bd_lat

* @returns {*[]}

*/

function bd09togcj02(bd_lon, bd_lat) {

var x_pi = 3.14159265358979324 * 3000.0 / 180.0;

var x = bd_lon - 0.0065;

var y = bd_lat - 0.006;

var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * x_pi);

var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);

var gg_lng = z * Math.cos(theta);

var gg_lat = z * Math.sin(theta);

return [gg_lng, gg_lat]

}

/**

* 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换

* 即谷歌、高德 转 百度

* @param lng

* @param lat

* @returns {*[]}

*/

function gcj02tobd09(lng, lat) {

var z = Math.sqrt(lng * lng + lat * lat) + 0.00002 * Math.sin(lat * x_PI);

var theta = Math.atan2(lat, lng) + 0.000003 * Math.cos(lng * x_PI);

var bd_lng = z * Math.cos(theta) + 0.0065;

var bd_lat = z * Math.sin(theta) + 0.006;

return [bd_lng, bd_lat]

}

/**

* WGS84转GCj02

* @param lng

* @param lat

* @returns {*[]}

*/

function wgs84togcj02(lng, lat) {

if (out_of_china(lng, lat)) {

return [lng, lat]

}

else {

var dlat = transformlat(lng - 105.0, lat - 35.0);

var dlng = transformlng(lng - 105.0, lat - 35.0);

var radlat = lat / 180.0 * PI;

var magic = Math.sin(radlat);

magic = 1 - ee * magic * magic;

var sqrtmagic = Math.sqrt(magic);

dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * PI);

dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * PI);

var mglat = lat + dlat;

var mglng = lng + dlng;

return [mglng, mglat]

}

}

/**

* GCJ02 转换为 WGS84

* @param lng

* @param lat

* @returns {*[]}

*/

function gcj02towgs84(lng, lat) {

if (out_of_china(lng, lat)) {

return [lng, lat]

}

else {

var dlat = transformlat(lng - 105.0, lat - 35.0);

var dlng = transformlng(lng - 105.0, lat - 35.0);

var radlat = lat / 180.0 * PI;

var magic = Math.sin(radlat);

magic = 1 - ee * magic * magic;

var sqrtmagic = Math.sqrt(magic);

dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * PI);

dlng = (dlng * 180.0) / (a / sqrtmagic * Math.cos(radlat) * PI);

mglat = lat + dlat;

mglng = lng + dlng;

return [lng * 2 - mglng, lat * 2 - mglat]

}

}

function transformlat(lng, lat) {

var 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

}

function transformlng(lng, lat) {

var 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

* @returns {boolean}

*/

function out_of_china(lng, lat) {

return (lng < 72.004 || lng > 137.8347) || ((lat < 0.8293 || lat > 55.8271) || false);

}

//使用示例

//gps坐标转火星坐标

var lng_lat_1 = wgs84togcj02(113.912743,22.497629);

console.log('火星坐标...',lng_lat_1);

//火星坐标转百度坐标

var lng_lat_2 = gcj02tobd09(lng_lat_1[0], lng_lat_1[1]);

console.log('百度坐标...',lng_lat_2);

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javascript 15位和18位身份证的正则表达式及其验证

1、简单的正则表达式&#xff1a; &#xff08;1&#xff09;preg_match("/^(\d{18,18}|\d{15,15}|\d{17,17}x)$/",$id_card)&#xff08;2&#xff09;preg_match("/^(\d{6})(18|19|20)?(\d{2})([01]\d)([0123]\d)(\d{3}) (\d|X)?$/",$id_card)&#x…

EasyUI_datagrid

案例一丶jquery.easyui.min.js:10631 Uncaught TypeError: this.renderEmptyRow is not a function 解决方法&#xff1a;datagrid记录为空就会报错。是easyui里没处理return 空的方法。需要进行添加一些东西。具体我也不清楚&#xff0c; 案例二丶清除datagrid右侧空白区域 查…

三枚硬币自制收音机

大家好&#xff0c;我是记得诚。我们称这个收音机为三个硬币收音机是因为我们使用了三个硬币作为锚点&#xff0c;连接收音机各个部件&#xff0c;这将使我们的制作过程变得极为简单。在这个收音机中我们使用了一个特殊的10晶体管集成电路&#xff0c;使最后做出的收音机效果非…

clickhouse 增量更新_ClickHouse王炸功能即将来袭?

众所周知&#xff0c;MySQL 的用户群体很大&#xff0c;为了能够增强数据的实时性&#xff0c;很多解决方案会利用 binlog 将数据写入到 ClickHouse。为了能够监听 binlog 事件&#xff0c;我们需要用到类似 canal 这样的第三方中间件&#xff0c;这无疑增加了系统的复杂度。在…

在批处理文件中启动MediaPlayer播放制定文件

我们知道在运行可以使用wmplayer指令来启动一个MediaPlayer&#xff0c;如果需要让MediaPlayer播放制定的文件或是一个制定的流媒体发布点&#xff0c;我们可以使用如下的命令格式wmplayer “mms://WIN-FW.MiGu.com/12530″wmplayer “C:\wmpub\wmroot\legacy_content_clip.wmv…

双重检查锁实现单例模式的线程安全问题

一、结论 双重校验锁的单例模式代码如下&#xff1a; public class Singleton {   private static Singleton singleton; private Singleton() {} public static Singleton getSingleton() {     if (singleton null) { // 1       synchronized (Singleton.clas…

摇杆控制方向原理_为工业安全守好”门”!各种方向的控制阀原理图大集合

单向的、换向的....你想了解的方向控制阀都在这里了&#xff01;方向控制阀门液压阀是用来控制液压系统中油液的流动方向或调节其流量和压力的。方向控制阀作为液压阀的一种&#xff0c;利用流道的更换控制着油液的流动方向。单向型方向控制阀是只允许气流沿一个方向流动的方向…

对于新生代农民工,你有什么想说的?

昨晚上这个新闻很多人转&#xff0c;但是可能很少有人知道他的链接出处&#xff0c;链接来自于http://www.mohrss.gov.cn/SYrlzyhshbzb/jiuye/gzdt/202108/t20210816_420736.html我记得我还在上小学的时候&#xff0c;我们家有干不完的农活&#xff0c;暑假每天都要下田干活&am…

谁是经营之神

—北京维富友携手北京服装学院开展服装ERP沙盘大赛时间4月21日&#xff0c;地点北京服装学院&#xff0c;参加人数35人&#xff0c;参加人员北京维富友软件公司高级讲师、服装学院教师和同学共35人。目的&#xff1a;为了让学生更好的掌握服装企业管理和盈利管控&#xff0c;北…

在Android初次的前期学习中的二个小例子(2)

Hello13:SQLite数据库 一、简述SQLite的概念和主要特性SQLite是一个轻量级的关系型数据库&#xff0c;运算速度快&#xff0c;占用资源少&#xff0c;使用非常方便&#xff0c;支持SQL语法标准和数据库事务原则。相对于SharedPreferences使用文件保存数据&#xff0c;SQLite具有…

access 增加字段 工具_Java效率工具之Lombok

作者&#xff1a;LiWenD正在掘金来源&#xff1a;https://juejin.im/post/5b00517cf265da0ba0636d4b上一篇&#xff1a;数据库查询速度优化之解决技巧还在编写无聊枯燥又难以维护的POJO吗&#xff1f;洁癖者的春天在哪里&#xff1f;请看Lombok&#xff01;在过往的Java项目中&…

一文读懂 | 进程并发与同步

并发 是指在某一时间段内能够处理多个任务的能力&#xff0c;而 并行 是指同一时间能够处理多个任务的能力。并发和并行看起来很像&#xff0c;但实际上是有区别的&#xff0c;如下图&#xff08;图片来源于网络&#xff09;&#xff1a;concurrency-parallelism上图的意思是&a…

快速完成和读懂测试计划

每个项目测试计划都会不一样&#xff0c;但是一般情况下&#xff0c;每个公司都会有相应的模板&#xff0c;尤其是项目很频繁的公司&#xff0c;相对应的模板应该就更全面&#xff0c;并且更容易修改&#xff0c;更能适应新项目。 并且&#xff0c;经常接触测试计划的人可能会察…

rust卡领地柜权限_RFID智能医疗耗材柜,上海智能高值耗材柜,国药智能医用耗材柜...

近几年因为我们的医疗改革一直在进步并改革&#xff0c;国家对我们的医疗方面的补助也有了明显的加大投入&#xff0c;与此同时让各种公立私立医院如雨后春笋般层出不穷&#xff0c;各大医院为了在医疗市场占有一席之地&#xff0c;都在各个方面开始想办法提升自己医院的水准。…

刚接触电子时,有过哪些百思不得其解的问题?

青少年时期&#xff0c;刚接触电子时&#xff0c;出于好奇&#xff0c;对这方面的东西也比较关注&#xff0c;但同时也衍生了一些百思不得其解的疑问&#xff0c;比如...01物理书里说大地是导体&#xff0c;那为什么我的小灯珠却不亮&#xff01;&#xff1f;02初三时学了物理的…

建立管理SQL Server登录帐户

1、打开SQL Server 2005的管理工具&#xff0c;选择以windows身份验证模式登陆。然后右击服务器选择属性。2、在打开的服务器属性页面中&#xff0c;选择“安全性”做如下图设置&#xff1a;3.在windows上新建三个组:ReceptionEmployees&#xff0c;ITEmployees。4、然后在SQL …

属性

属性 属性的作用就是保护字段、对字段的赋值和取值进行限定。 属性的本质就是两个方法&#xff0c;一个叫get()一个叫set()。 既有get()也有set()我们诚之为可读可写属性。 只有get()没有set()我们称之为只读属性 没有get()只有set()我们称之为只写属性 private char _gender; …

c++ doxygen 注释规范_利用Doxygen给C程序生成注释文档

利用Doxygen为C程序生成注释文档一、Doxygen工具的安装利用Doxygen工具生成API帮助文档需要下载安装以下三个软件&#xff1a;(1)Doxygen&#xff1a;可以从一套归档源文件开始&#xff0c;生成HTML格式的在线类浏览器&#xff0c;或离线的LATEX、RTF参考手册。本文中所使用的版…

【2021新版】一线大厂 Go 面试题合集

秋天到了&#xff0c;又到了工程师们躁动不安&#xff0c;蠢蠢欲动的季节~这不&#xff0c;金九银十已然到了家门口&#xff0c;现在后台就有不少人问我&#xff1a;现在外边大厂面试都问啥想去大厂又怕面试挂面试应该怎么准备Go 开发前景如何啥样的后端适合切 Go 技术栈...面试…

python开发【基础二】

基本数据类型&#xff1a; 1、数字 在Python2中&#xff0c;分为整形(int)和长整形(long)。 在Python3中&#xff0c;都是int。 #1、将字符串转换为数字 a "123" v int(a) print(v) print(type(v))#2、当前数字的二进制&#xff0c;至少用几位表示 1位等于8个字节.…