C#编程练习(02):大地坐标系(LBH)向空间直角坐标系(XYZ)的转换及其逆转换

简介: C#编程练习(02):大地坐标系(LBH)向空间直角坐标系(XYZ)的转换及其逆转换

需求说明:以WGS-84软件为例,实现大地坐标系(LBH)向空间直角坐标系(XYZ)的转换及其逆转换

原理说明:

20181126092936945.jpg

程序源码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace XYZ2BLH
{
    class Program
    {
        //输出为度格式的字符串 (度分秒.秒的小数部分)
        //例如:35度23分32.9秒    表述为352332.9
        static string[] XYZ2LBH(double x,double y,double z)   
        {
            double[] blh = {0.0, 0.0, 0.0}; 
            double a = 6378137;
            double b = 6356752.3142;
            double e2 = 0.0066943799013;
            double ePie2 = 0.00673949674227;
            double xita = Math.Atan(z * a / (Math.Sqrt(x * x + y * y) * b));
            double xitaSin3 = Math.Sin(xita) * Math.Sin(xita) * Math.Sin(xita);
            double xitaCos3 = Math.Cos(xita) * Math.Cos(xita) * Math.Cos(xita);
            double B = Math.Atan((z + ePie2 * b * xitaSin3) / ((Math.Sqrt(x * x + y * y) - e2 * a *  xitaCos3)));
            double L = Math.Atan(y / x);
            double N = a / Math.Sqrt(1 - e2 * Math.Sin(B) * Math.Sin(B)); ;
            double H = Math.Sqrt(x * x + y * y) / Math.Cos(B) - N;
            //转化为角度
            B = 180 * B / Math.PI;
            if (B < 0.0) { B = B + 90; }                                 
            L = 180 * L / Math.PI;
            if (L < 0.0) { L = L + 180; }
            return new string[] {rad2dms(B), rad2dms(L), H.ToString()};  
        }
        //获取一个小数的整数部分和小数部分
        static double[] modf(double t)
        {
            t += 1.0e-14;//避免角度转换过程产生无效近似
            double t_integer = Math.Floor(t);
            return new double[] { t_integer, t - t_integer };      
        }
        //角度转弧度
        static double turn1(double t)
        {
            double[] t1 = modf(t);
            double[] t2 = modf(t1[1] * 100);
            double x1 = t1[0];
            double x2 = t2[0];
            double x3 = t2[1] * 100;        
            //Console.Write("{0:N} \t {1:N}\t {2:N}\r\n", x1, x2, x3);
            return (x1 + x2 / 60 + x3 / 3600) / 180 * Math.PI;
        }
        //弧度转角度
        static string rad2dms(double rad)
        {
            int du, fen;
            double miao;
            du = (int)rad;
            fen = (int)((rad - (double)du) * 60);
            miao = ((rad - (double)du) * 60 - (double)fen) * 60;
            return du.ToString() + fen.ToString().PadLeft(2,'0') + miao.ToString();        
        }
        //经度、纬度和大地高转向空间直角坐标
        static double[] LBH2XYZ(double[] lbh)
        {
            double B = turn1(lbh[1]);
            double L = turn1(lbh[0]);
            double H = lbh[2];
            double A = 1 / 298.257223563;
            double a = 6378137.0000000000;
            double E = 2 * A - A * A;
            double W = Math.Sqrt(1 - E * Math.Sin(B) * Math.Sin(B));
            double N = a / W;
            double[] xyz = { 0.0, 0.0, 0.0 };
            xyz[0] = (N + H) * Math.Cos(B) * Math.Cos(L);
            xyz[1] = (N + H) * Math.Cos(B) * Math.Sin(L);
            xyz[2] = (N * (1 - E) + H) * Math.Sin(B);
            return xyz;
        }
        static void Main(string[] args)
        {
            double[] lbh = { 108.5743, 32.2352, 100.59 };
            double[] xyz = LBH2XYZ(lbh);
            Console.WriteLine("{0:N6} {1:N6} {2:N6}", xyz[0], xyz[1], xyz[2]);
            string[] lbhTmp = XYZ2LBH(xyz[0], xyz[1], xyz[2]);
            Console.WriteLine("{0:N6} {1:N6} {2:N6}", double.Parse(lbhTmp[0]), double.Parse(lbhTmp[1]), double.Parse(lbhTmp[2]));         
        }
    }
}

测试结果:

20181126093323133.png


相关文章
|
9月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
260 3
|
9月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
238 3
|
3月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
60 3
|
2月前
|
存储 安全 编译器
学懂C#编程:属性(Property)的概念定义及使用详解
通过深入理解和使用C#的属性,可以编写更清晰、简洁和高效的代码,为开发高质量的应用程序奠定基础。
116 12
|
3月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
114 4
|
5月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
69 2
|
5月前
|
安全 程序员 编译器
C#一分钟浅谈:泛型编程基础
在现代软件开发中,泛型编程是一项关键技能,它使开发者能够编写类型安全且可重用的代码。C# 自 2.0 版本起支持泛型编程,本文将从基础概念入手,逐步深入探讨 C# 中的泛型,并通过具体实例帮助理解常见问题及其解决方法。泛型通过类型参数替代具体类型,提高了代码复用性和类型安全性,减少了运行时性能开销。文章详细介绍了如何定义泛型类和方法,并讨论了常见的易错点及解决方案,帮助读者更好地掌握这一技术。
110 11
|
4月前
|
安全 C# 数据安全/隐私保护
实现C#编程文件夹加锁保护
【10月更文挑战第16天】本文介绍了两种用 C# 实现文件夹保护的方法:一是通过设置文件系统权限,阻止普通用户访问;二是使用加密技术,对文件夹中的文件进行加密,防止未授权访问。提供了示例代码和使用方法,适用于不同安全需求的场景。
232 0
|
5月前
|
SQL 开发框架 安全
并发集合与任务并行库:C#中的高效编程实践
在现代软件开发中,多核处理器普及使多线程编程成为提升性能的关键。然而,传统同步模型在高并发下易引发死锁等问题。为此,.NET Framework引入了任务并行库(TPL)和并发集合,简化并发编程并增强代码可维护性。并发集合允许多线程安全访问,如`ConcurrentQueue&lt;T&gt;`和`ConcurrentDictionary&lt;TKey, TValue&gt;`,有效避免数据不一致。TPL则通过`Task`类实现异步操作,提高开发效率。正确使用这些工具可显著提升程序性能,但也需注意任务取消和异常处理等常见问题。
75 1