1.获取当前的GameMode:GameMode = Cast<你GameMode的类名>( UGameplayStatics::GetGameMode(this));

2.输出日志Debug UE_LOG(LogTemp, Log, TEXT("StartPoint:%s"), *StarPoint.ToString()); %d表示按整型数据的实际长度输出数据、%c用来输出一个字符、%s用来输出一个字符串、%x表示以十六进制数形式输出整数。

3.给碰撞组件动态绑定碰撞函数:GetCapsuleComponent()->OnComponentBeginOverlap.AddDynamic(this, &你的类名::你的函数名);

4.Character键值绑定,键轴绑定:

void APacManCharacter::SetupPlayerInputComponent(UInputComponent* PlayerInputComponent)
{
Super::SetupPlayerInputComponent(PlayerInputComponent);

PlayerInputComponent->BindAxis("MoveX", this, &你的character类::MoveXAxis);
PlayerInputComponent->BindAxis("MoveY", this, &你的character类::MoveYAxis);
PlayerInputComponent->BindAction("NewGame",IE_Pressed, this, &你的character类::NewG);
PlayerInputComponent->BindAction("Restart", IE_Pressed, this, &你的character类::RS);
PlayerInputComponent->BindAction("Pause", IE_Pressed, this, &你的character类::Pa);

}

5.添加队列,遍历每个元素:定义头文件 TArray<class AEnemy*> Enemys;  在cpp里引入头文件 #include"Public/EngineUtils.h"  然后在队列里添加元素

for (TActorIterator<AEnemy> EnemyItr(GetWorld()); EnemyItr; ++EnemyItr)
{
AEnemy* enemy = Cast<AEnemy>(*EnemyItr);
if (enemy)
{
Enemys.Add(enemy);
}
}

遍历列表中的每个元素,调用每个元素的方法

for (auto Iter(Enemys.CreateIterator()); Iter; Iter++)
{
(*Iter)->Destroy();
}

6.FORCEINLINE 内联函数,目的是为了提高函数的执行效率。声明类型后再直接在头文件下面添加FORCEINLINE关键字:

EGameState GetCurrentState() const;

FORCEINLINE EGameState 你的GameMode类名::GetCurrentState() const
{
return currentState;
}

7.定时器:在头文件里定义一个FTimerHandle TimeVulnerable;  在cpp里引入头文件#include"Public/TimerManager.h"

GetWorldTimerManager().SetTimer(TimeVulnerable, this, &你的类::时间结束后执行的函数, 你的时间.0f, bool是否循环);

8.利用ConstructorHelpers来找资源:引入头文件#include"UObject/ConstructorHelpers.h"

然后开始找资源  例如 static ConstructorHelpers::FObjectFinder<UStaticMesh> CylinderObj(TEXT("'/Game/StarterContent/Shapes/Shape_Cylinder'"));

安全校验 如果查找成功 if (CylinderObj.Succeeded())

9.创建一个staticmeshcomponent:在头文件里定义一个指针变量  UStaticMeshComponent* EnemyBody;  然后在cpp里引入头文件  #include"Components/StaticMeshComponent.h"

再在构造函数里创建mesh资源   EnemyBody = CreateDefaultSubobject<UStaticMeshComponent>(TEXT("Body"));

10.C++AI,继承AAIController  可重写两个虚函数

.h头文件里重写  virtual void Possess(class APawn* InPawn) override;  相当于beginplay 游戏刚开始的时候调用的函数

.cpp里实现函数前要先调用父类的方法  Super::Possess(InPawn);

void AAIEnemy::Possess(class APawn* InPawn)

{
Super::Possess(InPawn);

}

第二个是重写移动完成后的函数

.h头文件里重写 virtual void OnMoveCompleted(FAIRequestID RequestID, const FPathFollowingResult& Result) override;  参数尽量保持一致

.cpp里实现移动完成后寻找下一个点

void AAIEnemy::OnMoveCompleted(FAIRequestID RequestID, const FPathFollowingResult & Result)
{

SearchNewPoint();

}

10.导航网格实现路径寻找:

void AAIEnemy::SearchNewPoint()
{

UNavigationSystem* NavMesh = UNavigationSystem::GetCurrent(this);
if (NavMesh)
{

const float SearchRadius = 10000.0f; //搜寻半径
FNavLocation RamdomPt;
const bool bFound = NavMesh->GetRandomReachablePointInRadius(Bot->GetActorLocation(),SearchRadius,RamdomPt);
if (bFound)
{
MoveToLocation(RamdomPt);
}
}

11.C++绘制HUD:新建一个C++类继承AHUD类  头文件重写DrawHUD函数 virtual void DrawHUD() override;

然后在cpp里实现在屏幕上中央打印文字

DrawText(TEXT("Hello")
, FColor::White, (Canvas->SizeX) / 2.0f-150, (Canvas->SizeY) / 2.0f-100, HUDFont);

12.获取当前角色character:你的Character类* Man = Cast<你的Character类>(UGameplayStatics::GetPlayerPawn(this, 0))

13.物体碰撞函数及参数设置:

UFUNCTION()
void OnCollision(class UPrimitiveComponent* HitComp, class AActor* OtherActor, class UPrimitiveComponent* OtherComponent, int OtherBodyIndex, bool bFromSweep, const FHitResult &SweepResult);

实现:

void AEnemy::OnCollision(UPrimitiveComponent * HitComp, AActor * OtherActor, UPrimitiveComponent * OtherComponent, int OtherBodyIndex, bool bFromSweep, const FHitResult & SweepResult)
{
if (OtherActor->IsA(你的Character类::StaticClass()))  //判断碰到的物体是不是主角
}

UE4 C++ 笔记的更多相关文章

  1. UE4学习笔记(三): 为什么使用C++替代UnrealScript?

    原文链接: https://forums.unrealengine.com/showthread.php?2574-Why-C-for-Unreal-4&p=16252&viewful ...

  2. UE4物理笔记

    基本 物理资源随骨骼创建,可添加到骨骼网格上. 物理材质可添加到材质或组件或物理资源上. 通过配置PrimitiveComponent组件的Collision Presets值,可实现自定义的碰撞忽略 ...

  3. UE4 编译笔记

    UE4 的功能被分成了很多的模块,在API文档里每个类都有 Module 这个属性(值为模块名)每个模块使用其他模块要在Build.cs里导入,像vs里的引入库.在构建时 PublicDependen ...

  4. UE4 小笔记

    1,设置postprocess材质时使用Add or Update Blendable 用Make PostprocessSetting会报警告,因为C++代码中没有设置为BlueprintReadW ...

  5. UE4渲染笔记

    Lightmass 实时渲染光影效果对性能有很大影响,可利用lightmass预先生成光影贴图,然后在游戏中使用. 将场景光照结果完全烘焙到模型贴图上,从而完完全全的假冒现实光照效果. 文档上是 li ...

  6. UE4 PostProcessVolume笔记

    透镜:Lens Bloom 光溢出 VDirt Mask 光溢出泥土蒙版 Depth of Filed 景深 V Eye Adaptation (Auto-Exposure) 人眼适应 V这个效果有时 ...

  7. Aery的UE4 C++游戏开发之旅(3)蓝图

    目录 蓝图 蓝图命名规范 蓝图优化 暴露C++至蓝图 暴露C++类 暴露C++属性 暴露C++函数 暴露C++结构体/枚举 暴露C++接口 蓝图和C++的结合方案 使用继承重写蓝图 使用组合重写蓝图 ...

  8. UE4 中Struct Emum 类型的定义方式 笔记

    UE4 基础,但是不经常用总是忘记,做个笔记加深记忆: 图方便就随便贴一个项目中的STRUCT和 Enum 的.h 文件 Note:虽然USTRUCT可以定义函数,但是不能加UFUNCTION 标签喔 ...

  9. UE4入门学习笔记开篇

    做了3年的Unity, 现在开始转入到做UE4,一来就进入一个超大项目组中学习,度过了最初2个月的生涩和紧张后,现在准备开始慢慢总结,慢慢学习,逐步深入理解和研究UE. 做了3年的游戏开发后,个人感悟 ...

随机推荐

  1. docker-compose up使用自定义的网段的两种方式(从其根源指定)

    问题描述         还是那个研究安全大业的同事,在部署他的秘密武器,是用docker-compose部署的,有差不多20多个docker-compose.yml文件,然后由于docker-com ...

  2. MySQL事务锁问题-Lock wait timeout exceeded

    转载:https://cloud.tencent.com/developer/article/1356959 问题现象:   接口响应时间超长,耗时几十秒才返回错误提示,后台日志中出现Lock wai ...

  3. 两个Integer变量a和b,值相等,a==b等于多少?

    Integer a = Integer.valueOf(127); Integer b = Integer.valueOf(127);   Integer c = Integer.valueOf(12 ...

  4. 2--STM32+USB移植+HID 与AUDIO类MIDI设备组成的复合设备(原创)

      前期准备: 一.硬件资源:STM32F103,USB-FS固件库. 链接: STM32 之 标准外设版USB驱动库详解(架构+文件+函数+使用说明+示例程序) https://blog.csdn. ...

  5. DNS搭建

    构建主从服务DNS 1.主服务名字:ns1.amber.com #hostname ns1.amber.com bash 刷新一下 #bash 2.Vim /etc/hosts 3.Vim /etc/ ...

  6. 【C++】源自指针的报错

    最近在调试PCL程序的时候,被这个报错折腾了好久. 无数血泪史总结成一句话,指针未初始化! PointCloudXYZ::Ptr plane_ptr;   错误!!! PointCloudXYZ::P ...

  7. 工控随笔_17_西门子_WinCC的VBS脚本_06_过程和函数

    和其他语言一样,vbs提供了过程和函数机制,通过函数和过程可以优化代码结构和实现代码复用, 减少代码的编写量. 一.代码 具体不再多说,看实例代码. ' vbs的函数和过程 '1.过程式编程是一大编程 ...

  8. vmware 中配置centos 7 静态IP

    虚拟机配置成静态IP可以保证每次宿主机器重启后,虚拟机的IP保持不变,这对于学习集群环境下的软件(如hadoop集群,mysql等数据库集群)很有用. vmware workstation 中装好li ...

  9. webRTC中音频相关的netEQ(五):DSP处理

    上篇(webRTC中音频相关的netEQ(四):控制命令决策)讲了MCU模块是怎么根据网络延时.抖动缓冲延时和反馈报告等来决定给DSP模块发什么控制命令的.DSP模块根据收到的命令进行相关处理,处理简 ...

  10. @Transactional的正确打开方式

    经常用到事务管理,可还是不小心会写错,导致事务没有生效,这里总结下. 正确的代码例子如下所示,框架是使用spring+mybatis的,有些配置的就不贴出来了. TestController2: pa ...