UE C++ 相机视口变换(World与相机互转)

UE C++ 相机视口变换(World与相机互转)

UFUNCTION(BlueprintCallable, BlueprintPure)
static void ProjectSceneCaptureToWorld(const class USceneCaptureComponent2D* SceneCaptureComponent2D,const FVector2D& SceneCapturePosition, FVector& WorldPosition,FVector& WorldDirection)
{if (!IsValid(SceneCaptureComponent2D)){return;}// 视口矩阵const FTransform& ViewTransform = SceneCaptureComponent2D->GetComponentToWorld();FMatrix ViewMatrix = ViewTransform.ToInverseMatrixWithScale();ViewMatrix = ViewMatrix * FMatrix(FPlane(0, 0, 1, 0), FPlane(1, 0, 0, 0), FPlane(0, 1, 0, 0),FPlane(0, 0, 0, 1));const float FOV = SceneCaptureComponent2D->FOVAngle * (float)PI / 360.0f;const FIntPoint CaptureSize(SceneCaptureComponent2D->TextureTarget->GetSurfaceWidth(),SceneCaptureComponent2D->TextureTarget->GetSurfaceHeight());float XAxisMultiplier;float YAxisMultiplier;if (CaptureSize.X > CaptureSize.Y){XAxisMultiplier = 1.0f;YAxisMultiplier = CaptureSize.X / static_cast<float>(CaptureSize.Y);}else{XAxisMultiplier = CaptureSize.Y / static_cast<float>(CaptureSize.X);YAxisMultiplier = 1.0f;}// 投影矩阵const FMatrix ProjectionMatrix = FReversedZPerspectiveMatrix(FOV, FOV, XAxisMultiplier, YAxisMultiplier,GNearClippingPlane, GNearClippingPlane);//视口矩阵与投影矩阵的逆矩阵                                                           const FMatrix InverseViewMatrix = ViewMatrix.InverseFast();const FMatrix InverseProjectionMatrix = ProjectionMatrix.Inverse();const FIntRect ViewRect = FIntRect(0, 0, CaptureSize.X, CaptureSize.Y);FSceneView::DeprojectScreenToWorld(SceneCapturePosition, ViewRect, InverseViewMatrix, InverseProjectionMatrix,WorldPosition, WorldDirection);
}
	UFUNCTION(BlueprintCallable, BlueprintPure)static bool ProjectWorldToSceneCapture(const FVector& WorldPosition,const class USceneCaptureComponent2D* SceneCaptureComponent2D,FVector2D& SceneCapturePosition){if (!IsValid(SceneCaptureComponent2D)){return false;}//视口矩阵const FTransform& ViewTransform = SceneCaptureComponent2D->GetComponentToWorld();FMatrix ViewMatrix = ViewTransform.ToInverseMatrixWithScale();ViewMatrix = ViewMatrix * FMatrix(FPlane(0, 0, 1, 0), FPlane(1, 0, 0, 0), FPlane(0, 1, 0, 0),FPlane(0, 0, 0, 1));const float FOV = SceneCaptureComponent2D->FOVAngle * (float)PI / 360.0f;const FIntPoint CaptureSize(SceneCaptureComponent2D->TextureTarget->GetSurfaceWidth(),SceneCaptureComponent2D->TextureTarget->GetSurfaceHeight());float XAxisMultiplier;float YAxisMultiplier;if (CaptureSize.X > CaptureSize.Y){XAxisMultiplier = 1.0f;YAxisMultiplier = CaptureSize.X / static_cast<float>(CaptureSize.Y);}else{XAxisMultiplier = CaptureSize.Y / static_cast<float>(CaptureSize.X);YAxisMultiplier = 1.0f;}// 投影矩阵const FMatrix ProjectionMatrix = FReversedZPerspectiveMatrix(FOV, FOV, XAxisMultiplier, YAxisMultiplier,GNearClippingPlane, GNearClippingPlane);const FMatrix ViewProjectionMatrix = ViewMatrix * ProjectionMatrix;const FPlane Result = ViewProjectionMatrix.TransformFVector4(FVector4(WorldPosition, 1.f));const FIntRect viewRect = FIntRect(0, 0, CaptureSize.X, CaptureSize.Y);if (Result.W > 0.0f){// the result of this will be x and y coords in -1..1 projection spaceconst float RHW = 1.0f / Result.W;const FPlane PosInScreenSpace = FPlane(Result.X * RHW, Result.Y * RHW, Result.Z * RHW, Result.W);// Move from projection space to normalized 0..1 UI spaceconst float NormalizedX = (PosInScreenSpace.X / 2.f) + 0.5f;const float NormalizedY = 1.f - (PosInScreenSpace.Y / 2.f) - 0.5f;const FVector2D RayStartViewRectSpace((NormalizedX * static_cast<float>(viewRect.Width())),(NormalizedY * static_cast<float>(viewRect.Height())));SceneCapturePosition = RayStartViewRectSpace + FVector2D(static_cast<float>(viewRect.Min.X),static_cast<float>(viewRect.Min.Y));return true;}return false;}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/752987.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Docker常见指令

1.docker search mysql &#xff1a;从docker镜像仓库搜索和mysql有关的镜像 docker search mysql 2.docker pull mysql &#xff1a;从docker仓库拉取mysql镜像 docker pull mysql 3.docker run mysql &#xff1a;启动mysql镜像 docker run mysql 4.docker ps &#xff…

【通信原理笔记】【二】随机信号分析——2.4 复随机过程

文章目录 前言一、复随机过程1.1定义1.2 复平稳过程 二、平稳带通过程分析2.1 解析过程2.2 随机过程的复包络 三、平稳序列与循环平稳总结 前言 目前为止&#xff0c;我们对实随机过程的分析方法已经基本掌握了。像复信号一样&#xff0c;我们也会有需要处理复随机过程的时候&…

工业母机5G智能制造工厂数字孪生可视化平台,推进行业数字化转型

随着科技的不断进步和工业的快速发展&#xff0c;数字化转型已成为工业领域的重要趋势。工业母机作为制造业的核心设备&#xff0c;其智能化、自动化水平的提升对于整个工业的发展具有重要意义。5G技术的广泛应用&#xff0c;为智能制造工厂提供了更为可靠、高速的网络连接&…

OSError: We couldn‘t connect to ‘https://huggingface.co‘ to load this file

想折腾bert的同学&#xff0c;应该也遇到这个问题。 一、报错信息分析 完整报错信息&#xff1a;OSError: We couldnt connect to https://huggingface.co to load this file, couldnt find it in the cached files and it looks like google/mt5-small is not the path to a…

力扣刷题Days20-151. 反转字符串中的单词(js)

目录 1,题目 2&#xff0c;代码 1&#xff0c;利用js函数 2&#xff0c;双指针 3&#xff0c;双指针加队列 3&#xff0c;学习与总结 1&#xff0c;正则表达式 / \s /&#xff1a; 2&#xff0c;结合使用 split 和正则表达式&#xff1a; 1,题目 给你一个字符串 s &am…

Docker学习之使用harbor搭建私有仓库(超详解析)

实验目的&#xff1a; 使用centos7&#xff0c;基于harbor构建私有仓库 实验步骤&#xff1a; 下载相关安装包和依赖&#xff1a; [rootlocalhost ~]# yum install -y yum-utils device-mapper-persistent-data lvm2 wget //安装docker所需要的相关依赖 [rootlocalhost ~]#…

PaddleOCR识别框架解读[14] OCR数据集

文章目录 1. 文本检测1.1 PaddleOCR 文字检测数据格式1.2 公开数据集1.2.1 ICDAR 20152. 文本识别2.1 PaddleOCR 文字识别数据格式2.2 公开数据集2.2.1 ICDAR 20153. 数据存放路径这里整理了OCR中常用的公开数据集,持续更新中,欢迎各位小伙伴贡献数据集~ 1. 文本检测 1.1 P…

山景BP1048 升级狗烧写

1.打开MVAssistant_BP10xx工具&#xff0c;在芯片型号栏中选择B1X系列。 2.模式选择 选 M2.仅升级Flash SH(可选) 3 .Code数据选择SDK编译好的bin文件 4.const数据选择编译好的提示音bin文件。 5.点击升级狗下载。 6. 如下图所示&#xff0c;出现提示为正在给升级狗正在下载程…

git pull 报错: 在签出前,请清理存储库工作树

问题&#xff1a; 使用vscode 用git 拉取代码&#xff0c;提示&#xff1a;在签出前&#xff0c;请清理存储库工作树** 原因&#xff1a; git仓库上的代码和本地代码存在冲突了所以会报这个报错。 解决办法&#xff1a; ①git stash 先将本地修改存储起来 ②git pull 拉取远…

创新应用2:nnmf+DBO+K-Medoids聚类,蜣螂优化算法DBO优化K-Medoids,适合学习和发paper。

创新应用2&#xff1a;nnmfDBOK-Medoids聚类&#xff0c;蜣螂优化算法DBO优化K-Medoids&#xff0c;适合学习和发paper。 一、蜣螂优化算法 摘要&#xff1a;受蜣螂滚球、跳舞、觅食、偷窃和繁殖等行为的启发&#xff0c;提出了一种新的基于种群的优化算法(Dung Beetle Optim…

多个图片怎么变成一张动图?一个方法在线操作

如何将图片变成gif动画&#xff1f;gif动图文件体积、画面丰富兼容性也比较高。通过多张静图就能够制作一张gif动画&#xff0c;能够自己制作生动有趣的gif动态图片能更好的传达信息。只需要使用在线图片合成&#xff08;https://www.gif.cn/&#xff09;工具&#xff0c;上传j…

【C语言基础】:字符函数和字符串函数

文章目录 一、字符函数1. 字符分类函数2. 字符转化函数 二、字符串函数1. strlen函数的使用和模拟实现strlen函数的使用strlen函数的模拟实现 2. strcpy函数的使用和模拟实现strcpy函数的使用strcpy函数的模拟实现 3. strcat函数的使用和模拟实现strcat函数的使用strcat函数的模…

el-table树形数据序号排序处理

1&#xff0c;用下面这个代码可以实现基本表格的序号排序 <el-table-column label"序号" width"50px" align"center"><template slot-scope"scope">{{ scope.$index 1 }}</template></el-table-column>2&…

【LeetCode热题100】104. 二叉树的最大深度(二叉树)

一.题目要求 给定一个二叉树 root &#xff0c;返回其最大深度。 二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。 二.题目难度 简单 三.输入样例 示例 1&#xff1a; 输入&#xff1a;root [3,9,20,null,null,15,7] 输出&#xff1a;3 示例 2&am…

训练数据集(一):真实场景下采集的煤矸石目标检测数据集,可直接用于YOLOv5/v6/v7/v8训练

文章目录 数据集介绍数据集训练精度展示数据集获取方式 数据集介绍 煤矸石训练数据集&#xff1a;891张&#xff1b;验证数据数据集&#xff1a;404张 数据集类别&#xff1a;0代表煤炭&#xff08;coal&#xff09;&#xff0c;1代表矸石&#xff08;gangue&#xff09;&…

Git reset命令后如何恢复到最新版本

文章目录 Git reset命令后如何恢复到最新版本使用git reflog命令使用git checkout命令 总结 Git reset命令后如何恢复到最新版本 Git reset命令后&#xff0c;可以使用以下两种方法恢复到最新版本&#xff1a; 使用git reflog命令 git reflog该命令可以查看所有Git操作的记录…

【C语言】比较两个字符串大小,strcmp函数

目录 一&#xff0c;strcmp函数 1&#xff0c;strcmp函数 2&#xff0c;函数头文件&#xff1a; 3&#xff0c;函数原型&#xff1a; 4&#xff0c;返回取值&#xff1a; 二&#xff0c;代码实现 三&#xff0c;小结 一&#xff0c;strcmp函数 1&#xff0c;strcmp函数 …

docxTemplater——从word模板生成docx文件

官网文档&#xff1a;Get Started (Browser) | docxtemplater 官网在线演示&#xff1a;Demo of Docxtemplater with all modules active | docxtemplater 源码&#xff1a;https://github.com/open-xml-templating/docxtemplater 不仅可以处理word&#xff08;免费&#xf…

【ArcGIS 脚本工具】强制移动要素类,绕过空间参考不一致

作为一个合格的数据管家&#xff0c;自然要让自己的数据库井井有条。 于是想着整理一下数据库里面的七零八落的要素类&#xff0c;按 数据库-要素数据集-要素类 的方式整理。 但是将要素类移动到要素数据集内的时候经常会出现下面的报错。 这大概率是因为要素类的坐标系与目标…

使用ChatGPT高效完成简历制作[中篇2]-有爱AI实战教程(九)

演示站点&#xff1a; https://ai.uaai.cn 对话模块 官方论坛&#xff1a; www.jingyuai.com 京娱AI 一、导读&#xff1a; 在使用 ChatGPT 时&#xff0c;当你给的指令越精确&#xff0c;它的回答会越到位&#xff0c;举例来说&#xff0c;假如你要请它帮忙写文案&#xff0c…