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


相关文章
|
4月前
|
开发框架 前端开发 .NET
C#编程与Web开发
【4月更文挑战第21天】本文探讨了C#在Web开发中的应用,包括使用ASP.NET框架、MVC模式、Web API和Entity Framework。C#作为.NET框架的主要语言,结合这些工具,能创建动态、高效的Web应用。实际案例涉及企业级应用、电子商务和社交媒体平台。尽管面临竞争和挑战,但C#在Web开发领域的前景将持续拓展。
164 3
|
4月前
|
SQL 开发框架 安全
C#编程与多线程处理
【4月更文挑战第21天】探索C#多线程处理,提升程序性能与响应性。了解C#中的Thread、Task类及Async/Await关键字,掌握线程同步与安全,实践并发计算、网络服务及UI优化。跟随未来发展趋势,利用C#打造高效应用。
178 3
|
10天前
|
安全 程序员 编译器
C#一分钟浅谈:泛型编程基础
在现代软件开发中,泛型编程是一项关键技能,它使开发者能够编写类型安全且可重用的代码。C# 自 2.0 版本起支持泛型编程,本文将从基础概念入手,逐步深入探讨 C# 中的泛型,并通过具体实例帮助理解常见问题及其解决方法。泛型通过类型参数替代具体类型,提高了代码复用性和类型安全性,减少了运行时性能开销。文章详细介绍了如何定义泛型类和方法,并讨论了常见的易错点及解决方案,帮助读者更好地掌握这一技术。
27 11
|
2天前
|
安全 数据库连接 API
C#一分钟浅谈:多线程编程入门
在现代软件开发中,多线程编程对于提升程序响应性和执行效率至关重要。本文从基础概念入手,详细探讨了C#中的多线程技术,包括线程创建、管理及常见问题的解决策略,如线程安全、死锁和资源泄露等,并通过具体示例帮助读者理解和应用这些技巧,适合初学者快速掌握C#多线程编程。
12 0
|
1月前
|
存储 C#
揭秘C#.Net编程秘宝:结构体类型Struct,让你的数据结构秒变高效战斗机,编程界的新星就是你!
【8月更文挑战第4天】在C#编程中,结构体(`struct`)是一种整合多种数据类型的复合数据类型。与类不同,结构体是值类型,意味着数据被直接复制而非引用。这使其适合表示小型、固定的数据结构如点坐标。结构体默认私有成员且不可变,除非明确指定。通过`struct`关键字定义,可以包含字段、构造函数及方法。例如,定义一个表示二维点的结构体,并实现计算距离原点的方法。使用时如同普通类型,可通过实例化并调用其成员。设计时推荐保持结构体不可变以避免副作用,并注意装箱拆箱可能导致的性能影响。掌握结构体有助于构建高效的应用程序。
52 7
|
20天前
|
图形学 C# 开发者
全面掌握Unity游戏开发核心技术:C#脚本编程从入门到精通——详解生命周期方法、事件处理与面向对象设计,助你打造高效稳定的互动娱乐体验
【8月更文挑战第31天】Unity 是一款强大的游戏开发平台,支持多种编程语言,其中 C# 最为常用。本文介绍 C# 在 Unity 中的应用,涵盖脚本生命周期、常用函数、事件处理及面向对象编程等核心概念。通过具体示例,展示如何编写有效的 C# 脚本,包括 Start、Update 和 LateUpdate 等生命周期方法,以及碰撞检测和类继承等高级技巧,帮助开发者掌握 Unity 脚本编程基础,提升游戏开发效率。
32 0
|
1月前
|
安全 C# 开发者
【C# 多线程编程陷阱揭秘】:小心!那些让你的程序瞬间崩溃的多线程数据同步异常问题,看完这篇你就能轻松应对!
【8月更文挑战第18天】多线程编程对现代软件开发至关重要,特别是在追求高性能和响应性方面。然而,它也带来了数据同步异常等挑战。本文通过一个简单的计数器示例展示了当多个线程无序地访问共享资源时可能出现的问题,并介绍了如何使用 `lock` 语句来确保线程安全。此外,还提到了其他同步工具如 `Monitor` 和 `Semaphore`,帮助开发者实现更高效的数据同步策略,以达到既保证数据一致性又维持良好性能的目标。
28 0
|
3月前
|
存储 C# 开发者
C# 编程基础:注释、变量、常量、数据类型和自定义类型
C# 编程基础:注释、变量、常量、数据类型和自定义类型
|
4月前
|
开发框架 .NET Java
探索 C#编程的奥秘与魅力
【4月更文挑战第20天】C#是微软开发的现代、面向对象的编程语言,以其简洁语法、强大功能和跨平台支持脱颖而出。它支持自动垃圾回收、泛型、委托、LINQ,并广泛应用于桌面、Web、移动和游戏开发。C#拥有活跃的开发者社区和丰富的资源,是Unity游戏开发的首选语言。随着.NET Core,C#可在多个操作系统上运行,持续创新,未来发展潜力巨大。
161 11