WGS84->GCJ-02坐标转化

GCJ-02火星坐标系和WGS-84坐标系转换关系

WGS-84:GPS坐标系
GCJ-02:火星坐标系,国测局02年发布的坐标体系,高德,腾讯等使用。
BD-09:百度坐标系,百度自研,百度地图使用。

GCJ-02 转WGS-84

公式


下面的改进后的代码package com.google.android.apps.location.gps.gnsslogger;

import java.math.BigDecimal;import java.math.RoundingMode;

/** * gps纠偏算法,适用于google,高德体系的地图 */public abstract class GpsUtilNew {

    private final static double a = 6378245.0;    private final static double pi = 3.1415926535897932384626;    private final static double ee = 0.00669342162296594323;

    /**     * 计算地球上任意两点(经纬度)距离     *     * @param lat1     *            第一点纬度     * @param lng1     *            第一点经度     * @param lat2     *            第二点纬度     * @param lng2     *            第二点经度     * @return 返回距离 单位:米     */    public static double distance(double lat1, double lng1, double lat2, double lng2) {        double a, b, R;        R = 6378137; // 地球半径        lat1 = lat1 * Math.PI / 180.0;        lat2 = lat2 * Math.PI / 180.0;        a = lat1 - lat2;        b = (lng1 - lng2) * Math.PI / 180.0;        double d;        double sa2, sb2;        sa2 = Math.sin(a / 2.0);        sb2 = Math.sin(b / 2.0);        d = 2 * R * Math.asin(Math.sqrt(sa2 * sa2 + Math.cos(lat1) * Math.cos(lat2) * sb2 * sb2));        return d;    }

    /**     * Description: WGS-84 to GCJ-02 <BR>     *     * @author dsn     * @date 2017年10月24日 下午2:09:27     * @param latitude     *            纬度     * @param longitude     *            经度     * @return [纬度,经度]     * @version 1.0     */    public static double[] toGCJ02Point(double latitude, double longitude) {        double[] dev = calDev(latitude, longitude);        double retLat = latitude + dev[0];        double retLon = longitude + dev[1];        return new double[] { retLat, retLon };    }

    /**     * Description: WGS-84 to GCJ-02 <BR>     *     * @author dsn     * @date 2017年10月24日 下午2:09:27     * @param latitude     *            纬度     * @param longitude     *            经度     * @param scale     *            经纬度保留小数位数     * @return [纬度,经度]     * @version 1.0     */    public static double[] toGCJ02Point(double latitude, double longitude, int scale) {        double[] dev = calDev(latitude, longitude);        double retLat = latitude + dev[0];        double retLon = longitude + dev[1];        return new double[] { new BigDecimal(retLat).setScale(scale, RoundingMode.DOWN).doubleValue(),                new BigDecimal(retLon).setScale(scale, RoundingMode.DOWN).doubleValue() };    }

    /**     * Description:GCJ-02 to WGS-84 <BR>     *     * @author dsn     * @date 2017年10月24日 下午2:09:54     * @param latitude     *            纬度     * @param longitude     *            经度     * @return [纬度,经度]     * @version 1.0     */    public static double[] toWGS84Point(double latitude, double longitude) {        double[] dev = calDev(latitude, longitude);        double retLat = latitude - dev[0];        double retLon = longitude - dev[1];        dev = calDev(retLat, retLon);        retLat = latitude - dev[0];        retLon = longitude - dev[1];        return new double[] { retLat, retLon };    }

    private static double[] calDev(double wgLat, double wgLon) {        if (isOutOfChina(wgLat, wgLon)) {            return new double[] { 0, 0 };        }        double dLat = calLat(wgLon - 105.0, wgLat - 35.0);        double dLon = calLon(wgLon - 105.0, wgLat - 35.0);        double radLat = wgLat / 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);        return new double[] { dLat, dLon };    }

    private static boolean isOutOfChina(double lat, double lon) {        if (lon < 72.004 || lon > 137.8347)            return true;        if (lat < 0.8293 || lat > 55.8271)            return true;        return false;    }

    private static double calLat(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(Math.abs(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 calLon(double x, double y) {        double ret = 300.0 + x + 2.0 * y + 0.1 * x * x + 0.1 * x * y + 0.1 * Math.sqrt(Math.abs(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;    }

}

原文地址:https://www.cnblogs.com/blogger-Li/p/11616835.html

时间: 2024-10-07 08:00:16

WGS84->GCJ-02坐标转化的相关文章

火星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 do

[C#]利用纠偏数据来处理地球坐标(WGS-84)与火星坐标 (GCJ-02)转换

关键代码: using System; using System.Collections; using System.Collections.Generic; using System.IO; using YanZhiwei.DotNet2.Utilities.Models; namespace YanZhiwei.DotNet2.Utilities.Common { /// <summary> /// 地图纠偏数据帮助类 /// </summary> public class M

API地图坐标转化(批量转换坐标)

```html 批量转换坐标(据说有50次/秒的限制哦) 谷歌地图 鼠标点击的谷歌坐标是: 百度地图 鼠标点击的百度坐标是:() ``` ```javascript // (function(){ function loadscript(xyUrl, callback){ var head = document.getElementsByTagName('head')[0]; var script = document.createElement('script'); script.type =

GPS坐标转化为百度坐标

============问题描述============ 想把手机采集的GPS坐标转化为百度坐标,在网上找了一下代码: GeoPoint geoPoint3 = new GeoPoint((int) ((mLat1 + 0.001) * 1E6), (int) ((mLon1 + 0.003) * 1E6)); GeoPoint GeoPointBaidu = CoordinateConvert.fromWgs84ToBaidu(geoPoint3);  mOverlayList.add(new

GPS定位的偏移校正(WGS84与火星坐标互转)

原文:GPS定位的偏移校正(WGS84与火星坐标互转) 地图坐标系目前包括: 地球坐标 (WGS84) WGS84:World Geodetic System 1984,是为GPS全球定位系统使用而建立的坐标系统. 国际标准,从 GPS 设备中取出的数据的坐标系 国际地图提供商使用的坐标系 火星坐标 (GCJ-02)也叫国测局坐标系 GCJ-02是由中国国家测绘局(民间说的火星坐标系)制订的地理信息系统的坐标系统. 它是一种对经纬度数据的加密算法,即加入随机的偏差. 国内出版的各种地图系统(包括

openlayers 球面墨卡托坐标转化

第一种方式: 1 var proj = new OpenLayers.Projection("EPSG:4326"); 2 var point = new OpenLayers.LonLat(-68, 42); 3 point.transform(proj, map.getProjectionObject()); 第二种方式,通过替换坐标坐标进行实现 var point = new OpenLayers.Bounds(-68, 40, -88, 52) point .transform

百度坐标转化细节

1.分析同步服务拿到的经纬度是否准确: 拿到一个点的经纬度,然后放到百度地图中验证是否准确: 2.分析算法是否准确: 百度坐标,谷歌中国坐标(国测局坐标系): 这里注意:谷歌中国也是用的国测局的坐标系:测试算法只用算法中的 百度坐标 转 国测局的坐标系 来验证算法是否准确: 如果准确,说明算法准确,那么还是要用这个算法来转 国测局的经纬度 到 WGS84. 这里无法直接用百度地图坐标转WGS85的来直接测试算法,因为百度地图在国内,没有国外的坐标,而只有谷歌国外才有WGS84: 3.我们本身的地

GPS坐标(WGS84)转换百度坐标(BD09) python测试

基础知识坐标系说明: WGS84:为一种大地坐标系,也是目前广泛使用的GPS全球卫星定位系统使用的坐标系. GCJ02:是由中国国家测绘局制订的地理信息系统的坐标系统.由WGS84坐标系经加密后的坐标系. BD09:为百度坐标系,在GCJ02坐标系基础上再次加密.其中bd09ll表示百度经纬度坐标,bd09mc表示百度墨卡托米制坐标 参考文档: http://lbsyun.baidu.com/index.php?title=webapi/guide/changeposition 功能接口主用调用

GPS坐标转化

//将GPS纬度信息转换为“火星坐标”的纬度 function latToGcj02(lon, lat) { var c = Math.PI, d = Math.sin, e = -100 + 2 * lon + 3 * lat + 0.2 * lat * lat + 0.1 * lon * lat + 0.2 * Math.sqrt(Math.abs(lon)), e = e + 2 * (20 * d(6 * lon * c) + 20 * d(2 * lon * c)) / 3, e =