UEC++碰撞预设和粒子特效激活/失效

1.写在构造函数里Actor.cpp

AMyActor::AMyActor(){

	PrimaryActorTick.bCanEverTick = true;

	//碰撞预设(碰撞已启用)
	MyBox->SetCollisionEnabled(ECollisionEnabled::NoCollision);//无碰撞
	MyBox->SetCollisionEnabled(ECollisionEnabled::QueryOnly);//纯查询(无物理碰撞)
	MyBox->SetCollisionEnabled(ECollisionEnabled::PhysicsOnly);//纯物理(不查询碰撞)
	MyBox->SetCollisionEnabled(ECollisionEnabled::QueryAndPhysics);//已启用碰撞(查询和物理)
	MyBox->SetCollisionEnabled(ECollisionEnabled::ProbeOnly);//仅探测(接触数据,无查询或物理碰撞)
	MyBox->SetCollisionEnabled(ECollisionEnabled::QueryAndProbe);//查询和探测(查询碰撞和接触数据,无物理碰撞)
	//碰撞预设(对象类型)
	MyBox->SetCollisionObjectType(ECC_WorldStatic);//世界静态
	MyBox->SetCollisionObjectType(ECC_WorldDynamic);//世界动态
	MyBox->SetCollisionObjectType(ECC_Pawn);//Pawn
	MyBox->SetCollisionObjectType(ECC_PhysicsBody);//物理体
	MyBox->SetCollisionObjectType(ECC_Vehicle);//车辆
	MyBox->SetCollisionObjectType(ECC_Destructible);//破裂体
	//碰撞预设(碰撞响应)
	MyBox->SetCollisionResponseToAllChannels(ECR_Block);//对所有通道设置响应为阻挡
	MyBox->SetCollisionResponseToAllChannels(ECR_Overlap);//对所有通道设置响应为重叠
	MyBox->SetCollisionResponseToAllChannels(ECR_Ignore);//对所有通道设置响应为忽略
	MyBox->SetCollisionResponseToChannel(ECC_Pawn, ECR_Overlap);//对单个通道设置响应为重叠
	MyBox->SetCollisionResponseToChannel(ECC_WorldStatic, ECR_Block);//对单个通道设置响应为阻挡
	MyBox->SetCollisionResponseToChannel(ECC_WorldDynamic, ECR_Ignore);//对单个通道设置响应为忽略
}

2.1构造函数里设置

AMyActor::AMyActor()
{
 	// 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;

	//设置盒体范围
	MyBox->SetBoxExtent(FVector(64, 64, 64));
}

2.2在开始里写默认失效

void AMyActor::BeginPlay()
{
	Super::BeginPlay();
	//默认失效
	if (MyParticle) {
		MyParticle->Deactivate();
	}

	//盒体碰撞组件->BeginOverlap事件代理绑定
	MyBox->OnComponentBeginOverlap.AddDynamic(this, &AMyActor::BeginOverlapFunction);
	MyBox->OnComponentEndOverlap.AddDynamic(this, &AMyActor::EndOverlapFunction);
	//盒体碰撞组件->Hit事件代理绑定
	MyBox->OnComponentHit.AddDynamic(this, &AMyActor::HitFunction);
}

2.3写上激活和失效函数

void AMyActor::BeginOverlapFunction(UPrimitiveComponent* OverlappedComponent, AActor* OtherActor, UPrimitiveComponent* OtherComp, int32 OtherBodyIndex, bool bFromSweep, const FHitResult& SweepResult){
	MyParticle->Activate();//特效激活
	GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("BeginOverLapEvent is success"));
}

void AMyActor::EndOverlapFunction(UPrimitiveComponent* OverlappedComponent, AActor* OtherActor, UPrimitiveComponent* OtherComp, int32 OtherBodyIndex){
	MyParticle->Deactivate();//特效失效
	GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Red, TEXT("EndOverLapEvent is success"));
}

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
引用\[1\]中的代码展示了使用vector来创建一个二维数组,并使用resize函数来指定数组的大小。而引用\[2\]中的代码则展示了另一种创建二维数组的方法,直接在vector的构造函数中指定数组的大小。这两种方法都可以用来创建二维数组,只是在语法上稍有不同。 UEC++中的数组和vector的区别在于它们的实现方式和功能。数组是一种固定大小的数据结构,它在内存中是连续存储的,可以通过索引来访问元素。而vector是一种动态数组,它可以根据需要自动调整大小,并且可以在任意位置插入或删除元素。 另外,数组的大小在编译时就确定了,而vector的大小可以在运行时动态改变。这使得vector更加灵活,可以根据实际需求来动态管理内存。 此外,vector还提供了一些方便的成员函数,如push_back和pop_back,可以在数组的末尾插入和删除元素。而数组则没有这些功能,需要手动实现。 总结来说,数组适用于固定大小的数据集合,而vector适用于需要动态管理大小的数据集合。在UEC++中,使用数组还是vector取决于具体的需求和使用场景。 #### 引用[.reference_title] - *1* *2* [C++容器嵌套实现动态二维数组(Vector2D)](https://blog.csdn.net/diezhai9068/article/details/101201579)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [UEC++ FString的那些事](https://blog.csdn.net/Ez_coder/article/details/118530317)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Woody_Dark

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值