火星02坐标转换为WGS84坐标
import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileReader;
import java.io.IOException; public class Gpstest { final static int TABLESIZE=660*450;
//#define ID(i, j) ((i) + 660 * (j)) static double[] TableX=new double[TABLESIZE];
static double[] TableY=new double[TABLESIZE];
static boolean bInitTable = false; static void InitTable() throws IOException
{
File filename = new File("C://Mars2Wgsnew.txt");
long lX1, lY1;
String tempString;
String[] tem;
bInitTable = false;
BufferedReader reader = new BufferedReader(new FileReader(filename));
for(int i=0;;i++){
tempString = reader.readLine();
if(tempString==null){
break;
}
// System.out.println(tempString);
tempString=tempString.replaceAll(" ","");
tem=tempString.split(","); TableX[i] = ((double) Long.valueOf(tem[0])) / 100000.0;
TableY[i] = ((double) Long.valueOf(tem[1])) / 100000.0;
}
reader.close();
bInitTable = true;
} // Result:
// 0 - ok
// -1 - Table is not initialized
// -2 - Latitude or Longitude is invalid
static int Mars2Wgs( double x_mars, double y_mars )
{
int i, j, k;
double x1, y1, x2, y2, x3, y3, x4, y4, xtry, ytry, dx, dy,x_wgs,y_wgs;
double t, u; if(!bInitTable) return -1; xtry = x_mars;
ytry = y_mars; for( k=0; k<10; ++k )
{
// 只对中国国境内数据转换
if( xtry < 72 || xtry > 137.9 || ytry < 10 || ytry > 54.9)
{
return -2;
}
i = (int) ((xtry - 72.0) * 10.0);
j = (int) ((ytry - 10.0) * 10.0);
x1 = TableX[i+660*j];
y1 = TableY[i+660*j];
x2 = TableX[(i+1)+660*j];
y2 = TableY[(i+1)+660*j];
x3 = TableX[(i+1)+660*(j+1)];
y3 = TableY[(i+1)+660*(j+1)];
x4 = TableX[i+660*(j+1)];
y4 = TableY[i+660*(j+1)];
t = (xtry - 72.0 - 0.1 * i) * 10.0;
u = (ytry - 10.0 - 0.1 * j) * 10.0;
dx = (1.0-t)*(1.0-u)*x1 + t*(1.0-u)*x2 + t*u*x3 + (1.0-t)*u*x4 - xtry;
dy = (1.0-t)*(1.0-u)*y1 + t*(1.0-u)*y2 + t*u*y3 + (1.0-t)*u*y4 - ytry;
xtry = (xtry + x_mars - dx)/2.0;
ytry = (ytry + y_mars - dy)/2.0;
}
x_wgs = xtry;
y_wgs = ytry;
System.out.println(x_wgs+";"+y_wgs);
return 0;
} public static void main(String[] args) throws IOException
{
double x_mars, y_mars, x_wgs, y_wgs;
File fname = new File("C://2.txt");
String tempString;
String[] tem;
BufferedReader reader = new BufferedReader(new FileReader(fname));
int result;
for(int i=0;;i++){
tempString = reader.readLine();
if(tempString==null){
break;
}
// System.out.println(tempString);
tempString=tempString.replaceAll(" ","");
tem=tempString.split(","); x_mars = ((double) Double.valueOf(tem[0]));
y_mars = ((double) Double.valueOf(tem[1]));
InitTable();
result = Mars2Wgs(x_mars, y_mars);
}
}
}
本例子程序改编自其它网友,其功能是将火星02坐标转换为WGS84坐标
需要一个数据文件Mars2Wgsnew.txt。转换后存在几米到十几米的误差
http://files.cnblogs.com/casicyuan/Mars2Wgsnew.rar
火星02坐标转换为WGS84坐标的更多相关文章
- 火星坐标、百度坐标、WGS-84坐标相互转换及墨卡托投影坐标转经纬度JavaScript版
火星坐标 火星坐标是国家测绘局为了国家安全在原始坐标的基础上进行偏移得到的坐标,基本国内的电子地图.导航设备都是采用的这一坐标系或在这一坐标的基础上进行二次加密得到的.火星坐标的真实名称应该是GCJ- ...
- Web墨卡托坐标与WGS84坐标互转
原文地址:http://bbs.esrichina-bj.cn/ESRI/thread-78245-1-1.html 在WebGIS的开发中经常用到的地图投影为Web墨卡托和WGS84,故歌地图,bi ...
- 【转】火星坐标、百度坐标、WGS-84坐标相互转换及墨卡托投影坐标转经纬度JavaScript版
原文地址:https://www.cnblogs.com/fwc1994/p/5884115.html 火星坐标 火星坐标是国家测绘局为了国家安全在原始坐标的基础上进行偏移得到的坐标,基本国内的电子地 ...
- 轨迹系列5——验证轨迹GPS坐标转换为本地坐标的四/七参数是否准确的一种方案
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1. 背景 目前对多个项目轨迹不准确的情况做了排查,发现导致轨迹偏移百分 ...
- canvas中window坐标转换为canvas坐标
function getMousePos(canvas, evt) { var rect = canvas.getBoundingClientRect(); return { x: evt.clien ...
- 百度坐标(BD-09)、国测局坐标(火星坐标,GCJ-02)和WGS-84坐标互转
// 坐标转换 var coordTransform = (function () { // 一些常量 var PI = 3.1415926535897932384626; var X_PI = 3. ...
- GPS转换为百度坐标
原文地址:http://www.cnblogs.com/zhaohuionly/archive/2013/06/18/3142623.html 最近在做一个关于手机定位的小应用,需求是这样的,用户通过 ...
- arcgis server 中Web墨卡托投影与WGS-84坐标的转换
arcgis server 中Web墨卡托投影坐标与WGS-84坐标的转换 //经纬度转墨卡托 function lonlat2mercator(lonlat){ var mercator={x:0, ...
- GPS坐标换算为百度坐标
最近在做一个关于手机定位的小应用,需求是这样的,用户通过手机(Wp8)进行二维码扫描操作并且记录用户的当前位置,在PC上可以查看用户所在地图的位置,做法就是在用户扫描条码时,通过手机GPS获取当前在地 ...
随机推荐
- 【设计模式 - 4】之原型模式(Prototype)
1 模式简介 原型模式的定义:通过复制一个现有的对象(原型)来得到一个相似的对象. 原型模式的UML图如下图所示: 从上图中可以看到,所有的对象实体类都是继承自一个Prototype的父类, ...
- cocos2d与cocos2d-X中的draw和update
像其它的游戏引擎一样,我们有两个不同的方法来完成draw和update. 1: Draw:每一个CCNode都有一个draw方法,每一帧都会调用.我们只在这个方法里做描绘的事情. 2: Update: ...
- SpringMVC ModelAndView方法与模板传参接收不到问题
最近在使用Spring MVC做项目时,碰到一个问题,就是通过ModelAndView与前端模板页面通信时,一直无法在模板中显示出来传过去的参数值. 在网上也查了好久,就是不知道是啥问题,很是郁闷. ...
- HDOJ 4696 Answers 乱搞
乱搞: rt.有1就能输出全部的数,否则仅仅能输出偶数 Answers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/1 ...
- java websockect
https://github.com/TooTallNate/Java-WebSocket (websockect类库包) http://blog.openlg.net/index.php/archi ...
- [转] react-native 之布局篇
PS: 苹果使用的宽度单位是为了设计开发者在应用上使用接近的数值.比如宽度范围都在320-414之间.但是宽度对应到像素是有一个转换比例的,对于背景图尤其要准备足够像素的图片.这个足够像素可以通过公式 ...
- [转] 再叙TIME_WAIT
http://huoding.com/2013/12/31/316 之所以起这样一个题目是因为很久以前我曾经写过一篇介绍TIME_WAIT的文章,不过当时基本属于浅尝辄止,并没深入说明问题的来龙去脉, ...
- Fragment之我的解决方案:Fragmentation
Fragment系列文章:1.Fragment全解析系列(一):那些年踩过的坑2.Fragment全解析系列(二):正确的使用姿势3.Fragment之我的解决方案:Fragmentation 如果你 ...
- Python之路【第十篇】:HTML -暂无等待更新
Python之路[第十篇]:HTML -暂无等待更新
- c#中使用数据读取器读取查询结果
今天有时间了. 在看<c#数据库入门经典> ,总结数据读取器查询结果. 针对单个结果集使用读取器,有3中方法: String connString =..; String sql =@&q ...