WGS84 2 GCJ-02
#include "math.h" #include "stdio.h" double casm_rr ; unsigned int casm_t1; unsigned int casm_t2; double casm_x1; double casm_y1; double casm_x2; double casm_y2; double casm_f; double yj_sin2(double x) { double tt ; double ss; int ff ; double s2; int cc; ff=; if (x<) { x=-x; ff=; } cc=int(x/6.28318530717959); tt=x-cc*6.28318530717959; if (tt>3.1415926535897932) { tt=tt-3.1415926535897932; if (ff==) ff=; else if (ff==) ff=; } x=tt; ss=x; s2=x; tt=tt*tt; s2=s2*tt; ss=ss-s2* 0.166666666666667; s2=s2*tt; ss=ss+s2* 8.33333333333333E-03; s2=s2*tt; ss=ss-s2* 1.98412698412698E-04; s2=s2*tt; ss=ss+s2* 2.75573192239859E-06; s2=s2*tt; ss=ss-s2* 2.50521083854417E-08; if (ff==) ss=-ss; return ss; } double Transform_yj5(double x , double y ) { double tt; tt = + * x + * y + 0.1 * x * x + 0.1 * x * y + 0.1 * sqrt(sqrt(x*x)); tt = tt + ( *yj_sin2(18.849555921538764 * x ) + * yj_sin2(6.283185307179588 * x))*0.6667; tt = tt + ( * yj_sin2(3.141592653589794 * x ) + * yj_sin2(1.047197551196598 * x))*0.6667; tt = tt + ( * yj_sin2(0.2617993877991495 * x) + * yj_sin2(0.1047197551196598 * x))*0.6667; return tt; } double Transform_yjy5(double x , double y ) { double tt ; tt = - + * x + * y + 0.2 * y * y + 0.1 * x * y + 0.2 * sqrt(sqrt(x*x)); tt = tt + ( * yj_sin2(18.849555921538764 * x) + * yj_sin2(6.283185307179588 * x))*0.6667; tt = tt + ( * yj_sin2(3.141592653589794 * y)+ * yj_sin2(1.047197551196598 * y))*0.6667; tt = tt + ( * yj_sin2(0.2617993877991495 * y) + * yj_sin2(0.1047197551196598 * y))*0.6667; return tt; } double Transform_jy5(double x , double xx ) { double n ; double a ; double e ; a = ; e = 0.00669342; n = sqrt ( - e * yj_sin2(x * 0.0174532925199433) * yj_sin2(x * 0.0174532925199433) ); n = (xx * ) /(a / n * cos(x * 0.0174532925199433) * 3.1415926) ; return n; } double Transform_jyj5(double x , double yy ) { double m ; double a ; double e ; double mm; a = ; e = 0.00669342; mm= - e * yj_sin2(x * 0.0174532925199433) * yj_sin2(x * 0.0174532925199433) ; m = (a * ( - e)) / (mm * sqrt(mm)); return (yy * ) / (m * 3.1415926); } double r_yj() { int casm_a ; int casm_c ; casm_a = ; casm_c = ; return ; } double random_yj() { int t; int casm_a ; int casm_c ; casm_a = ; casm_c = ; casm_rr = casm_a * casm_rr + casm_c ; t = int(casm_rr /); casm_rr = casm_rr - t * ; casm_rr = casm_rr / ; return (casm_rr); } void IniCasm(unsigned int w_time, unsigned int w_lng, unsigned int w_lat) { int tt; casm_t1 = w_time ; casm_t2 = w_time ; tt=int(w_time/0.357); casm_rr=w_time-tt*0.357; if (w_time==) casm_rr=0.3; casm_x1 = w_lng; casm_y1 = w_lat; casm_x2 = w_lng; casm_y2 = w_lat; casm_f=; } unsigned int wgtochina_lb(int wg_flag, unsigned int wg_lng, unsigned int wg_lat, int wg_heit, int wg_week, unsigned int wg_time, unsigned int *china_lng, unsigned int *china_lat) { double x_add ; double y_add ; double h_add ; double x_l; double y_l; double casm_v ; double t1_t2; double x1_x2; double y1_y2; if (wg_heit>) { *china_lng = ; *china_lat = ; return 0xFFFF95FF; } x_l = wg_lng; x_l = x_l / 3686400.0; y_l = wg_lat ; y_l = y_l / 3686400.0; if (x_l < 72.004) { *china_lng = ; *china_lat = ; return 0xFFFF95FF; } if ( x_l > 137.8347) { *china_lng = ; *china_lat = ; return 0xFFFF95FF; } if (y_l < 0.8293) { *china_lng = ; *china_lat = ; return 0xFFFF95FF; } if ( y_l > 55.8271) { *china_lng = ; *china_lat = ; return 0xFFFF95FF; } if (wg_flag ==) { IniCasm(wg_time,wg_lng,wg_lat); *china_lng = wg_lng; *china_lat = wg_lat; return 0x00000000; } casm_t2= wg_time ; t1_t2 =(double)(casm_t2 - casm_t1)/1000.0; if ( t1_t2<= ) { casm_t1= casm_t2 ; casm_f=casm_f+; casm_x1 = casm_x2; casm_f=casm_f+; casm_y1 = casm_y2; casm_f=casm_f+; } else { if ( t1_t2 > ) { if (casm_f == ) { casm_f=; casm_x2 = wg_lng; casm_y2 = wg_lat; x1_x2 = casm_x2 - casm_x1; y1_y2 = casm_y2 - casm_y1; casm_v = sqrt (x1_x2 * x1_x2 + y1_y2 * y1_y2 ) /t1_t2; if (casm_v > ) { *china_lng = ; *china_lat = ; return (0xFFFF95FF); } } casm_t1= casm_t2 ; casm_f=casm_f+; casm_x1 = casm_x2; casm_f=casm_f+; casm_y1 = casm_y2; casm_f=casm_f+; } } x_add = Transform_yj5(x_l - , y_l - ) ; y_add = Transform_yjy5(x_l - , y_l - ) ; h_add = wg_heit; x_add = x_add + h_add * 0.001 + yj_sin2(wg_time*0.0174532925199433)+random_yj(); y_add = y_add + h_add * 0.001 + yj_sin2(wg_time*0.0174532925199433)+random_yj(); *china_lng = unsigned int( (x_l + Transform_jy5(y_l, x_add)) * ); *china_lat = unsigned int( (y_l + Transform_jyj5(y_l, y_add)) * ); return (0x00000000); } bool wg2mars( const double in_lon, const double in_lat, double& out_lon, double& out_lat ) { const double BASE = 3686400.0; unsigned int lon, lat; lon = unsigned int ( in_lon * BASE ); lat = unsigned int ( in_lat * BASE ); unsigned int ret = wgtochina_lb( , lon, lat, , , , &lon, &lat ); out_lon = lon / BASE; out_lat = lat / BASE; return (==ret); }
http://hi.baidu.com/sa_sc/item/570101a588b5f8f714329b26
WGS84 2 GCJ-02的更多相关文章
- 火星02坐标转换为WGS84坐标
import java.io.BufferedReader; import java.io.File; import java.io.FileNotFoundException; import jav ...
- 地球坐标系(WGS-84)转火星坐标系(GCJ)
/** * 单点坐标纠偏 */ var pi = 3.14159265358979324; var a = 6378245.0; var ee = 0.00669342162296594323; va ...
- 使用js对WGS-84 ,GCJ-02与BD-09的坐标进行转换
获取到经纬度在用百度地图进行定位时,却发现行驶轨迹的路线定到海里面去了.从网上查阅,知道此方法. 出处:https://www.jianshu.com/p/53f00ba897f7 一.在进行地图开发 ...
- python、js实现WGS84、高德(火星)、百度坐标转换
在日常工作学习中常会涉及到WGS84.高德(火星/谷歌).百度三种空间坐标系的坐标转换,本文将通过python.js两种语言实现坐标系的转换. 坐标系说明: wgs84:为一种大地坐标系,也是目前广泛 ...
- 火星坐标、百度坐标、WGS-84坐标相互转换及墨卡托投影坐标转经纬度JavaScript版
火星坐标 火星坐标是国家测绘局为了国家安全在原始坐标的基础上进行偏移得到的坐标,基本国内的电子地图.导航设备都是采用的这一坐标系或在这一坐标的基础上进行二次加密得到的.火星坐标的真实名称应该是GCJ- ...
- GPS坐标互转:WGS-84(GPS)、GCJ-02(Google地图)、BD-09(百度地图)(转载)
WGS-84:是国际标准,GPS坐标(Google Earth使用.或者GPS模块)GCJ-02:中国坐标偏移标准,Google Map.高德.腾讯使用BD-09:百度坐标偏移标准,Baidu Map ...
- WGS84、Web墨卡托、火星坐标、百度坐标互转
转自:1.http://blog.csdn.net/wildboy2001/article/details/12031351 2.http://kongxz.com/2013/10/wgs-cgj/ ...
- WGS84、GCJ-02(火星坐标)、百度坐标,Web墨卡托坐标
GCJ-02坐标系统(火星坐标)简介:http://blog.csdn.net/giswens/article/details/8775121(存档:http://mapbd.com/cms/2012 ...
- GCJ-02火星坐标系和WGS-84坐标系转换关系
GCJ-02火星坐标系和WGS-84坐标系转换关系 WGS-84:GPS坐标系 GCJ-02:火星坐标系,国测局02年发布的坐标体系,高德,腾讯等使用. BD-09:百度坐标系,百度自研,百度地图使用 ...
- WGS84,GCJ02, BD09坐标转换
public class Gps { private double wgLat; private double wgLon; public Gps(double wgLat, double wgLon ...
随机推荐
- asp.net 页面按回车就会触发button按钮事件
转载于 https://www.cnblogs.com/anz130/articles/2445830.html 转自:http://space.itpub.net/12639172/viewspac ...
- 基于Java+Selenium的WebUI自动化测试框架(三)------记录LOG
在有了Position类和接口类之后,我们是不是立刻就要着手开始写实现类了呢?按照一般的顺序是这样.但是,我们这里先停一下.原因有二: 1)既然是写一个框架,我们希望总体的功能上是全面的.实现类中,我 ...
- 猜数游戏-人机对战-经典的randint使用
翻阅去年的笔记,老师曾经教的random模块下的三种用法,其中之一是randint用法,今天上传,留作笔记参考.人生苦短,我用python! # -*- coding: UTF-8 -*- impor ...
- Java8新特性--CompletableFuture
并发与并行 Java 5并发库主要关注于异步任务的处理,它采用了这样一种模式,producer线程创建任务并且利用阻塞队列将其传递给任务的consumer.这种模型在Java 7和8中进一步发展,并且 ...
- vs2017 c# 控制台 输出中文显示问号 ; vs2017 c# 控制台 输出中文显示乱码
问题: 解决: 在main方法最前面加一句就OK了! Console.OutputEncoding = Encoding.GetEncoding("gbk"); 或者 Consol ...
- 用于异步事件驱动的 P 语言 P Language
微软最近开源了P语言,致力于在Linux.macOS和Windows上编写安全的异步事件驱动程序. 微软将P描述为一种领域特定语言,对异步系统的组件间通信进行建模,例如嵌入式.网络或分布式系统.P程序 ...
- LightOJ - 1214-Large Division(数学,同余)
链接: https://vjudge.net/problem/LightOJ-1214 题意: Given two integers, a and b, you should check whethe ...
- 使用jQuery快速高效制作网页交互特效---表单校验
表单基本验证技术 为什么需要表单验证 减轻服务器的压力 保证输入的数据符合要求 常用的表单验证 1.日期格式 2.表单元素是否为空 3.用户名和密码 4.E-mail地址 5.身份证号码 表单选择器 ...
- 普通页面引入React(使用和不使用JSX)
1. 不使用JSX 优点: 不用配置有关JSX的编译. 依赖语法: React.createElement(component/type, props, ...chilidren); //第一个参数可 ...
- DevTool-Network
如图所示,图中蓝线表示DOMContentLoaded事件触发时经过的时间,DOM树构建花费的时间. 图中红线表示onload事件触发时经过的时间,也是所有的资源(图片等)下载处理完成的时间. 图中绿 ...