6、倾斜摄影的osgb数据坐标和虚幻引擎的世界坐标的互转

1、首先明确一点,倾斜摄影的osgb文件内包含的数据都是局部坐标系下的坐标,而这个局部坐标系的原点会在倾斜摄影数据的配置文件中标明(一般是在Data文件夹同级别目录下的metatdata.xml文件中)

2、局部坐标系下的转换

局部坐标系下的坐标转换就是直接将osgb的顶点坐标转换为虚幻的坐标,但是两者都是在局部坐标下下的坐标,不同的是前者是osg引擎中的局部坐标系,后者是虚幻引擎的局部坐标。

c 复制代码
//虚幻坐标转osg坐标
auto ConvertUECoordinate2OSGCoordinate = [](FVector point) {
	//虚幻坐标系的单位是厘米,但是osg的单位是米
	double X = point.X / 100.0;
	//虚幻坐标系的y轴和osg的y轴是相反的
	double Y = -point.Y / 100.0;
	double Z = point.Z / 100.0;
	return osg::Vec3f(X, Y, Z);
	};
//osg坐标转虚幻坐标
auto ConvertOSGCoordinate2UECoordinate = [](osg::Vec3f point) {
    double X = point.x() * 100.0;
    double Y = -point.y() * 100.0;
    double Z = point.z() * 100.0;
    return FVector(X, Y, Z);
};

3、世界坐标系下的转换

借助前面的方法已经得到了虚幻或osg的局部坐标下的坐标,同理,只要将局部坐标系的坐标原点(其在某个引擎的世界坐标系下的坐标)也转换到osg或虚幻引擎的坐标,即得到转换后的坐标原点(在另一个引擎的世界坐标下下的坐标),坐标原点+转换后的局部坐标=最终的转换后的世界坐标。

当然也可以在转换前就计算好osg或虚幻引擎的世界坐标,借助前面的方法得到虚幻或osg引擎的世界坐标。

相关推荐
深邃-1 小时前
【数据结构与算法】-二叉树(2):实现顺序结构二叉树(堆的实现),向上调整算法,向下调整算法,堆排序,TOP-K问题
数据结构·算法·二叉树·排序算法·堆排序··top-k
We་ct4 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
王老师青少年编程8 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮8 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说8 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
郑寿昌8 小时前
UE5与UE6在Lumen和Nanite的差异解析
游戏引擎·图形渲染·着色器
wuweijianlove9 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung10 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了10 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL10 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化