Files
UnrealEngineUWP/Engine/Source/Editor/GraphEditor/Private/GraphEditorDragDropAction.cpp
Matthew Griffin bb70b349ce Merging CL 2804086 from //UE4/Release-4.11 to Dev-Main (//UE4/Dev-Main) to isolate copyright update
#lockdown Nick.Penwarden

[CL 2819020 by Matthew Griffin in Main branch]
2016-01-07 08:17:16 -05:00

201 lines
5.1 KiB
C++

// Copyright 1998-2016 Epic Games, Inc. All Rights Reserved.
#include "GraphEditorCommon.h"
#include "SScaleBox.h"
UEdGraphPin* FGraphEditorDragDropAction::GetHoveredPin() const
{
return HoveredPin.Get();
}
UEdGraphNode* FGraphEditorDragDropAction::GetHoveredNode() const
{
return HoveredNode.IsValid() ? HoveredNode->GetNodeObj() : NULL;
}
UEdGraph* FGraphEditorDragDropAction::GetHoveredGraph() const
{
// Note: We always want to report a graph even when hovering over a node or pin;
// the same is not true for nodes when hovering over a pin (at least right now)
if (HoveredGraph.IsValid())
{
return HoveredGraph->GetGraphObj();
}
else if (UEdGraphNode* Node = GetHoveredNode())
{
return Node->GetGraph();
}
else if (UEdGraphPin* Pin = GetHoveredPin())
{
return Pin->GetOwningNode()->GetGraph();
}
return NULL;
}
void FGraphEditorDragDropAction::SetHoveredPin(UEdGraphPin* InPin)
{
if (HoveredPin != InPin)
{
HoveredPin = InPin;
HoverTargetChanged();
}
}
void FGraphEditorDragDropAction::SetHoveredNode(const TSharedPtr<SGraphNode>& InNode)
{
if (HoveredNode != InNode)
{
HoveredNode = InNode;
HoverTargetChanged();
}
}
void FGraphEditorDragDropAction::SetHoveredGraph(const TSharedPtr<SGraphPanel>& InGraph)
{
if (HoveredGraph != InGraph)
{
HoveredGraph = InGraph;
HoverTargetChanged();
}
}
void FGraphEditorDragDropAction::SetHoveredCategoryName(const FText& InHoverCategoryName)
{
if(!HoveredCategoryName.EqualTo(InHoverCategoryName))
{
HoveredCategoryName = InHoverCategoryName;
HoverTargetChanged();
}
}
void FGraphEditorDragDropAction::SetHoveredAction(TSharedPtr<struct FEdGraphSchemaAction> Action)
{
if(HoveredAction.Pin().Get() != Action.Get())
{
HoveredAction = Action;
HoverTargetChanged();
}
}
void FGraphEditorDragDropAction::Construct()
{
// Create the drag-drop decorator window
CursorDecoratorWindow = SWindow::MakeCursorDecorator();
const bool bShowImmediately = false;
FSlateApplication::Get().AddWindow(CursorDecoratorWindow.ToSharedRef(), bShowImmediately);
HoverTargetChanged();
}
bool FGraphEditorDragDropAction::HasFeedbackMessage()
{
return CursorDecoratorWindow->GetContent() != SNullWidget::NullWidget;
}
void FGraphEditorDragDropAction::SetFeedbackMessage(const TSharedPtr<SWidget>& Message)
{
if (Message.IsValid())
{
CursorDecoratorWindow->ShowWindow();
CursorDecoratorWindow->SetContent
(
SNew(SBorder)
. BorderImage(FEditorStyle::GetBrush("Graph.ConnectorFeedback.Border"))
[
Message.ToSharedRef()
]
);
}
else
{
CursorDecoratorWindow->HideWindow();
CursorDecoratorWindow->SetContent(SNullWidget::NullWidget);
}
}
void FGraphEditorDragDropAction::SetSimpleFeedbackMessage(const FSlateBrush* Icon, const FSlateColor& IconColor, const FText& Message)
{
// Let the user know the status of making this connection.
// Use CreateRaw as we cannot using anything that will create a shared ptr from within an objects construction, this should be
// safe though as we will destroy our window before we get destroyed.
TAttribute<EVisibility> ErrorIconVisibility = TAttribute<EVisibility>::Create(TAttribute<EVisibility>::FGetter::CreateRaw(this, &FGraphEditorDragDropAction::GetErrorIconVisible));
TAttribute<EVisibility> IconVisibility = TAttribute<EVisibility>::Create(TAttribute<EVisibility>::FGetter::CreateRaw(this, &FGraphEditorDragDropAction::GetIconVisible));
SetFeedbackMessage(
SNew(SHorizontalBox)
+SHorizontalBox::Slot()
.AutoWidth()
.Padding(3.0f)
[
SNew(SScaleBox)
.Stretch(EStretch::ScaleToFit)
[
SNew(SImage)
.Visibility(ErrorIconVisibility)
.Image( FEditorStyle::GetBrush( TEXT("Graph.ConnectorFeedback.Error") ))
.ColorAndOpacity( FLinearColor::White )
]
]
+SHorizontalBox::Slot()
.AutoWidth()
.Padding(3.0f)
[
SNew(SScaleBox)
.Stretch(EStretch::ScaleToFit)
[
SNew(SImage)
.Visibility(IconVisibility)
.Image( Icon )
.ColorAndOpacity( IconColor )
]
]
+SHorizontalBox::Slot()
.AutoWidth()
.MaxWidth(500)
.VAlign(VAlign_Center)
[
SNew(STextBlock)
.WrapTextAt( 480 )
.Text( Message )
]
);
}
EVisibility FGraphEditorDragDropAction::GetIconVisible() const
{
return bDropTargetValid ? EVisibility::Visible : EVisibility::Collapsed;
}
EVisibility FGraphEditorDragDropAction::GetErrorIconVisible() const
{
return bDropTargetValid ? EVisibility::Collapsed : EVisibility::Visible;
}
////////////////////////////////////////////////////////////
void FGraphSchemaActionDragDropAction::HoverTargetChanged()
{
if(ActionNode.IsValid())
{
const FSlateBrush* StatusSymbol = FEditorStyle::GetBrush(TEXT("Graph.ConnectorFeedback.NewNode"));
//Create feedback message with the function name.
SetSimpleFeedbackMessage(StatusSymbol, FLinearColor::White, ActionNode->GetMenuDescription());
}
}
FReply FGraphSchemaActionDragDropAction::DroppedOnPanel( const TSharedRef< SWidget >& Panel, FVector2D ScreenPosition, FVector2D GraphPosition, UEdGraph& Graph)
{
if(ActionNode.IsValid())
{
TArray<UEdGraphPin*> DummyPins;
ActionNode->PerformAction(&Graph, DummyPins, GraphPosition);
return FReply::Handled();
}
return FReply::Unhandled();
}