http://www.cnblogs.com/blueroses/p/6037981.html

Ue4的UE_LOG

說明:本文爲Wiki上的RAMA大神文章的大致翻譯

遊戲模式:

在遊戲模式下,你需要在遊戲的快捷方式後面加 -Log,纔會在遊戲中顯示。

 

編輯器模式(Play In Editor):

你可以在Output窗口中看到log信息。

如果想在遊戲中看到,需要到Engin.ini中修改參數添加"GameCommandLine=-log,如果沒有,則需要按~,輸入-Log命令開啓。

 

快速使用:

UE_LOG(LogTemp, Warning, TEXT("Your message"));

不用設置標籤,簡單快速。

 

設置擁有自己標籤的Log:

在你的遊戲頭文件中加入:

複製代碼
//General Log
DECLARE_LOG_CATEGORY_EXTERN(YourLog, Log, All);
 
//Logging during game startup
DECLARE_LOG_CATEGORY_EXTERN(YourInit, Log, All);
 
//Logging for your AI system
DECLARE_LOG_CATEGORY_EXTERN(YourAI, Log, All);
 
//Logging for Critical Errors that must always be addressed
DECLARE_LOG_CATEGORY_EXTERN(YourCriticalErrors, Log, All);
複製代碼

這樣輸出的Log你就可以知道是哪個部分的,這也是UE_Log很有用的原因。

在你的遊戲Cpp文件中:

複製代碼
//General Log
DEFINE_LOG_CATEGORY(YourLog);
 
//Logging during game startup
DEFINE_LOG_CATEGORY(YourInit);
 
//Logging for your AI system
DEFINE_LOG_CATEGORY(YourAI);
 
//Logging for Critical Errors that must always be addressed
DEFINE_LOG_CATEGORY(YourCriticalErrors);
複製代碼

 

Log格式:

Log Message

//"This is a message to yourself during runtime!"
UE_LOG(YourLog,Warning,TEXT("This is a message to yourself during runtime!"));

Log an FString

 %s strings are wanted as TCHAR* by Log, so use *FString()
//"MyCharacter's Name is %s"
UE_LOG(YourLog,Warning,TEXT("MyCharacter's Name is %s"), *MyCharacter->GetName() );

Log an Int

//"MyCharacter's Health is %d"
UE_LOG(YourLog,Warning,TEXT("MyCharacter's Health is %d"), MyCharacter->Health );

Log a Float

//"MyCharacter's Health is %f"
UE_LOG(YourLog,Warning,TEXT("MyCharacter's Health is %f"), MyCharacter->Health );

Log an FVector

//"MyCharacter's Location is %s"
UE_LOG(YourLog,Warning,TEXT("MyCharacter's Location is %s"), 
    *MyCharacter->GetActorLocation().ToString());

Log an FName

//"MyCharacter's FName is %s"
UE_LOG(YourLog,Warning,TEXT("MyCharacter's FName is %s"), 
    *MyCharacter->GetFName().ToString());

Log an FString,Int,Float

//"%s has health %d, which is %f percent of total health"
UE_LOG(YourLog,Warning,TEXT("%s has health %d, which is %f percent of total health"),
    *MyCharacter->GetName(), MyCharacter->Health, MyCharacter->HealthPercent);

Log的顏色設置:

//"this is Grey Text"
UE_LOG(YourLog,Log,TEXT("This is grey text!"));
//"this is Yellow Text"
UE_LOG(YourLog,Warning,TEXT("This is yellow text!"));
//"This is Red Text"
UE_LOG(YourLog,Error,TEXT("This is red text!"));

可以看得出第二個參數是是用來控制顏色的。

 

傳遞客戶端信息(網絡模式):

PlayerController->ClientMessage("Your Message");

命令行命令以及Engine.ini配置:

Log conventions (in the console, ini files, or environment variables)

[cat] = a category for the command to operate on, or 'global' for all categories.
標籤,沒有設置就顯示所有的Log
[level] = verbosity level, one of: none, error, warning, display, log, verbose, all, default
關卡,顯示某某關卡的Log

At boot time, compiled in default is overridden by ini files setting, which is overridden by command line

Log console command usage

複製代碼
Log list - list all log categories
Log list [string] - list all log categories containing a substring
Log reset - reset all log categories to their boot-time default
Log [cat] - toggle the display of the category [cat]
Log [cat] off - disable display of the category [cat]
Log [cat] on - resume display of the category [cat]
Log [cat] [level] - set the verbosity level of the category [cat]
Log [cat] break - toggle the debug break on display of the category [cat]
複製代碼

Log command line

-LogCmds=\"[arguments],[arguments]...\"           - applies a list of console commands at boot time
-LogCmds=\"foo verbose, bar off\"         - turns on the foo category and turns off the bar category

Environment variables

Any command line option can be set via the environment variable UE-CmdLineArgs

set UE-CmdLineArgs=\"-LogCmds=foo verbose breakon, bar off\"

Config file

In DefaultEngine.ini or Engine.ini:

[Core.Log]
global=[default verbosity for things not listed later]
[cat]=[level]
foo=verbose break
Rama後面的一篇文章提供了顯示代碼行號、函數名稱、類名等功能:
https://wiki.unrealengine.com/Logs,_Printing_the_Class_Name,_Function_Name,_Line_Number_of_your_Calling_Code!
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章