输出日记/消息到屏幕上
GEngine->AddOnScreenDebugMessage
首先天加头文件
//头文件访问 GEngine 中的 AddOnscreenDebugMessage 函数(用于将消息输出至屏幕)的必要功能。
#include "Engine/"
GEngine->AddOnScreenDebugMessage(-1, , FColor::Red, "ATrap::SteppedToTrigger_Implementation -- AddOnScreenDebugMessage!!!!");
// FString::Printf 格式话字符串
GEngine->AddOnScreenDebugMessage(-1, , FColor::White, FString::Printf(TEXT("-- TestFuncThreeParams,%d, %d,%f"), bVal ? 1:0, iVal, fVal));
----------------------------------------
输出日记/消息到编辑器控制台
查看Log
Game模式:记录Log需要在启动参数后加 -Log 。
编辑器模式:打开Log窗口(Window->Developer Tools->Output Log)
//UE_LOG
UE_LOG(LogTemp, Log, TEXT("C++ : CountdownHasFinished_Implementation"));
使用Log
UE_LOG(LogMy,Warning,TEXT("Hello World"));
UE_LOG(LogMy,Warning,TEXT("Show a String %s"),*FString("Hello"));
UE_LOG(LogMy,Warning,TEXT("Show a Int %d"),100);
//FString官方文档:/4.26/zh-CN/ProgrammingAndScripting/ProgrammingWithCPP/UnrealArchitecture/StringHandling/FString/
//构建 FString
FString TestHUDString = FString(TEXT("This is my test FString."));
//输出 FString
UE_LOG(LogTemp, Log, TEXT("%s"), *TestHUDString );
// FString::Printf 格式话字符串
//输出 FString
UE_LOG(LogTemp, Log, TEXT("%s"), FString::Printf(TEXT("-- TestFuncThreeParams,%d, %d,%f"), bVal ? 1:0, iVal, fVal) );
第一个参数为Log的分类。
第二个参数为类型,有Log、Warning、Error三种类型。Log为灰色,Warning为黄色,Error为红色。
常用的符号:
- %s 字符串(FString)
- %d 整型数据(int32)
- %f 浮点型(float)
自定义日记类别Category
自定义 Category 的宏可参考 文件。
在UE4中,UE_LOG
宏有五个日志类别(Category):
: 用于临时调试信息或快速测试。
: 用于游戏运行时的事件和状态更新。
: 用于从蓝图中输出的用户消息。
: 用于在线游戏模块相关的日志记录。
: 用于导航系统相关的日志记录。
你也可以自定义其他的日志类别来适应你的项目需求。日志类别可以帮助你更好地组织和查找日志信息,以便于调试和问题排查
你可以在UE4中定义自己的日志类别(Category)。可以使用DECLARE_LOG_CATEGORY_EXTERN
宏在头文件中声明,并使用DEFINE_LOG_CATEGORY
宏在源文件中定义。以下是一个示例:
在 头文件中声明自定义日志类别:
#pragma once
#include ""
#include "Logging/"
/// 如果想定义一个‘Public’的Category,并且在全局生效,不管是 static 函数还是其他类都可以使用,
/// 就需要在头文件中声明一个Category,并在CPP中定义,每个用到的CPP文件都需要include该头文件。
/// 使用 DECLARE_LOG_CATEGORY_EXTERN 宏来声明日记类别。这里的日记类别为 MyLogCategory
DECLARE_LOG_CATEGORY_EXTERN(MyLogCategory, Log, All);
在 源文件中定义自定义日志类别:
#include ""
/// 在.cpp源文件中定义积极类别 MyLogCategory ,此类别在头文件.h中已经声明
DEFINE_LOG_CATEGORY(MyLogCategory);
现在你就可以在代码中使用 MyLogCategory
日志类别了:
#include ""
void MyFunction()
{
UE_LOG(MyLogCategory, Log, TEXT("This is a log message"));
}
当你运行程序时,在输出日志窗口中将会显示 "This is a log message" 的文本信息,并被标记为 MyLogCategory
类别的日志。通过自定义日志类别,你可以更好地组织和查找你的日志信息,并根据需要对其进行筛选和处理。
‘UE_LOG’和声明或定义Log Category的宏中提到的’Log’,’Warning’,’All’等,是ELogVerbosity中定义的枚举,具体含义可参考下面的源码。
参考资料:如何使用UE_LOG-****博客