当前位置: 首页 > news >正文

【.net core】天地图坐标转换为高德地图坐标(WGS84 坐标转 GCJ02 坐标)

 类文件

public static class WGS84ToGCJ02Helper
{// 定义一些常量private const double PI = 3.14159265358979324;private const double A = 6378245.0;private const double EE = 0.00669342162296594323;// 判断坐标是否在中国范围内(不在国内则不进行转换)private static bool OutOfChina(double lng, double lat){return (lng < 72.004 || lng > 137.8347) ||(lat < 0.8293 || lat > 55.8271);}// 转换纬度private static double TransformLat(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 TransformLng(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;}// WGS84 转 GCJ02public static (double lng, double lat) Wgs84ToGcj02(double wgsLng, double wgsLat){if (OutOfChina(wgsLng, wgsLat)){return (wgsLng, wgsLat);}double dLat = TransformLat(wgsLng - 105.0, wgsLat - 35.0);double dLng = TransformLng(wgsLng - 105.0, wgsLat - 35.0);double radLat = wgsLat / 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);dLng = (dLng * 180.0) / (A / sqrtMagic * Math.Cos(radLat) * PI);double mgLat = wgsLat + dLat;double mgLng = wgsLng + dLng;return (mgLng, mgLat);}
}

调用

        // 示例:北京天安门的 WGS84 坐标double wgsLng = 116.397228;double wgsLat = 39.907501;// 转换为 GCJ02 坐标var gcjCoord = WGS84ToGCJ02Helper.Wgs84ToGcj02(wgsLng, wgsLat);Console.WriteLine($"WGS84 坐标: ({wgsLng}, {wgsLat})");Console.WriteLine($"GCJ02 坐标: ({gcjCoord.lng}, {gcjCoord.lat})");

相关文章:

  • 电脑提示dll文件缺失怎么办 dll修复方法
  • 用电脑控制keysight示波器
  • 《一生一芯》数字实验三:加法器与ALU
  • ASP.NET Core使用Quartz部署到IIS资源自动被回收解决方案
  • Ubuntu崩溃修复方案
  • 购物商城网站 Java+Vue.js+SpringBoot,包括商家管理、商品分类管理、商品管理、在线客服管理、购物订单模块
  • 船舶事故海上搜救VR情景演练全场景 “复刻”,沉浸式救援体验​
  • 机器学习的数学基础:决策树
  • Unity VR/MR开发-VR设备与适用场景分析
  • HTML中各种标签的作用
  • 为什么要选择VR看房?VR看房有什么优点?
  • html - <mark>标签
  • 【Go语言基础【3】】变量、常量、值类型与引用类型
  • html文字红色粗体,闪烁渐变动画效果,中英文切换版本
  • 酷黑NBA足球赛事直播源码体育直播M39模板赛事源码
  • Ubuntu20.04设置为开机后直接自动进入纯命令行界面
  • Cilium动手实验室: 精通之旅---4.Cilium Gateway API - Lab
  • 从0开始学习R语言--Day17--Cox回归
  • Ubuntu ifconfig 查不到ens33网卡
  • Axure零基础跟我学:展开与收回
  • 大连网络推广平台/湖南正规关键词优化首选
  • 机关政府网站建设/济南网站制作
  • 怎样做网站搜索推广/友情链接购买网站
  • 怎么创作自己的网站/新闻早知道
  • 网站文字很少怎么做优化/宁波seo推广服务电话
  • 湘潭做网站问下磐石网络/seo分析seo诊断