技术经验解读:三维空间中直角坐标与球坐标的相互转换

简介: 技术经验解读:三维空间中直角坐标与球坐标的相互转换

三维直角坐标系


三维直角坐标系是一种利用直角坐标(x,y,z)来表示一个点 P 在三维空间的位置的三维正交坐标系。


注:本文所讨论的三维直角坐标系,默认其x-轴、y-轴、z-轴满足右手定则(如右图所示)。


在三维空间的任何一点 P ,可以用直角坐标(x,y,z)来表达其位置。如左下图显示了三维直角坐标的几何意义:点P在x-轴、y-轴、z-轴上的投影距离分别为x、y、z。如右下图所示,两个点 P 与 Q 的直角坐标分别为(3,0,5)与(-5,-5,7) 。


球坐标系


球坐标系是一种利用球坐标(r,θ,φ)来表示一个点 P 在三维空间的位置的三维正交坐标系。


下图描述了球坐标的几何意义:原点O与目标点P之间的径向距离为r,O到P的连线与正z-轴之间的夹角为天顶角θ,O到P的连线在xy-平面上的投影线与正x-轴之间的夹角为方位角φ。


假设 P 点在三维空间的位置的三个坐标是 。那么, 0 ≤ r 是从原点到 P 点的距离, 0 ≤ θ ≤ π 是从原点到 P 点的连线与正 z-轴的夹角, 0 ≤ φ < 2π 是从原点到 P 点的连线在 xy-平面的投影线,与正 x-轴的夹角。当 时, 与 都一起失去意义。当 或 时, 失去意义。


三维空间下//代码效果参考:http://www.lyjsj.net.cn/wz/art_22834.html

直角坐标与球坐标的相互转换

直接坐标转球坐标





球坐标转直角坐标





基于Flex的坐标转换实现


直角坐标定义类CartesianCoord.cs


?12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849package hans_gis.coord{ public class CartesianCoord { public var x:Number; public var y:Number; public var z:Number; static private var temp:CartesianCoord = CartesianCoord.ZERO; public function CartesianCoord(x:Number=0, y:Number=0, z:Number=0) { this.x = x; this.y = y; this.z = z; } public function //代码效果参考:http://www.lyjsj.net.cn/wz/art_22832.html

clone():CartesianCoord { return new CartesianCoord(this.x, this.y, this.z); } public function copyTo(n:CartesianCoord):void { n.x = this.x; n.y = this.y; n.z = this.z; } public function copyFrom(n:CartesianCoord):void { this.x = n.x; this.y = n.y; this.z = n.z; } public function reset(newx:Number = 0, newy:Number = 0, newz:Number = 0):void { this.x = newx; this.y = newy; this.z = newz; } static public function get ZERO():CartesianCoord { return new CartesianCoord(0, 0, 0); } }}

球坐标定义类SphericalCoord.cs


?package hans_gis.coord{ public class SphericalCoord { public var radius:Number; public var theta:Number; public var phi:Number; static private var temp:SphericalCoord = SphericalCoord.ZERO; public function SphericalCoord(radius:Number=0, theta:Number=0, phi:Number=0) { this.radius = radius; this.theta = theta; this.phi = phi; } public function clone():SphericalCoord { return new SphericalCoord(this.radius, this.theta, this.phi); } public function copyTo(n:SphericalCoord):void { n.radius = this.radius; n.theta = this.theta; n.phi = this.phi; } public function copyFrom(n:SphericalCoord):void { this.radius = n.radius; this.theta = n.theta; this.phi = n.phi; } public function reset(newradius:Number = 0, newtheta:Number = 0, newphi:Number = 0):void { this.radius = newradius; this.theta = newtheta; this.phi = newphi; } static public function get ZERO():SphericalCoord { return new SphericalCoord(0, 0, 0); } }}


坐标转换定义类CoordsTransform.cs


?package hans_gis.coord{ public class CoordsTransform { public function CoordsTransform() { } public function CartesianToSpherical(coord:CartesianCoord):SphericalCoord{ var radius = this.GetModuloFromCartesianCoord(coord); var theta = this.GetThetaFromCartesianCoord(coord); var phi = this.GetPhiFromCartesianCoord(coord); return new SphericalCoord(radius, theta, phi);<div class="line number14 index13

相关文章
|
人工智能 搜索推荐 算法
豆包角色制作指南
这篇文章是一份豆包角色制作指南,介绍了如何使用虚拟角色生成器创建IP或非IP角色,以及创作对话人物sp的技巧和Bot主动发消息的技巧。
|
数据采集 数据可视化 数据挖掘
数据清洗有什么方式
数据清洗有什么方式
|
机器学习/深度学习 存储 人工智能
基于内容的图像检索系统设计与实现(1)
基于内容的图像检索系统设计与实现(1)
基于内容的图像检索系统设计与实现(1)
|
10月前
|
存储 边缘计算 物联网
探索边缘计算在物联网时代的无限可能
探索边缘计算在物联网时代的无限可能
272 94
|
7月前
|
Web App开发 编解码 vr&ar
Deepseek解读 | UE像素流送与实时云渲染技术的差别
为了实现UE引擎开发的3D/XR程序推流,开发者通常使用像素流送(Pixel Streaming)技术。它通过WebRTC协议将服务器端渲染的画面传输到客户端,适用于短时、少并发场景。然而,在项目落地阶段,其局限性显现,实时云渲染方案成为更好的选择。Deepseek分析表明,实时云渲染具备高性能分布式渲染、低延迟传输、多平台支持等优势,特别适合高复杂度场景和大规模应用。Paraverse平行云的LarkXR产品,作为领先的实时云渲染解决方案,提供高质量、低延迟的渲染体验,支持多种3D引擎和XR内容格式,具备弹性扩展和成本优化等特点,广泛应用于元宇宙、虚拟仿真等领域。
|
9月前
|
SQL 自然语言处理 IDE
LLM的IDE使用一段时间后的体会
使用Windsurf开发Web应用,全程无需手写代码,仅通过自然语言交流指导大模型完成任务。初期体验流畅高效,尤其适合快速实现小规模项目。然而,面对需求变更时,代码设计易受影响,需细致指导大模型以保持良好设计。整体而言,LLM辅助编程如同结对编程中的导航员角色,用户需提升自身指导能力以发挥其最大效能。
305 0
LLM的IDE使用一段时间后的体会
|
监控 安全 测试技术
确保第三方API安全的5个最佳实践
确保第三方API安全的5个最佳实践
|
Windows
在VsCode上调试Cocos2d-x lua项目
在VsCode上调试Cocos2d-x lua项目
1389 0
|
移动开发 小程序 JavaScript
【经验分享】记一次支付宝小程序的性能优化
【经验分享】记一次支付宝小程序的性能优化
436 7
|
Shell Windows
PowerToys 微软高效工具包 使用指南
高效的工具 往往都是可以借助一些实用的工具的 下面PowerToys 也拥有许多我们生活工作中 常用的一些功能。
PowerToys 微软高效工具包  使用指南