虚幻学习笔记16—C++和3DUI(二)

这篇具有很好参考价值的文章主要介绍了虚幻学习笔记16—C++和3DUI(二)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、前言

        上一篇虚幻学习笔记15—C++和UI(一)中介绍了通过C++代码创建2D的ui,本章主要讲解怎么用C++代码创建3D的UI,在虚幻学习笔记3—UI跟随弹窗这章中讲解了怎样用蓝图创建一个3D的UI,并且和其交互。

        本系列使用的虚幻5.2.1,vs2022。

二、实现

        本案例中通过创建一个第三人称人物头顶的血条案例来进行说明。

2.1、创建3DUI内容

  1、创建一个“My3DWidget”类,在其中创建两个变量,代码如下

	UPROPERTY(EditAnywhere, BlueprintReadWrite, Category = "My3DUI")
	float CurHealth = 100.0f;
	UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "MyInput")
	float	MaxHealth = 100.0f;

2、然后创建一个控件蓝图添加一个进度条,如图2.1.1所示,然后将其呈现的宽度和高度设置一

虚幻学习笔记16—C++和3DUI(二),虚幻,ue5,unreal engine
图2.1.1

下,并将其锚点设置为平铺,这样就会将进度条完整的呈现在3DUI区域,不会有间隙等出现。

3、将新建的蓝图的“类设置”中的父类设置为刚刚创建的“My3DWidget”类,并且将进度条的值进行绑定,绑定的蓝图设置如图2.1.2所示,即将当前血量除以最大血量(这一步对于后续显示3D效果没什么影响,不设置也可以)。

虚幻学习笔记16—C++和3DUI(二),虚幻,ue5,unreal engine
2.1.2
2.2、在C++中加载3DUI

1、创建一个Character类,命名为“MyCharacter1”,在这个类里面将加载之前创建的3DUI蓝图,首先需要在头文件中定义该类型的变量,代码如下。

//加载UI的头文件
#include "Components/WidgetComponent.h"

//定义的变量
	//3DUI
	UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "My3DUI")
	UWidgetComponent* My3DUI;

2、然后再在构造函数中加载2.1创建的蓝图,代码如下:其中“"/Script/UMGEditor.WidgetBlueprint'/Game/BluePrint/UI3D.UI3D_C'"为2.1中创建的蓝图的引用,注意后面一定要加上后缀”_C“。

	My3DUI = CreateDefaultSubobject<UWidgetComponent>(TEXT("My3DUI"));
	My3DUI->SetupAttachment(RootComponent);
	static ConstructorHelpers::FClassFinder<UUserWidget>tempUICalss(TEXT("/Script/UMGEditor.WidgetBlueprint'/Game/BluePrint/UI3D.UI3D_C'"));
	My3DUI->SetWidgetClass(tempUICalss.Class);
	My3DUI->SetRelativeLocation(FVector(0, 0, 100));
	My3DUI->SetWidgetSpace(EWidgetSpace::Screen);
	My3DUI->SetDrawSize(FVector2D(400, 20));

3、编译成功后创建一个“MyCharacter1”类型的蓝图“BP_MyCharacter1”,在蓝图中添加一个静态网格,并且将一个人物网格给它并调整其网格和父组件的相对位置,最后将其拖放到场景中运行即可看到3DUI血条始终跟随人物的效果,如图2.2.1所示

虚幻学习笔记16—C++和3DUI(二),虚幻,ue5,unreal engine
图2.2.1

4、如果将屏幕空间设置成场景,代码如下

	My3DUI->SetWidgetSpace(EWidgetSpace::World);

这样3DUI血条不会一直朝向摄像机,会出现看到其侧面设置背面的情况,如图2.2.2所示

虚幻学习笔记16—C++和3DUI(二),虚幻,ue5,unreal engine
图2.2.2

三、总结

3.1、3DUI通过蓝图进行创建,然后在其他类中加载作为子物体,最后呈现也只能创建一个新的蓝图来呈现,这样有点饶,其实把这里的C++类作为模板,蓝图作为实例或对象即可。

3.2、UI的空间包含屏幕和世界两个,呈现的效果是不一样的,屏幕会始终将正面朝向摄像机,世界其正面是固定的,会看到UI的背面和侧面。文章来源地址https://www.toymoban.com/news/detail-791288.html

到了这里,关于虚幻学习笔记16—C++和3DUI(二)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • UE4(Unreal Engine4)虚幻引擎视口布局,并且自定义HDRI

    在UE4中搭建电影级场景。先看下效果 (1)在UE4(Unreal Engine4)中安装 Quixel Bridge Megascans bridget插件 具体操作:请看我这篇博文:Quixel Bridge Megascans bridget插件 (2)素材准备: Quixel Bridge (1)创建关卡 (2)设置过场动画 (3)加入HDRI背景 (4)重置曝光 (5)组装资源 石头 蘑菇

    2023年04月08日
    浏览(54)
  • UE4--3DUI

    在要添加的物体中添加Widget组件 Space:渲染位置(World:渲染到世界,一般用于3D,Screen:渲染到屏幕:一般用于2D) Widget Class:要渲染的对象(渲染那个UI界面)  Draw at Desired Size:理想大小     当需要用户与3DUI进行交互时,需要添加WidgetInteraction组件 需要调整方向,让组

    2024年02月16日
    浏览(50)
  • UE4 3DUI显示与交互案例

    实现效果:   实现步骤: 1.打开一个第一人称游戏模板,创建控件蓝图,命名为 全自动_UMG    2.双击打开全自动_UMG,创建两个按钮  3.新建一个蓝图,命名为3DUI_test   4.双击打开3DUI_test,添加一个控件组件    5.选中widget组件,控件类选为全自动_UMG  6.选中widget,设置绘制大

    2023年04月18日
    浏览(45)
  • 《使用Unreal Engine Python插件进行UE4中的Python开发》学习笔记1

    ·本文为B站系列教学视频 《使用 UnrealEnginPython 插件进行UE4中的Python开发》 ——《 Day 01 初识 UnrealEnginePython 》的学习笔记,UP主为腾讯游戏策划、虚幻社区贡献者 世欺子。 本节课对基于虚幻引擎( Unreal Engine )的 Python 集成开发插件 UnrealEnginePython 进行简要介绍,接着在虚幻

    2024年04月11日
    浏览(62)
  • 【虚幻引擎】UE5 C++编译和打包失败的原因

    解决办法一:可以去官网下载https://dotnet.microsoft.com/en-us/download/dotnet/3.1   解决方案二:打开Visual Studio Installer,选择单个组件,勾选NET Core 3.1 原因:这是由于更新版本到5.03的时候, 产生的 解决办法一:使用低版本 解决办法二:使用低版本的TP_VirtualRealityBP.upack,替换这个报

    2024年02月03日
    浏览(66)
  • Unreal Engine 虚幻引擎,性能分析,优化(二)

    目录 一、CPU 性能分析 二、GPU性能分析 三、Memory内存使用 一、CPU 性能分析 如渲染线程中出现 CPU 受限,原因可能是绘制调用过多。这是一个常见问题,美术师通常会将绘制调用进行组合,从而减少消耗(如:将多个墙壁组合为一个网格体)。实际消耗存在于多个区域中:

    2024年02月05日
    浏览(59)
  • 虚幻引擎图文笔记:项目升级到虚幻5(UE5.0.1)以后出现奇怪阴影问题的解决办法

    UE5.0.1 奇怪的阴影的解决办法 奇怪阴影问题解决

    2024年02月15日
    浏览(49)
  • 【虚幻引擎UE】UE5 实现相机录制视频并导出(C++基于OpenCV生成视频合成exe)

    说明: 该功能暂不支持导出声音。 由于OpenCV3和UE5不太兼容,因此考虑制作外部exe实现视频合成。 1、实现 SavePicToFile 导出图片蓝图函数 .cpp文件

    2024年02月15日
    浏览(101)
  • UE5 C++学习笔记 常用宏的再次理解

    1.随意创建一个类,他都有UCLASS()。GENERATED_BODY()这样的默认的宏。 UCLASS() 告知虚幻引擎生成类的反射数据。类必须派生自UObject. (告诉引擎我是从远古大帝UObject中,继承而来,我们是一家人,只是我进化了其他功能) GENERATED_BODY()表示我们不直接使用父类的构造函数,如果我

    2024年01月20日
    浏览(49)
  • 《UE5_C++多人TPS完整教程》学习笔记15 ——《P16 会话接口委托(Session Interface Delegates)》

    本文为B站系列教学视频 《UE5_C++多人TPS完整教程》 —— 《P16 会话接口委托(Session Interface Delegates)》 的学习笔记,该系列教学视频为 Udemy 课程 《Unreal Engine 5 C++ Multiplayer Shooter》 的中文字幕翻译版,UP主(也是译者)为 游戏引擎能吃么。 本节课我们将向新创建的子系统添

    2024年02月20日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包