在Unreal Engine 4中,打Log很方便,可以使用宏:
- UE_LOG(LogTemp, Warning, TEXT("Your message"));
但是使用之前需要先定义Log Category,Category会在Log中体现出来,以便在茫茫Log中更容易区分其作用或所属模块。
如果想定义只在一个CPP文件中使用的Category,不希望被其他类使用,可以定义一个Static的Category:
- DEFINE_LOG_CATEGORY_STATIC(CategoryName,Log,All);
如果想定义一个‘Public’的Category,并且在全局生效,不管是static函数还是其他类都可以使用,就需要在头文件中声明一个Category,并在CPP中定义,每个用到的CPP文件都需要include该头文件:
- // in A.h
- DECLARE_LOG_CATEGORY_EXTERN(CategoryName, Log, All) // 声明一个Category为extern,避免多个文件使用此头文件时重复声明
- // in A.cpp
- #include "A.h"
- DEFINE_LOG_CATEGORY(CategoryName) // 定义该Category,全局仅需一份
- // in B.cpp
- #include "A.h" // 由于之前声明为extern,使用者引入头文件即可使用在A.cpp中的定义
如果想给某个定义一个专属的Category,可以使用:
- // in A.h
- classA
- {
- DECLARE_LOG_CATEGORY_CLASS(CategoryName,Log,All);
- };
- // in A.cpp
- DEFINE_LOG_CATEGORY_CLASS(A,CategoryName);
定义好Log Category之后就可以使用
UE_LOG
了,除了最前面例子中的用法,UE_LOG
的用法和C中的printf类似,支持字符串Format,例如:
- UE_LOG(CategoryName,Warning,TEXT("MyCharacter's Health is %d"), MyCharacter->Health );
- UE_LOG(CategoryName,Warning,TEXT("MyCharacter's Health is %f"), MyCharacter->Health );
- UE_LOG(CategoryName,Warning,TEXT("MyCharacter's Name is %s"), *MyCharacter->GetName() );