2014-12-07 19:09:38 -05:00
|
|
|
// Copyright 1998-2015 Epic Games, Inc. All Rights Reserved.
|
2014-11-19 07:43:07 -05:00
|
|
|
|
|
|
|
|
#include "LogVisualizer.h"
|
|
|
|
|
#include "LogVisualizerModule.h"
|
|
|
|
|
#include "LogVisualizerStyle.h"
|
|
|
|
|
#include "SDockTab.h"
|
2014-11-25 10:26:44 -05:00
|
|
|
#include "VisualLoggerRenderingActor.h"
|
2014-12-01 10:42:59 -05:00
|
|
|
#include "LogVisualizerSettings.h"
|
2014-11-28 09:26:40 -05:00
|
|
|
#if WITH_EDITOR
|
2014-11-25 17:52:12 -05:00
|
|
|
#include "Editor/EditorEngine.h"
|
2014-11-28 09:26:40 -05:00
|
|
|
#include "ISettingsModule.h"
|
|
|
|
|
#include "LevelEditor.h"
|
2014-12-11 06:23:59 -05:00
|
|
|
#include "WorkspaceMenuStructureModule.h"
|
2014-11-28 09:26:40 -05:00
|
|
|
#endif // WITH_EDITOR
|
2014-11-19 07:43:07 -05:00
|
|
|
|
|
|
|
|
#define LOCTEXT_NAMESPACE "FLogVisualizerModule"
|
|
|
|
|
|
|
|
|
|
static const FName VisualLoggerTabName("VisualLogger");
|
|
|
|
|
|
|
|
|
|
//DEFINE_LOG_CATEGORY(LogLogVisualizer);
|
|
|
|
|
|
|
|
|
|
void FNewLogVisualizerModule::StartupModule()
|
|
|
|
|
{
|
|
|
|
|
FLogVisualizerStyle::Initialize();
|
|
|
|
|
|
|
|
|
|
FVisualLoggerCommands::Register();
|
|
|
|
|
IModularFeatures::Get().RegisterModularFeature(VisualLoggerTabName, this);
|
|
|
|
|
|
2014-12-11 06:23:59 -05:00
|
|
|
FGlobalTabmanager::Get()->RegisterNomadTabSpawner(
|
|
|
|
|
VisualLoggerTabName,
|
|
|
|
|
FOnSpawnTab::CreateRaw(this, &FNewLogVisualizerModule::SpawnLogVisualizerTab))
|
|
|
|
|
.SetGroup(WorkspaceMenu::GetMenuStructure().GetDeveloperToolsMiscCategory())
|
|
|
|
|
.SetDisplayName(NSLOCTEXT("LogVisualizerApp", "TabTitle", "Visual Logger"))
|
|
|
|
|
.SetTooltipText(NSLOCTEXT("LogVisualizerApp", "TooltipText", "Opens Visual Logger tool."))
|
|
|
|
|
.SetIcon(FSlateIcon(FLogVisualizerStyle::GetStyleSetName(), "LogVisualizerApp.TabIcon"));
|
2014-11-28 09:26:40 -05:00
|
|
|
|
|
|
|
|
ISettingsModule* SettingsModule = FModuleManager::GetModulePtr<ISettingsModule>("Settings");
|
|
|
|
|
if (SettingsModule != nullptr)
|
|
|
|
|
{
|
|
|
|
|
SettingsModule->RegisterSettings("Editor", "General", "VisualLogger",
|
|
|
|
|
LOCTEXT("AIToolsSettingsName", "Visual Logger"),
|
|
|
|
|
LOCTEXT("AIToolsSettingsDescription", "General settings for UE4 AI Tools."),
|
|
|
|
|
ULogVisualizerSettings::StaticClass()->GetDefaultObject()
|
|
|
|
|
);
|
|
|
|
|
}
|
2014-11-19 07:43:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FNewLogVisualizerModule::ShutdownModule()
|
|
|
|
|
{
|
|
|
|
|
FGlobalTabmanager::Get()->UnregisterTabSpawner(VisualLoggerTabName);
|
|
|
|
|
FVisualLoggerCommands::Unregister();
|
|
|
|
|
IModularFeatures::Get().UnregisterModularFeature(VisualLoggerTabName, this);
|
2014-11-28 09:26:40 -05:00
|
|
|
|
|
|
|
|
ISettingsModule* SettingsModule = FModuleManager::GetModulePtr<ISettingsModule>("Settings");
|
|
|
|
|
if (SettingsModule != nullptr)
|
|
|
|
|
{
|
|
|
|
|
SettingsModule->UnregisterSettings("Editor", "General", "VisualLogger");
|
|
|
|
|
}
|
2014-11-19 07:43:07 -05:00
|
|
|
|
|
|
|
|
FLogVisualizerStyle::Shutdown();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
TSharedRef<SDockTab> FNewLogVisualizerModule::SpawnLogVisualizerTab(const FSpawnTabArgs& SpawnTabArgs)
|
|
|
|
|
{
|
|
|
|
|
const TSharedRef<SDockTab> MajorTab = SNew(SDockTab)
|
2014-11-25 10:26:44 -05:00
|
|
|
.TabRole(ETabRole::MajorTab).OnTabClosed(SDockTab::FOnTabClosedCallback::CreateRaw(this, &FNewLogVisualizerModule::OnTabClosed));
|
2014-11-19 07:43:07 -05:00
|
|
|
|
|
|
|
|
TSharedPtr<SWidget> TabContent;
|
|
|
|
|
|
|
|
|
|
TabContent = SNew(SVisualLogger, MajorTab, SpawnTabArgs.GetOwnerWindow());
|
|
|
|
|
|
|
|
|
|
MajorTab->SetContent(TabContent.ToSharedRef());
|
|
|
|
|
|
|
|
|
|
return MajorTab;
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-11 06:23:59 -05:00
|
|
|
void FNewLogVisualizerModule::OnTabClosed(TSharedRef<SDockTab> DockTab)
|
2014-11-25 10:26:44 -05:00
|
|
|
{
|
|
|
|
|
UWorld* World = NULL;
|
|
|
|
|
#if WITH_EDITOR
|
|
|
|
|
UEditorEngine *EEngine = Cast<UEditorEngine>(GEngine);
|
|
|
|
|
if (GIsEditor && EEngine != NULL)
|
|
|
|
|
{
|
|
|
|
|
// lets use PlayWorld during PIE/Simulate and regular world from editor otherwise, to draw debug information
|
|
|
|
|
World = EEngine->PlayWorld != NULL ? EEngine->PlayWorld : EEngine->GetEditorWorldContext().World();
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
#endif
|
|
|
|
|
if (!GIsEditor)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
World = GEngine->GetWorld();
|
|
|
|
|
}
|
|
|
|
|
|
2014-12-11 06:23:59 -05:00
|
|
|
TSharedRef<SVisualLogger> VisualLoggerTab = StaticCastSharedRef<SVisualLogger>(DockTab->GetContent());
|
|
|
|
|
VisualLoggerTab->OnTabLosed();
|
|
|
|
|
|
2014-11-25 10:26:44 -05:00
|
|
|
if (World == NULL)
|
|
|
|
|
{
|
|
|
|
|
World = GWorld;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (World)
|
|
|
|
|
{
|
|
|
|
|
for (TActorIterator<AVisualLoggerRenderingActor> It(World); It; ++It)
|
|
|
|
|
{
|
|
|
|
|
World->DestroyActor(*It);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2014-11-19 07:43:07 -05:00
|
|
|
IMPLEMENT_MODULE(FNewLogVisualizerModule, LogVisualizer);
|
|
|
|
|
#undef LOCTEXT_NAMESPACE
|