UE4C++_常用的两个Debug的方法

38 篇文章 5 订阅
26 篇文章 0 订阅
   UE4_LOG(LogTemp,Warning,TEXT("StartOnConsole"));

这里写图片描述

 GEngine->AddOnScreenDebugMessage(-1, 5.0f, FColor::Black, TEXT("Begin123"));
好的,以下是一个简单的UE4 C++代码示例,用于触发门的开启事件: 首先,创建一个继承自Actor的蓝图类,将门模型拖放到该类中,并为门添加一个Box组件作为门的触发器。 在.h文件中添加以下代码: ```c++ #pragma once #include "CoreMinimal.h" #include "GameFramework/Actor.h" #include "MyDoor.generated.h" UCLASS() class MYPROJECT_API AMyDoor : public AActor { GENERATED_BODY() public: AMyDoor(); protected: UPROPERTY(VisibleAnywhere, Category = "Components") class UStaticMeshComponent* DoorMesh; UPROPERTY(VisibleAnywhere, Category = "Components") class UBoxComponent* TriggerBox; UPROPERTY(EditAnywhere, Category = "Properties") float OpenAngle = 90.0f; UPROPERTY(EditAnywhere, Category = "Properties") float DoorCloseDelay = 2.0f; float LastDoorOpenTime; UPROPERTY(EditAnywhere, Category = "Properties") float DoorOpenSpeed = 0.8f; UPROPERTY(EditAnywhere, Category = "Properties") float DoorCloseSpeed = 2.0f; UFUNCTION() void OnDoorOverlapBegin(class AActor* OverlappedActor, class AActor* OtherActor); UFUNCTION() void OnDoorOverlapEnd(class AActor* OverlappedActor, class AActor* OtherActor); public: virtual void Tick(float DeltaTime) override; }; ``` 在.cpp文件中添加以下代码: ```c++ #include "MyDoor.h" #include "Components/StaticMeshComponent.h" #include "Components/BoxComponent.h" AMyDoor::AMyDoor() { PrimaryActorTick.bCanEverTick = true; DoorMesh = CreateDefaultSubobject<UStaticMeshComponent>(TEXT("DoorMesh")); RootComponent = DoorMesh; TriggerBox = CreateDefaultSubobject<UBoxComponent>(TEXT("TriggerBox")); TriggerBox->SetupAttachment(RootComponent); TriggerBox->OnComponentBeginOverlap.AddDynamic(this, &AMyDoor::OnDoorOverlapBegin); TriggerBox->OnComponentEndOverlap.AddDynamic(this, &AMyDoor::OnDoorOverlapEnd); LastDoorOpenTime = 0.0f; } void AMyDoor::Tick(float DeltaTime) { Super::Tick(DeltaTime); if (GetWorld()->TimeSeconds - LastDoorOpenTime > DoorCloseDelay) { float CurrentYaw = DoorMesh->GetComponentRotation().Yaw; float TargetYaw; if (CurrentYaw > 0) { TargetYaw = 0.0f; } else { TargetYaw = OpenAngle; } float NewYaw = FMath::FInterpTo(CurrentYaw, TargetYaw, DeltaTime, DoorCloseSpeed); DoorMesh->SetRelativeRotation(FRotator(0.0f, NewYaw, 0.0f)); } } void AMyDoor::OnDoorOverlapBegin(class AActor* OverlappedActor, class AActor* OtherActor) { if (OtherActor && OtherActor != this) { LastDoorOpenTime = GetWorld()->TimeSeconds; float CurrentYaw = DoorMesh->GetComponentRotation().Yaw; float NewYaw = FMath::FInterpTo(CurrentYaw, OpenAngle, GetWorld()->DeltaTimeSeconds, DoorOpenSpeed); DoorMesh->SetRelativeRotation(FRotator(0.0f, NewYaw, 0.0f)); } } void AMyDoor::OnDoorOverlapEnd(class AActor* OverlappedActor, class AActor* OtherActor) { if (OtherActor && OtherActor != this) { LastDoorOpenTime = GetWorld()->TimeSeconds; } } ``` 这个代码示例中,我们添加了一个门模型和一个Box组件用作门的触发器。在Box组件上注册了OnComponentBeginOverlap和OnComponentEndOverlap事件,当有物体进入或离开Box时,将触发相应的事件。在OnDoorOverlapBegin事件中,我们通过插值将门旋转到开启的角度,并在LastDoorOpenTime中存储当前时间。在Tick函数中,我们检查LastDoorOpenTime是否超过DoorCloseDelay,如果是,则插值将门旋转回关闭的角度。 最后,将蓝图类添加到场景中,运行游戏并测试门的开启和关闭事件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值