当前位置: 首页 > java >正文

UEC++第15天|番茄插件、实现跳跃、实现背景运动

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这是flyBird的第二天,做了一些简单的功能,明天继续更新

vs的番茄插件

在visual stdudio里使用可以帮助代码补全,这一篇博客写的不错,大家可以参考一下。VS2019 安装番茄助手(Visual Assist x 插件)攻略_vs2019番茄助手-CSDN博客

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

实现跳跃功能

想要实现跳跃的功能,首先需要物体是开启了物理模拟的情况下,才能实现的。

使用物理模拟的APISetSimulatePhysics调整为true,实现跳跃就是添加对应的向上的力。

void ABirdPawn::DoFly()
{UE_LOG(LogTemp, Log, TEXT("DoFly"));// 开启物理模拟BirdRenderComp->SetSimulatePhysics(true);//清理原有力的速度BirdRenderComp->SetPhysicsLinearVelocity(FVector::ZeroVector);// 添加力BirdRenderComp->AddImpulse(FVector::UpVector * 400, NAME_None, true);
}

在UE中加载地板

  1. 在对应的游戏模式里面去添加ALandActor的指针。ALandActor* LandActor;;
 class ABgActor;class ALandActor;/*** */UCLASS()class FLYBIRD_API AFlyBirdGameModeBase : public AGameModeBase{GENERATED_BODY()AFlyBirdGameModeBase();protected:virtual void BeginPlay() override;protected:UPROPERTY()ABgActor* BgActor;ALandActor* LandActor;};
  1. 然后在里面去设置LandActor。
#include "FlyBirdGameModeBase.h"
#include "BirdPawn.h"
#include "Engine/World.h"
#include "BgActor.h"
#include "LandActor.h"AFlyBirdGameModeBase::AFlyBirdGameModeBase()
{DefaultPawnClass = ABirdPawn::StaticClass();
}void AFlyBirdGameModeBase::BeginPlay()
{Super::BeginPlay();BgActor =  GetWorld()->SpawnActor<ABgActor>();BgActor->SetActorLocation(FVector(0, -100,0));// 在该世界中生成指定类型actorLandActor = GetWorld()->SpawnActor<ALandActor>();LandActor->SetActorLocation(FVector(0, 0, -200));
}

3.LandActor本身的设置

#pragma once#include "CoreMinimal.h"
#include "GameFramework/Actor.h"
#include "LandActor.generated.h"class UPaperSpriteComponent;
UCLASS()
class FLYBIRD_API ALandActor : public AActor
{GENERATED_BODY()public:	// Sets default values for this actor's propertiesALandActor();protected:// Called when the game starts or when spawnedvirtual void BeginPlay() override;public:	// Called every framevirtual void Tick(float DeltaTime) override;protected:// 这里的UPROPERTY() 是让虚幻帮助我们去管理内存UPROPERTY()// 设置我们的第一块组件UPaperSpriteComponent* FirstSpriteRender;UPROPERTY()UPaperSpriteComponent* SecondSpriteRender;};
  • 设置场景组件
  • 设置依附关系
  • 如何在构造函数上添加资产
  • 调整第二块精灵的位置
#include "LandActor.h"
#include "PaperSpriteComponent.h"
#include "UObject/ConstructorHelpers.h"
#include "PaperSprite.h"// Sets default values
ALandActor::ALandActor()
{// Set this actor to call Tick() every frame.  You can turn this off to improve performance if you don't need it.PrimaryActorTick.bCanEverTick = true;// 添加空的场景组件RootComponent = CreateDefaultSubobject<USceneComponent>(TEXT("RootComp"));FirstSpriteRender = CreateDefaultSubobject<UPaperSpriteComponent>(TEXT("land1SpriteRender"));SecondSpriteRender = CreateDefaultSubobject<UPaperSpriteComponent>(TEXT("land2SpriteRender"));// 设置依附关系FirstSpriteRender->SetupAttachment(RootComponent);SecondSpriteRender->SetupAttachment(RootComponent);// 如何在构造函数上加载资产ConstructorHelpers::FObjectFinder<UPaperSprite> LandSpriteObj(TEXT("PaperSprite'/Game/FlyBird/Textures/BG/land_Sprite.land_Sprite'"));// 设置精灵资产FirstSpriteRender->SetSprite(LandSpriteObj.Object);SecondSpriteRender->SetSprite(LandSpriteObj.Object);//调整第二块精灵的位置SecondSpriteRender->SetRelativeLocation(FVector(336,0,0));
}// Called when the game starts or when spawned
void ALandActor::BeginPlay()
{Super::BeginPlay();}// Called every frame
void ALandActor::Tick(float DeltaTime)
{Super::Tick(DeltaTime);
}

让地板运动起来

依旧是修改landActor.写一个函数UpdateMove 来实现移动功能,然后定义一个变量MoveSpeed控制移动速度

#pragma once#include "CoreMinimal.h"
#include "GameFramework/Actor.h"
#include "LandActor.generated.h"class UPaperSpriteComponent;
UCLASS()
class FLYBIRD_API ALandActor : public AActor
{GENERATED_BODY()public:	// Sets default values for this actor's propertiesALandActor();protected:// Called when the game starts or when spawnedvirtual void BeginPlay() override;void UpdateMove(float DeltaTime);
public:	// Called every framevirtual void Tick(float DeltaTime) override;protected:UPROPERTY()UPaperSpriteComponent* FirstSpriteRender;UPROPERTY()UPaperSpriteComponent* SecondSpriteRender;float MoveSpeed;};

在具体实现的时候

#include "PaperSpriteComponent.h"
#include "UObject/ConstructorHelpers.h"
#include "PaperSprite.h"// Sets default values
ALandActor::ALandActor()
{// Set this actor to call Tick() every frame.  You can turn this off to improve performance if you don't need it.PrimaryActorTick.bCanEverTick = true;// 添加空的场景组件RootComponent = CreateDefaultSubobject<USceneComponent>(TEXT("RootComp"));FirstSpriteRender = CreateDefaultSubobject<UPaperSpriteComponent>(TEXT("land1SpriteRender"));SecondSpriteRender = CreateDefaultSubobject<UPaperSpriteComponent>(TEXT("land2SpriteRender"));// 设置依附关系FirstSpriteRender->SetupAttachment(RootComponent);SecondSpriteRender->SetupAttachment(RootComponent);// 如何在构造函数上加载资产ConstructorHelpers::FObjectFinder<UPaperSprite> LandSpriteObj(TEXT("PaperSprite'/Game/FlyBird/Textures/BG/land_Sprite.land_Sprite'"));// 设置精灵资产FirstSpriteRender->SetSprite(LandSpriteObj.Object);SecondSpriteRender->SetSprite(LandSpriteObj.Object);//调整第二块精灵的位置SecondSpriteRender->SetRelativeLocation(FVector(336,0,0));MoveSpeed = 200;
}// Called when the game starts or when spawned
void ALandActor::BeginPlay()
{Super::BeginPlay();}void ALandActor::UpdateMove(float DeltaTime)
{if (!FirstSpriteRender || !SecondSpriteRender) // 防止组件为空执行逻辑崩溃{return;}// 写一些移动逻辑,这里的数值是精灵资产图片的大小FirstSpriteRender->AddRelativeLocation(FVector::ForwardVector* -1 * MoveSpeed * DeltaTime);SecondSpriteRender->AddRelativeLocation(FVector::ForwardVector * -1 * MoveSpeed * DeltaTime);// 检查地板是否超出移动范围if (FirstSpriteRender->GetRelativeTransform().GetLocation().X < -336) { FirstSpriteRender->SetRelativeLocation(SecondSpriteRender->GetRelativeTransform().GetLocation() + FVector::ForwardVector * 336);}if (SecondSpriteRender->GetRelativeTransform().GetLocation().X < -336) {SecondSpriteRender->SetRelativeLocation(FirstSpriteRender->GetRelativeTransform().GetLocation() + FVector::ForwardVector * 336);}}// Called every frame
void ALandActor::Tick(float DeltaTime)
{Super::Tick(DeltaTime);UpdateMove(DeltaTime);}

遇到的问题

UPaperSpriteComponent* FirstSpriteRender; 是什么意思,为什么指针类型要为UPaperSpriteComponent?

  • 在虚幻引擎中,UPaperSpriteComponent 用于在 2D 场景中渲染精灵图像。
  • 在 2D 游戏开发中,当需要动态创建、管理或修改精灵的显示相关属性时,就会用到这种指针声明。
http://www.xdnf.cn/news/2910.html

相关文章:

  • JavaScript高级进阶(五)
  • 豪越科技消防立库方案:实现应急物资高效管理
  • 链表的中间节点
  • 机器视觉算法与应用:企业级开发全流程详解
  • Kotlin -> lateinit 和 lazy 详解
  • 嵌入式音视频实时通话EasyRTC打造设备安装与调试的高效远程解决方案
  • Nginx反向代理的负载均衡配置
  • Python入门:流程控制练习
  • 数据编辑器中变量的精妙计算与灵动转换​
  • 汽车启动原理是什么?
  • 水库现代化建设指南-水库运管矩阵管理系统建设方案
  • Linux环境变量的作用以及进程的虚拟地址原理
  • 【Tips】高效文献管理:Zotero 导入参考文献的多种方式详解
  • 【PyTorch动态计算图实战解析】从原理到高效开发
  • CSS in JS:机遇与挑战的思考
  • Java | 韩顺平 循序渐进学Java自用笔记---OOP高级
  • EPSG的作用
  • C++23中的std::forward_like:完美转发的增强
  • 第十六届蓝桥杯 2025 C/C++B组第一轮省赛 全部题解(未完结)
  • 探索目标检测:边界框与锚框的奥秘
  • leetcode 21. 合并两个有序链表(c++解法+相关知识点复习)
  • 目标检测和目标跟踪的区别与联系
  • 大前端开发——前端知识渐变分层讲解 利用金字塔原理简化前端知识体系
  • 长短期记忆网络(LSTM)
  • MySQL多表操作
  • Ansible 铸就 Linux 安全之盾(Ansible Builds Linux Security Shield)
  • 《软件测试52讲》学习笔记:如何设计一个“好的“测试用例?
  • 【学习资源】知识图谱与大语言模型融合
  • 在Mybatis中写sql的常量应用
  • 万物皆可执行:多功能机器人正在定义新生产力法则