You've already forked UnrealEngineUWP
mirror of
https://github.com/izzy2lost/UnrealEngineUWP.git
synced 2026-03-26 18:15:20 -07:00
201 lines
5.1 KiB
C++
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();
|
|
}
|