进行保存
This commit is contained in:
parent
a7295dc87b
commit
b9ee84436e
BIN
Resources/Collapse.png
Normal file
BIN
Resources/Collapse.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 119 B |
BIN
Resources/Expaned.png
Normal file
BIN
Resources/Expaned.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 121 B |
@ -52,4 +52,9 @@ public:
|
|||||||
virtual void UpdateProperties(IPropertiesInterface* Interface) {};
|
virtual void UpdateProperties(IPropertiesInterface* Interface) {};
|
||||||
virtual void ClearProperties() {};
|
virtual void ClearProperties() {};
|
||||||
FGuid CurrentSelectedPropertiesInterfaceGuid;
|
FGuid CurrentSelectedPropertiesInterfaceGuid;
|
||||||
|
|
||||||
|
|
||||||
|
virtual void DeleteAllAssetsInTimeline() {};
|
||||||
|
|
||||||
|
virtual class SCutTimeline* GetCutTimeline() { return nullptr; };
|
||||||
};
|
};
|
||||||
|
@ -33,6 +33,7 @@ public:
|
|||||||
};
|
};
|
||||||
static FString MainSaveFullPath()
|
static FString MainSaveFullPath()
|
||||||
{
|
{
|
||||||
|
GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Blue, FGlobalData::BasePath);
|
||||||
return FPaths::Combine(FGlobalData::BasePath, FGlobalData::CurrentProjectName, FGlobalData::CurrentProjectName + TEXT(".bin"));
|
return FPaths::Combine(FGlobalData::BasePath, FGlobalData::CurrentProjectName, FGlobalData::CurrentProjectName + TEXT(".bin"));
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -27,6 +27,7 @@ public:
|
|||||||
virtual void Seek(int32 Frame) {};
|
virtual void Seek(int32 Frame) {};
|
||||||
virtual void RemoveClip(const FGuid& Guid) {};
|
virtual void RemoveClip(const FGuid& Guid) {};
|
||||||
virtual void BreakClip(const FGuid& Guid) {};
|
virtual void BreakClip(const FGuid& Guid) {};
|
||||||
|
virtual void DeleteUseLessClips() {};
|
||||||
|
|
||||||
FGuid SelectedClipGUID;
|
FGuid SelectedClipGUID;
|
||||||
int32 SelectedClipFrame;
|
int32 SelectedClipFrame;
|
||||||
|
@ -10,5 +10,6 @@ void FCurtainCommands::RegisterCommands()
|
|||||||
UI_COMMAND(MoveDown, "下移一层", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
UI_COMMAND(MoveDown, "下移一层", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
UI_COMMAND(InsertUp, "在上方插入单元", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
UI_COMMAND(InsertUp, "在上方插入单元", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
UI_COMMAND(InsertDown, "在下方插入单元", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
UI_COMMAND(InsertDown, "在下方插入单元", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
|
UI_COMMAND(Delete, "删除", "Executes My FCurtainCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
}
|
}
|
||||||
#undef LOCTEXT_NAMESPACE
|
#undef LOCTEXT_NAMESPACE
|
||||||
|
@ -15,4 +15,5 @@ public:
|
|||||||
TSharedPtr<FUICommandInfo> MoveDown;
|
TSharedPtr<FUICommandInfo> MoveDown;
|
||||||
TSharedPtr<FUICommandInfo> InsertUp;
|
TSharedPtr<FUICommandInfo> InsertUp;
|
||||||
TSharedPtr<FUICommandInfo> InsertDown;
|
TSharedPtr<FUICommandInfo> InsertDown;
|
||||||
|
TSharedPtr<FUICommandInfo> Delete;
|
||||||
};
|
};
|
||||||
|
@ -32,6 +32,11 @@ void SCurtain::Construct(const FArguments& InArgs)
|
|||||||
.Image(FUtils::GetBrushFromImage(FUtils::GetResourcesPath("BackGround.png"), {}))
|
.Image(FUtils::GetBrushFromImage(FUtils::GetResourcesPath("BackGround.png"), {}))
|
||||||
.OnMouseButtonDown_Lambda([this](const FGeometry& Geometry, const FPointerEvent& Event)
|
.OnMouseButtonDown_Lambda([this](const FGeometry& Geometry, const FPointerEvent& Event)
|
||||||
{
|
{
|
||||||
|
if (Event.GetEffectingButton() == EKeys::RightMouseButton)
|
||||||
|
{
|
||||||
|
CurtainPanel->ShowCurtainCommand(Curtain->CurtainUUID);
|
||||||
|
return FReply::Handled();
|
||||||
|
}
|
||||||
CurtainPanel->DeSelectedAll();
|
CurtainPanel->DeSelectedAll();
|
||||||
Curtain->bIsActive = true;
|
Curtain->bIsActive = true;
|
||||||
CurtainPanel->CallRender();
|
CurtainPanel->CallRender();
|
||||||
@ -48,7 +53,7 @@ void SCurtain::Construct(const FArguments& InArgs)
|
|||||||
.HAlign(HAlign_Left)
|
.HAlign(HAlign_Left)
|
||||||
.VAlign(VAlign_Center)
|
.VAlign(VAlign_Center)
|
||||||
[
|
[
|
||||||
SNew(SInlineEditableTextBlock)
|
SAssignNew(InlineEditableTextBlock, SInlineEditableTextBlock)
|
||||||
.Text(FText::FromString(Curtain->CurtainName))
|
.Text(FText::FromString(Curtain->CurtainName))
|
||||||
.OnTextCommitted_Lambda([this](const FText& Text, ETextCommit::Type CommitType)
|
.OnTextCommitted_Lambda([this](const FText& Text, ETextCommit::Type CommitType)
|
||||||
{
|
{
|
||||||
@ -87,7 +92,7 @@ FReply SCurtain::OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEv
|
|||||||
{
|
{
|
||||||
if (MouseEvent.GetEffectingButton() == EKeys::RightMouseButton)
|
if (MouseEvent.GetEffectingButton() == EKeys::RightMouseButton)
|
||||||
{
|
{
|
||||||
CurtainPanel->ShowCurtainCommand(0);
|
CurtainPanel->ShowCurtainCommand(Curtain->CurtainUUID);
|
||||||
return FReply::Handled();
|
return FReply::Handled();
|
||||||
}
|
}
|
||||||
return SCompoundWidget::OnMouseButtonDown(MyGeometry, MouseEvent);
|
return SCompoundWidget::OnMouseButtonDown(MyGeometry, MouseEvent);
|
||||||
|
@ -30,4 +30,5 @@ public:
|
|||||||
FCurtain* Curtain;
|
FCurtain* Curtain;
|
||||||
FCurtainGroup* CurtainGroup;
|
FCurtainGroup* CurtainGroup;
|
||||||
int32 CurtainIndex;
|
int32 CurtainIndex;
|
||||||
|
TSharedPtr<SInlineEditableTextBlock> InlineEditableTextBlock;
|
||||||
};
|
};
|
||||||
|
@ -62,7 +62,7 @@ void SCurtainGroup::Construct(const FArguments& InArgs)
|
|||||||
// .Style(&ExpandableAreaStyle)
|
// .Style(&ExpandableAreaStyle)
|
||||||
.HeaderContent()
|
.HeaderContent()
|
||||||
[
|
[
|
||||||
SNew(SInlineEditableTextBlock)
|
SAssignNew(InlineEditableTextBlock, SInlineEditableTextBlock)
|
||||||
.Text(FText::FromString(CurtainGroup->GroupName))
|
.Text(FText::FromString(CurtainGroup->GroupName))
|
||||||
.OnVerifyTextChanged_Lambda([](const FText& Text, FText& ErrorMessage)
|
.OnVerifyTextChanged_Lambda([](const FText& Text, FText& ErrorMessage)
|
||||||
{
|
{
|
||||||
@ -90,16 +90,21 @@ void SCurtainGroup::Construct(const FArguments& InArgs)
|
|||||||
void SCurtainGroup::CallRender()
|
void SCurtainGroup::CallRender()
|
||||||
{
|
{
|
||||||
ContentVerticalBox->ClearChildren();
|
ContentVerticalBox->ClearChildren();
|
||||||
|
CurtainWidgets.Empty();
|
||||||
for (FCurtain& Curtain : CurtainGroup->Curtains)
|
for (FCurtain& Curtain : CurtainGroup->Curtains)
|
||||||
{
|
{
|
||||||
ContentVerticalBox->AddSlot()
|
TSharedPtr<SCurtain> CurtainWidget =
|
||||||
[
|
|
||||||
SNew(SCurtain)
|
SNew(SCurtain)
|
||||||
.Curtain(&Curtain)
|
.Curtain(&Curtain)
|
||||||
.CurtainGroup(CurtainGroup)
|
.CurtainGroup(CurtainGroup)
|
||||||
.CurtainPanel(CurtainPanel)
|
.CurtainPanel(CurtainPanel)
|
||||||
.CurtainIndex(&Curtain - &CurtainGroup->Curtains[0])
|
.CurtainIndex(&Curtain - &CurtainGroup->Curtains[0]);
|
||||||
|
|
||||||
|
ContentVerticalBox->AddSlot()
|
||||||
|
[
|
||||||
|
CurtainWidget.ToSharedRef()
|
||||||
];
|
];
|
||||||
|
CurtainWidgets.Add(CurtainWidget);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,4 +122,14 @@ FReply SCurtainGroup::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent&
|
|||||||
return FReply::Handled();
|
return FReply::Handled();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FReply SCurtainGroup::OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent)
|
||||||
|
{
|
||||||
|
if (MouseEvent.IsMouseButtonDown(EKeys::RightMouseButton))
|
||||||
|
{
|
||||||
|
CurtainPanel->ShowCurtainCommand(CurtainGroup->GroupUID);
|
||||||
|
return FReply::Handled();
|
||||||
|
}
|
||||||
|
return FReply::Handled();
|
||||||
|
}
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "CoreMinimal.h"
|
#include "CoreMinimal.h"
|
||||||
|
#include "SCurtain.h"
|
||||||
#include "Cut5/Widgets/DefineGlobal.h"
|
#include "Cut5/Widgets/DefineGlobal.h"
|
||||||
#include "Widgets/SCompoundWidget.h"
|
#include "Widgets/SCompoundWidget.h"
|
||||||
|
|
||||||
@ -31,4 +32,10 @@ public:
|
|||||||
void CallRender();
|
void CallRender();
|
||||||
|
|
||||||
virtual FReply OnDrop(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent) override;
|
virtual FReply OnDrop(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent) override;
|
||||||
|
|
||||||
|
virtual FReply OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
||||||
|
|
||||||
|
TSharedPtr<SInlineEditableTextBlock> InlineEditableTextBlock;
|
||||||
|
|
||||||
|
TArray<TSharedPtr<SCurtain>> CurtainWidgets;
|
||||||
};
|
};
|
||||||
|
@ -12,6 +12,7 @@
|
|||||||
#include "Cut5/Widgets/Commands/CurtainCommands.h"
|
#include "Cut5/Widgets/Commands/CurtainCommands.h"
|
||||||
#include "Widgets/Layout/SScrollBox.h"
|
#include "Widgets/Layout/SScrollBox.h"
|
||||||
#include "Widgets/Layout/SSeparator.h"
|
#include "Widgets/Layout/SSeparator.h"
|
||||||
|
#include "Widgets/Text/SInlineEditableTextBlock.h"
|
||||||
#include "Widgets/Views/STreeView.h"
|
#include "Widgets/Views/STreeView.h"
|
||||||
|
|
||||||
BEGIN_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
BEGIN_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
@ -31,9 +32,9 @@ void SCurtainPanel::Construct(const FArguments& InArgs)
|
|||||||
{
|
{
|
||||||
|
|
||||||
}));
|
}));
|
||||||
CommandList->MapAction(FCurtainCommands::Get().Rename, FExecuteAction::CreateLambda([]()
|
CommandList->MapAction(FCurtainCommands::Get().Rename, FExecuteAction::CreateLambda([this]()
|
||||||
{
|
{
|
||||||
|
RenameCurtain();
|
||||||
}));
|
}));
|
||||||
CommandList->MapAction(FCurtainCommands::Get().MoveUp, FExecuteAction::CreateLambda([]()
|
CommandList->MapAction(FCurtainCommands::Get().MoveUp, FExecuteAction::CreateLambda([]()
|
||||||
{
|
{
|
||||||
@ -51,7 +52,10 @@ void SCurtainPanel::Construct(const FArguments& InArgs)
|
|||||||
{
|
{
|
||||||
|
|
||||||
}));
|
}));
|
||||||
|
CommandList->MapAction(FCurtainCommands::Get().Delete, FExecuteAction::CreateLambda([this]()
|
||||||
|
{
|
||||||
|
RemoveCurtain();
|
||||||
|
}));
|
||||||
FTextBlockStyle NormalText = FAppStyle::GetWidgetStyle<FTextBlockStyle>("NormalText");
|
FTextBlockStyle NormalText = FAppStyle::GetWidgetStyle<FTextBlockStyle>("NormalText");
|
||||||
NormalText.SetFontSize(15);
|
NormalText.SetFontSize(15);
|
||||||
|
|
||||||
@ -209,14 +213,18 @@ void SCurtainPanel::UnSelectAllCurtain()
|
|||||||
void SCurtainPanel::CallRender()
|
void SCurtainPanel::CallRender()
|
||||||
{
|
{
|
||||||
ScrollBox->ClearChildren();
|
ScrollBox->ClearChildren();
|
||||||
|
GroupWidgets.Empty();
|
||||||
for (FCurtainGroup& Group : Groups)
|
for (FCurtainGroup& Group : Groups)
|
||||||
{
|
{
|
||||||
ScrollBox->AddSlot()
|
TSharedPtr<SCurtainGroup> NewGroup =
|
||||||
[
|
|
||||||
SNew(SCurtainGroup)
|
SNew(SCurtainGroup)
|
||||||
.CurtainGroup(&Group)
|
.CurtainGroup(&Group)
|
||||||
.CurtainPanel(this)
|
.CurtainPanel(this);
|
||||||
|
ScrollBox->AddSlot()
|
||||||
|
[
|
||||||
|
NewGroup.ToSharedRef()
|
||||||
];
|
];
|
||||||
|
GroupWidgets.Add(NewGroup);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -257,8 +265,11 @@ void SCurtainPanel::Move(int32 SrcCurtainIndex, int32 DstCurtainIndex, int32 Src
|
|||||||
CallRender();
|
CallRender();
|
||||||
}
|
}
|
||||||
|
|
||||||
void SCurtainPanel::ShowCurtainCommand(int32 Index)
|
void SCurtainPanel::ShowCurtainCommand(const FGuid& Guid)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
|
SelectedGuid = Guid;
|
||||||
FMenuBuilder MenuBuilder(true, CommandList);
|
FMenuBuilder MenuBuilder(true, CommandList);
|
||||||
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().Copy);
|
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().Copy);
|
||||||
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().Paste);
|
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().Paste);
|
||||||
@ -267,10 +278,83 @@ void SCurtainPanel::ShowCurtainCommand(int32 Index)
|
|||||||
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().InsertDown);
|
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().InsertDown);
|
||||||
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().MoveUp);
|
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().MoveUp);
|
||||||
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().MoveDown);
|
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().MoveDown);
|
||||||
|
MenuBuilder.AddMenuEntry(FCurtainCommands::Get().Delete);
|
||||||
|
|
||||||
|
// MenuBuilder.AddWidget(
|
||||||
|
// SNew(SBox)
|
||||||
|
// .WidthOverride(160)
|
||||||
|
// .HeightOverride(40)
|
||||||
|
// [
|
||||||
|
// SNew(SButton)
|
||||||
|
// [
|
||||||
|
// SNew(STextBlock)
|
||||||
|
// .Text(FText::FromString(TEXT("删除")))
|
||||||
|
// ]
|
||||||
|
// ]
|
||||||
|
//
|
||||||
|
// , FText::FromString(TEXT("删除")), true);
|
||||||
|
|
||||||
TSharedPtr<SWidget> MenuContent;
|
TSharedPtr<SWidget> MenuContent;
|
||||||
MenuContent = MenuBuilder.MakeWidget();
|
MenuContent = MenuBuilder.MakeWidget();
|
||||||
|
|
||||||
FSlateApplication::Get().PushMenu(AsShared(), FWidgetPath(), MenuContent.ToSharedRef(), FSlateApplication::Get().GetCursorPos(), FPopupTransitionEffect::ContextMenu);
|
FSlateApplication::Get().PushMenu(AsShared(), FWidgetPath(), MenuContent.ToSharedRef(), FSlateApplication::Get().GetCursorPos(), FPopupTransitionEffect::ContextMenu);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SCurtainPanel::RemoveCurtain()
|
||||||
|
{
|
||||||
|
int32 j = 0;
|
||||||
|
for (FCurtainGroup& Group : Groups)
|
||||||
|
{
|
||||||
|
if (Group.GroupUID == SelectedGuid)
|
||||||
|
{
|
||||||
|
Groups.RemoveAt(j);
|
||||||
|
SelectedGuid.Invalidate();
|
||||||
|
CallRender();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
int32 i = 0;
|
||||||
|
for (FCurtain& Curtain : Group.Curtains)
|
||||||
|
{
|
||||||
|
if (Curtain.CurtainUUID == SelectedGuid)
|
||||||
|
{
|
||||||
|
Group.Curtains.RemoveAt(i);
|
||||||
|
SelectedGuid.Invalidate();
|
||||||
|
CallRender();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void SCurtainPanel::RenameCurtain()
|
||||||
|
{
|
||||||
|
int32 j = 0;
|
||||||
|
for (TSharedPtr<SCurtainGroup> Group : GroupWidgets)
|
||||||
|
{
|
||||||
|
if (Group->CurtainGroup->GroupUID == SelectedGuid)
|
||||||
|
{
|
||||||
|
FSlateApplication::Get().SetKeyboardFocus(Group->InlineEditableTextBlock);
|
||||||
|
Group->InlineEditableTextBlock->EnterEditingMode();
|
||||||
|
Group->InlineEditableTextBlock->EnterEditingMode();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
int32 i = 0;
|
||||||
|
for (TSharedPtr<SCurtain> Curtain : Group->CurtainWidgets)
|
||||||
|
{
|
||||||
|
if (Curtain->Curtain->CurtainUUID == SelectedGuid)
|
||||||
|
{
|
||||||
|
FSlateApplication::Get().SetKeyboardFocus(Curtain->InlineEditableTextBlock);
|
||||||
|
Curtain->InlineEditableTextBlock->EnterEditingMode();
|
||||||
|
Curtain->InlineEditableTextBlock->EnterEditingMode();
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -37,7 +37,9 @@ public:
|
|||||||
void CallRender();
|
void CallRender();
|
||||||
void DeSelectedAll();
|
void DeSelectedAll();
|
||||||
void Move(int32 SrcCurtainIndex = 0, int32 DstCurtainIndex = 0, int32 SrcGroupIndex = 0, int32 DstGroupIndex = 0);
|
void Move(int32 SrcCurtainIndex = 0, int32 DstCurtainIndex = 0, int32 SrcGroupIndex = 0, int32 DstGroupIndex = 0);
|
||||||
void ShowCurtainCommand(int32 Index);
|
void ShowCurtainCommand(const FGuid& Guid);
|
||||||
|
void RemoveCurtain();
|
||||||
|
void RenameCurtain();
|
||||||
ICutMainWidgetInterface* MainWidgetInterface = nullptr;
|
ICutMainWidgetInterface* MainWidgetInterface = nullptr;
|
||||||
int32 CurrentSelectedTree = 0;
|
int32 CurrentSelectedTree = 0;
|
||||||
TArray<TSharedPtr<SCurtainTree>> Trees;
|
TArray<TSharedPtr<SCurtainTree>> Trees;
|
||||||
@ -45,4 +47,7 @@ public:
|
|||||||
TSharedPtr<FUICommandList> CommandList;
|
TSharedPtr<FUICommandList> CommandList;
|
||||||
TSharedPtr<STextBlock> Title;
|
TSharedPtr<STextBlock> Title;
|
||||||
TArray<FCurtainGroup> Groups;
|
TArray<FCurtainGroup> Groups;
|
||||||
|
FGuid SelectedGuid = FGuid();
|
||||||
|
|
||||||
|
TArray<TSharedPtr<SCurtainGroup>> GroupWidgets;
|
||||||
};
|
};
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
#include "Cut5/WidgetInterface.h"
|
#include "Cut5/WidgetInterface.h"
|
||||||
|
|
||||||
#include "Widgets/Input/SEditableTextBox.h"
|
#include "Widgets/Input/SEditableTextBox.h"
|
||||||
|
|
||||||
extern "C"{
|
extern "C"{
|
||||||
@ -71,6 +72,9 @@ enum class ETrackType
|
|||||||
ProjectorTrack,
|
ProjectorTrack,
|
||||||
LightArrayTrack,
|
LightArrayTrack,
|
||||||
LightBarTrack,
|
LightBarTrack,
|
||||||
|
|
||||||
|
CustomColorTrack,
|
||||||
|
None = 255,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum class EPresetType
|
enum class EPresetType
|
||||||
@ -113,8 +117,14 @@ struct CUT5_API FTrackData
|
|||||||
};
|
};
|
||||||
struct CUT5_API FCursorData
|
struct CUT5_API FCursorData
|
||||||
{
|
{
|
||||||
int32 CursorFrameOffset = 0;
|
FCursorData(int32 Offset, FLinearColor InColor)
|
||||||
|
{
|
||||||
|
CursorFrameOffset = Offset;
|
||||||
|
Color = InColor;
|
||||||
|
};
|
||||||
|
|
||||||
|
int32 CursorFrameOffset = 0;
|
||||||
|
FLinearColor Color;
|
||||||
friend FArchive& operator<<(FArchive& Ar, FCursorData& CursorData)
|
friend FArchive& operator<<(FArchive& Ar, FCursorData& CursorData)
|
||||||
{
|
{
|
||||||
Ar << CursorData.CursorFrameOffset;
|
Ar << CursorData.CursorFrameOffset;
|
||||||
@ -240,6 +250,7 @@ struct CUT5_API FTimelinePropertyData
|
|||||||
Type = InType;
|
Type = InType;
|
||||||
IconPath = InIconPath;
|
IconPath = InIconPath;
|
||||||
}
|
}
|
||||||
|
bool bIsValid = true;
|
||||||
FString Name = "";
|
FString Name = "";
|
||||||
ETrackType Type = ETrackType::VideoTrack;
|
ETrackType Type = ETrackType::VideoTrack;
|
||||||
|
|
||||||
@ -294,6 +305,9 @@ public:
|
|||||||
TickDrag,
|
TickDrag,
|
||||||
CurtainDrag,
|
CurtainDrag,
|
||||||
EffectCardDrag,
|
EffectCardDrag,
|
||||||
|
Device,
|
||||||
|
PresetDrag,
|
||||||
|
CursorDrag,
|
||||||
};
|
};
|
||||||
FCutDragDropBase() {};
|
FCutDragDropBase() {};
|
||||||
FCutDragDropBase(EType InType)
|
FCutDragDropBase(EType InType)
|
||||||
@ -303,8 +317,10 @@ public:
|
|||||||
TSharedPtr<SWidget> DraggingWidget;
|
TSharedPtr<SWidget> DraggingWidget;
|
||||||
TSharedPtr<IWidgetInterface> OverrideWidget;
|
TSharedPtr<IWidgetInterface> OverrideWidget;
|
||||||
TSharedPtr<IWidgetInterface> MoveAboutWidget;
|
TSharedPtr<IWidgetInterface> MoveAboutWidget;
|
||||||
|
class ICutMainWidgetInterface* MainInterface;
|
||||||
float DragOffset = 0.0f;
|
float DragOffset = 0.0f;
|
||||||
EType DragDropType = EType::TrackClip;
|
EType DragDropType = EType::TrackClip;
|
||||||
|
ETrackType ManualClipType = ETrackType::None;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -314,6 +330,13 @@ public:
|
|||||||
// It's a Ptr to Resource;
|
// It's a Ptr to Resource;
|
||||||
FTimelinePropertyData* TimelinePropertyData = nullptr;
|
FTimelinePropertyData* TimelinePropertyData = nullptr;
|
||||||
cv::VideoCapture* VideoCapture;
|
cv::VideoCapture* VideoCapture;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
class CUT5_API FPresetDragOperation final : public FCutDragDropBase
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
// It's a Ptr to Resource;
|
||||||
FPresetsData PresetData = FPresetsData();
|
FPresetsData PresetData = FPresetsData();
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -345,6 +368,20 @@ public:
|
|||||||
FGuid CardGuid;
|
FGuid CardGuid;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class CUT5_API FDeviceDragDrop final : public FCutDragDropBase
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
ETrackType TrackType;
|
||||||
|
FString DeviceName;
|
||||||
|
};
|
||||||
|
|
||||||
|
class CUT5_API FCursorDragDrop final : public FCutDragDropBase
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FCursorData* CursorData;
|
||||||
|
FClipData* ClipData;
|
||||||
|
};
|
||||||
|
|
||||||
struct FTimelineInfo;
|
struct FTimelineInfo;
|
||||||
struct CUT5_API FTimelineInfo
|
struct CUT5_API FTimelineInfo
|
||||||
{
|
{
|
||||||
@ -419,7 +456,7 @@ class FCurtain
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
FString CurtainName = TEXT("新建幕");
|
FString CurtainName = TEXT("新建幕");
|
||||||
FGuid CurtainUUID;
|
FGuid CurtainUUID = FGuid::NewGuid();
|
||||||
bool bIsActive = false;
|
bool bIsActive = false;
|
||||||
|
|
||||||
friend FArchive& operator<< (FArchive& Ar, FCurtain& Curtain)
|
friend FArchive& operator<< (FArchive& Ar, FCurtain& Curtain)
|
||||||
@ -433,7 +470,7 @@ class FCurtainGroup
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
FString GroupName = TEXT("新建组");
|
FString GroupName = TEXT("新建组");
|
||||||
FGuid GroupUID;
|
FGuid GroupUID = FGuid::NewGuid();
|
||||||
TArray<FCurtain> Curtains;
|
TArray<FCurtain> Curtains;
|
||||||
bool bIsActive = false;
|
bool bIsActive = false;
|
||||||
|
|
||||||
|
@ -19,6 +19,22 @@ DragDropOperator* DragDropOperator::GetDragDropOperator()
|
|||||||
|
|
||||||
void DragDropOperator::OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent)
|
void DragDropOperator::OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent)
|
||||||
{
|
{
|
||||||
|
if (TSharedPtr<FCursorDragDrop> DragDrop = DragDropEvent.GetOperationAs<FCursorDragDrop>())
|
||||||
|
{
|
||||||
|
if (DragDrop->DragDropType == FCutDragDropBase::EType::CursorDrag)
|
||||||
|
{
|
||||||
|
TSharedPtr<STrackBody> Body = StaticCastSharedPtr<STrackBody>(DragDrop->OverrideWidget);
|
||||||
|
const FVector2D LocalPos = Body->GetCachedGeometry().AbsoluteToLocal(DragDropEvent.GetScreenSpacePosition());
|
||||||
|
if (LocalPos.X <= DragDrop->ClipData->ClipStartFrame * FGlobalData::DefaultTimeTickSpace || LocalPos.X >= DragDrop->ClipData->ClipEndFrame * FGlobalData::DefaultTimeTickSpace)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
float Offset = LocalPos.X;
|
||||||
|
DragDrop->CursorData->CursorFrameOffset = Offset / FGlobalData::DefaultTimeTickSpace - DragDrop->ClipData->ClipStartFrame;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
const auto& DragDropOperation = static_cast<FClip2ClipDragDropOperation&>(DragDropEvent.GetOperation().ToSharedRef().Get());
|
const auto& DragDropOperation = static_cast<FClip2ClipDragDropOperation&>(DragDropEvent.GetOperation().ToSharedRef().Get());
|
||||||
|
|
||||||
TSharedPtr<STrackBody> Body = StaticCastSharedPtr<STrackBody>(DragDropOperation.OverrideWidget);
|
TSharedPtr<STrackBody> Body = StaticCastSharedPtr<STrackBody>(DragDropOperation.OverrideWidget);
|
||||||
@ -49,6 +65,37 @@ void DragDropOperator::OnDragOver(const FGeometry& MyGeometry, const FDragDropEv
|
|||||||
void DragDropOperator::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent, TSharedPtr<SWidget> DropWidget)
|
void DragDropOperator::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent, TSharedPtr<SWidget> DropWidget)
|
||||||
{
|
{
|
||||||
const auto& DragDropOperation = static_cast<FTrackClipDragOperation&>(DragDropEvent.GetOperation().ToSharedRef().Get());
|
const auto& DragDropOperation = static_cast<FTrackClipDragOperation&>(DragDropEvent.GetOperation().ToSharedRef().Get());
|
||||||
|
if (DragDropOperation.DragDropType == FCutDragDropBase::EType::PresetDrag)
|
||||||
|
{
|
||||||
|
TSharedPtr<FPresetDragOperation> PresetDragOperation = DragDropEvent.GetOperationAs<FPresetDragOperation>();
|
||||||
|
TSharedPtr<STrackBody> TrackBody = StaticCastSharedPtr<STrackBody>(DropWidget);
|
||||||
|
TSharedPtr<STrackHead> TrackHead = TrackBody->TrackHead;
|
||||||
|
FClipData NewClipData;
|
||||||
|
NewClipData.PresetType = PresetDragOperation->PresetData.PresetType;
|
||||||
|
NewClipData.ClipGuid = FGuid::NewGuid();
|
||||||
|
NewClipData.ClipType = PresetDragOperation->ManualClipType;
|
||||||
|
NewClipData.ClipStartFrame = MyGeometry.AbsoluteToLocal(DragDropEvent.GetScreenSpacePosition()).X / FGlobalData::DefaultTimeTickSpace;
|
||||||
|
NewClipData.ClipEndFrame = (MyGeometry.AbsoluteToLocal(DragDropEvent.GetScreenSpacePosition()).X + 100) / FGlobalData::DefaultTimeTickSpace;
|
||||||
|
NewClipData.ClipColors.Add(FLinearColor(1, 1, 1, 1));
|
||||||
|
NewClipData.Cursors.Add(FCursorData(0, FLinearColor(1, 0, 0, 1)));
|
||||||
|
NewClipData.Cursors.Add(FCursorData(5, FLinearColor(0, 1, 1, 1)));
|
||||||
|
TrackHead->TrackData.ClipData.Add(NewClipData);
|
||||||
|
TrackBody->CallRender();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (DragDropOperation.DragDropType == FCutDragDropBase::EType::Device)
|
||||||
|
{
|
||||||
|
TSharedPtr<STrackBody> TrackBody = StaticCastSharedPtr<STrackBody>(DropWidget);
|
||||||
|
TSharedPtr<STrackHead> TrackHead = TrackBody->TrackHead;
|
||||||
|
TSharedPtr<FDeviceDragDrop> CutDragDropBase = DragDropEvent.GetOperationAs<FDeviceDragDrop>();
|
||||||
|
|
||||||
|
FTrackData NewTrackData;
|
||||||
|
NewTrackData.TrackType = CutDragDropBase->TrackType;
|
||||||
|
NewTrackData.TrackName = CutDragDropBase->DeviceName;
|
||||||
|
CutDragDropBase->MainInterface->GetCutTimeline()->AddNewTrackToGroup(TrackHead->GroupName, NewTrackData);
|
||||||
|
CutDragDropBase->MainInterface->OnAddNewTrack(ETrackType::PlayerTrack);
|
||||||
|
return;
|
||||||
|
}
|
||||||
if (DragDropOperation.DragDropType == FCutDragDropBase::EType::TrackClip)
|
if (DragDropOperation.DragDropType == FCutDragDropBase::EType::TrackClip)
|
||||||
{
|
{
|
||||||
TSharedPtr<STrackBody> TrackBody = StaticCastSharedPtr<STrackBody>(DropWidget);
|
TSharedPtr<STrackBody> TrackBody = StaticCastSharedPtr<STrackBody>(DropWidget);
|
||||||
@ -62,7 +109,8 @@ void DragDropOperator::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent&
|
|||||||
{
|
{
|
||||||
if ((ClipDragOperation.TimelinePropertyData->Type == ETrackType::VideoTrack && TrackHead->TrackData.TrackType == ETrackType::LightArrayTrack)
|
if ((ClipDragOperation.TimelinePropertyData->Type == ETrackType::VideoTrack && TrackHead->TrackData.TrackType == ETrackType::LightArrayTrack)
|
||||||
|| (ClipDragOperation.TimelinePropertyData->Type == ETrackType::VideoTrack && TrackHead->TrackData.TrackType == ETrackType::PlayerTrack)
|
|| (ClipDragOperation.TimelinePropertyData->Type == ETrackType::VideoTrack && TrackHead->TrackData.TrackType == ETrackType::PlayerTrack)
|
||||||
|| (ClipDragOperation.TimelinePropertyData->Type == ETrackType::AudioTrack && TrackHead->TrackData.TrackType == ETrackType::AudioTrackR))
|
|| (ClipDragOperation.TimelinePropertyData->Type == ETrackType::AudioTrack && TrackHead->TrackData.TrackType == ETrackType::AudioTrackR)
|
||||||
|
|| (ClipDragOperation.TimelinePropertyData->Type == ETrackType::VideoTrack && TrackHead->TrackData.TrackType == ETrackType::AtomSphereLightTrack))
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -72,76 +120,11 @@ void DragDropOperator::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent&
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ClipDragOperation.PresetData.PresetType != EPresetType::NotAPresets)
|
|
||||||
{
|
|
||||||
FClipData NewClipData;
|
FClipData NewClipData;
|
||||||
NewClipData.ClipGuid = FGuid::NewGuid();
|
NewClipData.ClipGuid = FGuid::NewGuid();
|
||||||
NewClipData.ClipType = ClipDragOperation.TimelinePropertyData->Type;
|
|
||||||
NewClipData.ClipStartFrame = MyGeometry.AbsoluteToLocal(DragDropEvent.GetScreenSpacePosition()).X / FGlobalData::DefaultTimeTickSpace;
|
|
||||||
switch (ClipDragOperation.PresetData.PresetType)
|
|
||||||
{
|
|
||||||
case EPresetType::Color:
|
|
||||||
|
|
||||||
break;
|
NewClipData.ClipType = TrackHead->TrackData.TrackType;
|
||||||
case EPresetType::Video:
|
|
||||||
break;
|
|
||||||
case EPresetType::Gradient:
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
//Overwrite the clip if it is in the same position
|
|
||||||
for (int32 i = TrackHead->TrackData.ClipData.Num() - 1; i >= 0; i--)
|
|
||||||
{
|
|
||||||
const int32 ClipStartFrame = TrackHead->TrackData.ClipData[i].ClipStartFrame;
|
|
||||||
const int32 ClipEndFrame = TrackHead->TrackData.ClipData[i].ClipEndFrame;
|
|
||||||
|
|
||||||
if (NewClipData.ClipStartFrame >= ClipStartFrame && NewClipData.ClipEndFrame <= ClipEndFrame)
|
|
||||||
{
|
|
||||||
// It mean the new clip is in the old clip
|
|
||||||
FClipData SaveClipData = TrackHead->TrackData.ClipData[i];
|
|
||||||
TrackHead->TrackData.ClipData.RemoveAt(i);
|
|
||||||
|
|
||||||
// Left
|
|
||||||
FClipData LeftClipData = SaveClipData;
|
|
||||||
LeftClipData.ClipEndFrame = NewClipData.ClipStartFrame;
|
|
||||||
TrackHead->TrackData.ClipData.Add(LeftClipData);
|
|
||||||
|
|
||||||
FClipData RightClipData = SaveClipData;
|
|
||||||
RightClipData.ClipStartFrame = NewClipData.ClipEndFrame;
|
|
||||||
TrackHead->TrackData.ClipData.Add(RightClipData);
|
|
||||||
|
|
||||||
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (NewClipData.ClipStartFrame <= ClipEndFrame && NewClipData.ClipEndFrame >= ClipEndFrame)
|
|
||||||
{
|
|
||||||
// It mean the new clip start point is in the old clip
|
|
||||||
TrackHead->TrackData.ClipData[i].CropClip(FClipData::ECropMethod::FromBack, (ClipEndFrame - NewClipData.ClipStartFrame));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (NewClipData.ClipEndFrame > ClipStartFrame && NewClipData.ClipStartFrame < ClipStartFrame)
|
|
||||||
{
|
|
||||||
// It mean the new clip end point is in the old clip
|
|
||||||
TrackHead->TrackData.ClipData[i].CropClip(FClipData::ECropMethod::FromFront, (NewClipData.ClipEndFrame - ClipStartFrame));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (NewClipData.ClipStartFrame <= ClipStartFrame && NewClipData.ClipEndFrame >= ClipEndFrame)
|
|
||||||
{
|
|
||||||
// It mean the new clip is out of the old clip
|
|
||||||
TrackHead->TrackData.ClipData.RemoveAt(i);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
TrackHead->TrackData.ClipData.Add(NewClipData);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
FClipData NewClipData;
|
|
||||||
NewClipData.ClipGuid = FGuid::NewGuid();
|
|
||||||
NewClipData.ClipType = ClipDragOperation.TimelinePropertyData->Type;
|
|
||||||
NewClipData.ClipStartFrame = MyGeometry.AbsoluteToLocal(DragDropEvent.GetScreenSpacePosition()).X / FGlobalData::DefaultTimeTickSpace;
|
NewClipData.ClipStartFrame = MyGeometry.AbsoluteToLocal(DragDropEvent.GetScreenSpacePosition()).X / FGlobalData::DefaultTimeTickSpace;
|
||||||
NewClipData.ClipColors.Add(FLinearColor(1, 1, 1, 1));
|
NewClipData.ClipColors.Add(FLinearColor(1, 1, 1, 1));
|
||||||
NewClipData.ResourcePropertyGuid = ClipDragOperation.TimelinePropertyData->Guid;
|
NewClipData.ResourcePropertyGuid = ClipDragOperation.TimelinePropertyData->Guid;
|
||||||
@ -163,6 +146,12 @@ void DragDropOperator::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent&
|
|||||||
NewClipData.PlayerName = TrackBody->MainWidgetInterface->GetGroupName(TrackHead);
|
NewClipData.PlayerName = TrackBody->MainWidgetInterface->GetGroupName(TrackHead);
|
||||||
NewClipData.PlayerLightData = FOpencvUtils::GetVideoSingleLightColor(ClipDragOperation.TimelinePropertyData->MoviePath);
|
NewClipData.PlayerLightData = FOpencvUtils::GetVideoSingleLightColor(ClipDragOperation.TimelinePropertyData->MoviePath);
|
||||||
}
|
}
|
||||||
|
if (TrackHead->TrackData.TrackType == ETrackType::AtomSphereLightTrack)
|
||||||
|
{
|
||||||
|
NewClipData.ClipType = ETrackType::AtomSphereLightTrack;
|
||||||
|
NewClipData.PlayerName = TrackBody->MainWidgetInterface->GetGroupName(TrackHead);
|
||||||
|
NewClipData.PlayerLightData = FOpencvUtils::GetVideoSingleLightColor(ClipDragOperation.TimelinePropertyData->MoviePath);
|
||||||
|
}
|
||||||
if (TrackHead->TrackData.TrackType == ETrackType::VideoTrack)
|
if (TrackHead->TrackData.TrackType == ETrackType::VideoTrack)
|
||||||
{
|
{
|
||||||
SCutMainWindow* MainWidget = static_cast<SCutMainWindow*>(TrackHead->MainWidgetInterface);
|
SCutMainWindow* MainWidget = static_cast<SCutMainWindow*>(TrackHead->MainWidgetInterface);
|
||||||
@ -233,7 +222,7 @@ void DragDropOperator::OnDrop(const FGeometry& MyGeometry, const FDragDropEvent&
|
|||||||
|
|
||||||
}
|
}
|
||||||
TrackHead->TrackData.ClipData.Add(NewClipData);
|
TrackHead->TrackData.ClipData.Add(NewClipData);
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -5,12 +5,15 @@
|
|||||||
|
|
||||||
#include "SlateOptMacros.h"
|
#include "SlateOptMacros.h"
|
||||||
#include "Cut5/Utils/Utils.h"
|
#include "Cut5/Utils/Utils.h"
|
||||||
|
#include "Cut5/Widgets/STimelineClip.h"
|
||||||
|
|
||||||
BEGIN_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
BEGIN_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
|
||||||
void SClipCursor::Construct(const FArguments& InArgs)
|
void SClipCursor::Construct(const FArguments& InArgs)
|
||||||
{
|
{
|
||||||
|
CursorData = InArgs._CursorData;
|
||||||
|
ClipData = InArgs._ClipData;
|
||||||
|
TimelineClip = InArgs._TimelineClip;
|
||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
SNew(SBox)
|
SNew(SBox)
|
||||||
@ -19,9 +22,23 @@ void SClipCursor::Construct(const FArguments& InArgs)
|
|||||||
[
|
[
|
||||||
SNew(SImage)
|
SNew(SImage)
|
||||||
.Image(FUtils::GetBrushFromImage(FUtils::GetResourcesPath(TEXT("Cursor.png")), {}))
|
.Image(FUtils::GetBrushFromImage(FUtils::GetResourcesPath(TEXT("Cursor.png")), {}))
|
||||||
|
.OnMouseButtonDown_Lambda([this](const FGeometry& MyGeometry, const FPointerEvent& MouseEvent)
|
||||||
|
{
|
||||||
|
const TSharedPtr<FCursorDragDrop> Operation = MakeShared<FCursorDragDrop>();
|
||||||
|
Operation->DragDropType = FCutDragDropBase::EType::CursorDrag;
|
||||||
|
Operation->CursorData = CursorData;
|
||||||
|
Operation->ClipData = ClipData;
|
||||||
|
Operation->OverrideWidget = TimelineClip->Body;
|
||||||
|
return FReply::Handled().DetectDrag(SharedThis(this), EKeys::LeftMouseButton).BeginDragDrop(Operation.ToSharedRef());
|
||||||
|
})
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SClipCursor::Tick(const FGeometry& AllottedGeometry, const double InCurrentTime, const float InDeltaTime)
|
||||||
|
{
|
||||||
|
SetRenderTransform(FSlateRenderTransform(FVector2D(CursorData->CursorFrameOffset * FGlobalData::DefaultTimeTickSpace - 11, 0)));
|
||||||
|
}
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -3,6 +3,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "CoreMinimal.h"
|
#include "CoreMinimal.h"
|
||||||
|
#include "Cut5/Widgets/DefineGlobal.h"
|
||||||
#include "Widgets/SCompoundWidget.h"
|
#include "Widgets/SCompoundWidget.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -14,9 +15,16 @@ public:
|
|||||||
SLATE_BEGIN_ARGS(SClipCursor)
|
SLATE_BEGIN_ARGS(SClipCursor)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
SLATE_ARGUMENT(FCursorData*, CursorData);
|
||||||
|
SLATE_ARGUMENT(FClipData*, ClipData);
|
||||||
|
SLATE_ARGUMENT(class STimelineClip*, TimelineClip);
|
||||||
SLATE_END_ARGS()
|
SLATE_END_ARGS()
|
||||||
|
|
||||||
/** Constructs this widget with InArgs */
|
/** Constructs this widget with InArgs */
|
||||||
void Construct(const FArguments& InArgs);
|
void Construct(const FArguments& InArgs);
|
||||||
|
virtual void Tick(const FGeometry& AllottedGeometry, const double InCurrentTime, const float InDeltaTime) override;
|
||||||
|
FCursorData* CursorData;
|
||||||
|
FClipData* ClipData;
|
||||||
|
class STimelineClip* TimelineClip;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -13,7 +13,7 @@ void SEffectPreset::Construct(const FArguments& InArgs)
|
|||||||
Name = InArgs._Name;
|
Name = InArgs._Name;
|
||||||
PresetPath = InArgs._PresetPath;
|
PresetPath = InArgs._PresetPath;
|
||||||
MainInterface = InArgs._MainInterface;
|
MainInterface = InArgs._MainInterface;
|
||||||
PresetsData.PresetType = EPresetType::Video;
|
PresetsData.PresetType = EPresetType::Gradient;
|
||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
SNew(SBox)
|
SNew(SBox)
|
||||||
@ -294,9 +294,9 @@ TSharedPtr<SWidget> SEffectPreset::GetPropertiesWidget()
|
|||||||
|
|
||||||
FReply SEffectPreset::OnDragDetected(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent)
|
FReply SEffectPreset::OnDragDetected(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent)
|
||||||
{
|
{
|
||||||
TSharedPtr<FTrackClipDragOperation> DragOperation = MakeShared<FTrackClipDragOperation>();
|
TSharedPtr<FPresetDragOperation> DragOperation = MakeShared<FPresetDragOperation>();
|
||||||
|
|
||||||
DragOperation->DragDropType = FCutDragDropBase::EType::TrackClip;
|
DragOperation->DragDropType = FCutDragDropBase::EType::PresetDrag;
|
||||||
DragOperation->PresetData = PresetsData;
|
DragOperation->PresetData = PresetsData;
|
||||||
return FReply::Handled().BeginDragDrop(DragOperation.ToSharedRef());
|
return FReply::Handled().BeginDragDrop(DragOperation.ToSharedRef());
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include "Cut5/Utils/OpencvUtils.h"
|
#include "Cut5/Utils/OpencvUtils.h"
|
||||||
#include "Cut5/Utils/Utils.h"
|
#include "Cut5/Utils/Utils.h"
|
||||||
#include "Kismet/GameplayStatics.h"
|
#include "Kismet/GameplayStatics.h"
|
||||||
|
#include "MicroWidgets/STips.h"
|
||||||
#include "Presets/SEffectPreset.h"
|
#include "Presets/SEffectPreset.h"
|
||||||
#include "Widgets/Layout/SWidgetSwitcher.h"
|
#include "Widgets/Layout/SWidgetSwitcher.h"
|
||||||
|
|
||||||
@ -206,6 +207,10 @@ void SCustomInputPanel::Construct(const FArguments& InArgs)
|
|||||||
.OnClicked_Lambda([this]()
|
.OnClicked_Lambda([this]()
|
||||||
{
|
{
|
||||||
if (bIsEditMode)
|
if (bIsEditMode)
|
||||||
|
{
|
||||||
|
GEngine->GameViewport->AddViewportWidgetContent(SNew(STips)
|
||||||
|
.Title(TEXT("确定删除预设吗?"))
|
||||||
|
.SubTitle(TEXT("删除整个组和所有组下特效卡的预设且不可恢复")).OnEnsure_Lambda([this](const FString& String)
|
||||||
{
|
{
|
||||||
for (int32 i = 0; i < SelectedProperties.Num(); i++)
|
for (int32 i = 0; i < SelectedProperties.Num(); i++)
|
||||||
{
|
{
|
||||||
@ -224,12 +229,18 @@ void SCustomInputPanel::Construct(const FArguments& InArgs)
|
|||||||
{
|
{
|
||||||
if (PropertyData[j].Guid == SelectedProperties[i].Guid)
|
if (PropertyData[j].Guid == SelectedProperties[i].Guid)
|
||||||
{
|
{
|
||||||
|
PropertyData[j].bIsValid = false;
|
||||||
PropertyData.RemoveAt(j);
|
PropertyData.RemoveAt(j);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
MainWidgetInterface->DeleteAllAssetsInTimeline();
|
||||||
|
}), 1);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return FReply::Handled();
|
return FReply::Handled();
|
||||||
}
|
}
|
||||||
IDesktopPlatform* DesktopPlatformModule = FDesktopPlatformModule::Get();
|
IDesktopPlatform* DesktopPlatformModule = FDesktopPlatformModule::Get();
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
#include "DragDropOperator/DragDropOperator.h"
|
#include "DragDropOperator/DragDropOperator.h"
|
||||||
#include "FX/SEffectCardsPanel.h"
|
#include "FX/SEffectCardsPanel.h"
|
||||||
#include "HAL/FileManagerGeneric.h"
|
#include "HAL/FileManagerGeneric.h"
|
||||||
|
#include "Kismet/KismetSystemLibrary.h"
|
||||||
#include "MicroWidgets/SNewProjectTips.h"
|
#include "MicroWidgets/SNewProjectTips.h"
|
||||||
#include "StatePanel/SStatePanel.h"
|
#include "StatePanel/SStatePanel.h"
|
||||||
#include "Widgets/Layout/SConstraintCanvas.h"
|
#include "Widgets/Layout/SConstraintCanvas.h"
|
||||||
@ -62,7 +63,7 @@ void SCutMainWindow::Construct(const FArguments& InArgs)
|
|||||||
|
|
||||||
CommandList->MapAction(FMainMenuCommands::Get().Exit, FExecuteAction::CreateLambda([this]()
|
CommandList->MapAction(FMainMenuCommands::Get().Exit, FExecuteAction::CreateLambda([this]()
|
||||||
{
|
{
|
||||||
exit(0);
|
FPlatformMisc::RequestExit(true);
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
|
||||||
@ -201,6 +202,7 @@ void SCutMainWindow::Construct(const FArguments& InArgs)
|
|||||||
// Property Panel
|
// Property Panel
|
||||||
SNew(STimelinePropertyPanel)
|
SNew(STimelinePropertyPanel)
|
||||||
.MainWindow(SharedThis(this))
|
.MainWindow(SharedThis(this))
|
||||||
|
.MainInterface(this)
|
||||||
]
|
]
|
||||||
+ SWidgetSwitcher::Slot()
|
+ SWidgetSwitcher::Slot()
|
||||||
[
|
[
|
||||||
@ -274,11 +276,21 @@ void SCutMainWindow::Render()
|
|||||||
StatePanel->PlayerList2->ClearChildren();
|
StatePanel->PlayerList2->ClearChildren();
|
||||||
PlayerLightsSlateInstances.Empty();
|
PlayerLightsSlateInstances.Empty();
|
||||||
bool bSingle = false;
|
bool bSingle = false;
|
||||||
|
for (FTrackGroup& TrackGroup : CutTimeline->TrackGroups)
|
||||||
|
{
|
||||||
|
if (TrackGroup.GroupType == ETrackType::PlayerTrack)
|
||||||
|
{
|
||||||
|
int32 i = 0;
|
||||||
|
FString LastGroupName;
|
||||||
for (FSingleTrackGroupInstance& TrackGroupInstance : CutTimeline->TrackGroupInstances)
|
for (FSingleTrackGroupInstance& TrackGroupInstance : CutTimeline->TrackGroupInstances)
|
||||||
{
|
{
|
||||||
if (StaticCastSharedPtr<STrackHead>(TrackGroupInstance.Head)->TrackData.TrackType == ETrackType::PlayerTrack)
|
if (LastGroupName != TrackGroupInstance.GroupName)
|
||||||
|
i = 0;
|
||||||
|
if (TrackGroupInstance.GroupName == TrackGroup.GroupName && StaticCastSharedPtr<STrackHead>(TrackGroupInstance.GetHead())->TrackData.TrackType == ETrackType::AtomSphereLightTrack)
|
||||||
{
|
{
|
||||||
TSharedPtr<SPlayerLight> PlayerLight = SNew(SPlayerLight).Name(TrackGroupInstance.GroupName).TrackHead(TrackGroupInstance.Head);
|
LastGroupName = TrackGroupInstance.GroupName;
|
||||||
|
FString NewName = TrackGroupInstance.GroupName + FString::FromInt(i);
|
||||||
|
TSharedPtr<SPlayerLight> PlayerLight = SNew(SPlayerLight).Name(NewName).TrackHead(TrackGroupInstance.Head);
|
||||||
(bSingle ? StatePanel->PlayerList1 : StatePanel->PlayerList2)->AddSlot()
|
(bSingle ? StatePanel->PlayerList1 : StatePanel->PlayerList2)->AddSlot()
|
||||||
[
|
[
|
||||||
PlayerLight.ToSharedRef()
|
PlayerLight.ToSharedRef()
|
||||||
@ -286,8 +298,14 @@ void SCutMainWindow::Render()
|
|||||||
bSingle = !bSingle;
|
bSingle = !bSingle;
|
||||||
PlayerLightsSlateInstances.Add(PlayerLight);
|
PlayerLightsSlateInstances.Add(PlayerLight);
|
||||||
}
|
}
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
FReply SCutMainWindow::OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent)
|
FReply SCutMainWindow::OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent)
|
||||||
@ -820,5 +838,14 @@ void SCutMainWindow::ClearProperties()
|
|||||||
CustomPanel->UpdateProperties(nullptr);
|
CustomPanel->UpdateProperties(nullptr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SCutMainWindow::DeleteAllAssetsInTimeline()
|
||||||
|
{
|
||||||
|
for (int32 i = 0; i < CutTimeline->TrackGroupInstances.Num(); i++)
|
||||||
|
{
|
||||||
|
CutTimeline->TrackGroupInstances[i].Body->DeleteUseLessClips();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -70,6 +70,6 @@ public:
|
|||||||
virtual FString GetGroupName(TSharedPtr<IWidgetInterface> WidgetInterface) override;
|
virtual FString GetGroupName(TSharedPtr<IWidgetInterface> WidgetInterface) override;
|
||||||
virtual void UpdateProperties(IPropertiesInterface* Interface) override;
|
virtual void UpdateProperties(IPropertiesInterface* Interface) override;
|
||||||
virtual void ClearProperties() override;
|
virtual void ClearProperties() override;
|
||||||
|
virtual void DeleteAllAssetsInTimeline() override;
|
||||||
|
virtual SCutTimeline* GetCutTimeline() override { return CutTimeline.Get(); };
|
||||||
};
|
};
|
||||||
|
@ -143,8 +143,25 @@ void SCutTimeline::Construct(const FArguments& InArgs)
|
|||||||
SNew(SImage)
|
SNew(SImage)
|
||||||
.Image(FUtils::GetBrushFromImage(FUtils::GetResourcesPath("PlayButton.png"), {}))
|
.Image(FUtils::GetBrushFromImage(FUtils::GetResourcesPath("PlayButton.png"), {}))
|
||||||
]
|
]
|
||||||
|
+ SHorizontalBox::Slot()
|
||||||
|
.SizeParam(FStretch(1.0))
|
||||||
|
[
|
||||||
|
SNew(SSlider)
|
||||||
|
.Value(0.0f)
|
||||||
|
.OnValueChanged_Lambda([this](float ChangedValue)
|
||||||
|
{
|
||||||
|
TrackBodyHScrollBox->SetScrollOffset(ChangedValue * TrackBodyHScrollBox->GetScrollOffsetOfEnd());
|
||||||
|
TickScrollBox->SetScrollOffset(ChangedValue * TickScrollBox->GetScrollOffsetOfEnd());
|
||||||
|
FGlobalData::CurrentTimeScroll = ChangedValue;
|
||||||
|
})
|
||||||
|
]
|
||||||
|
+ SHorizontalBox::Slot()
|
||||||
|
.SizeParam(FAuto())
|
||||||
|
[
|
||||||
|
SAssignNew(CurrentEditDebug, STextBlock)
|
||||||
|
.Text(FText::FromString(TEXT("当前正在编辑主面板")))
|
||||||
|
|
||||||
|
]
|
||||||
]
|
]
|
||||||
|
|
||||||
]
|
]
|
||||||
@ -155,7 +172,7 @@ void SCutTimeline::Construct(const FArguments& InArgs)
|
|||||||
// Timeline
|
// Timeline
|
||||||
SNew(SHorizontalBox)
|
SNew(SHorizontalBox)
|
||||||
+ SHorizontalBox::Slot()
|
+ SHorizontalBox::Slot()
|
||||||
.SizeParam(FStretch(0.015f))
|
.SizeParam(FStretch(0.02f))
|
||||||
[
|
[
|
||||||
SNew(SVerticalBox)
|
SNew(SVerticalBox)
|
||||||
+ SVerticalBox::Slot()
|
+ SVerticalBox::Slot()
|
||||||
@ -239,27 +256,10 @@ void SCutTimeline::Construct(const FArguments& InArgs)
|
|||||||
})
|
})
|
||||||
]
|
]
|
||||||
]
|
]
|
||||||
+ SVerticalBox::Slot()
|
|
||||||
.SizeParam(FAuto())
|
|
||||||
[
|
|
||||||
SNew(SSlider)
|
|
||||||
.Value(0.0f)
|
|
||||||
.OnValueChanged_Lambda([this](float ChangedValue)
|
|
||||||
{
|
|
||||||
TrackBodyHScrollBox->SetScrollOffset(ChangedValue * TrackBodyHScrollBox->GetScrollOffsetOfEnd());
|
|
||||||
TickScrollBox->SetScrollOffset(ChangedValue * TickScrollBox->GetScrollOffsetOfEnd());
|
|
||||||
FGlobalData::CurrentTimeScroll = ChangedValue;
|
|
||||||
})
|
|
||||||
]
|
|
||||||
]
|
|
||||||
]
|
|
||||||
+ SVerticalBox::Slot()
|
|
||||||
.SizeParam(FAuto())
|
|
||||||
[
|
|
||||||
SAssignNew(CurrentEditDebug, STextBlock)
|
|
||||||
.Text(FText::FromString(TEXT("当前正在编辑主面板")))
|
|
||||||
|
|
||||||
]
|
]
|
||||||
|
]
|
||||||
|
|
||||||
+ SVerticalBox::Slot()
|
+ SVerticalBox::Slot()
|
||||||
.SizeParam(FAuto())
|
.SizeParam(FAuto())
|
||||||
[
|
[
|
||||||
@ -363,13 +363,13 @@ TSharedPtr<SWidget> FSingleTrackGroupInstance::GetBody() const
|
|||||||
|
|
||||||
void SCutTimeline::AddNewTrack(FTrackData TrackData, int32 TrackIndex, FString GroupName)
|
void SCutTimeline::AddNewTrack(FTrackData TrackData, int32 TrackIndex, FString GroupName)
|
||||||
{
|
{
|
||||||
const TSharedPtr<STrackHead> NewTrackHead = SNew(STrackHead).TrackData(TrackData).CutTimeline(SharedThis(this)).MainWidgetInterface(MainWidgetInterface);
|
const TSharedPtr<STrackHead> NewTrackHead = SNew(STrackHead).TrackData(TrackData).CutTimeline(SharedThis(this)).MainWidgetInterface(MainWidgetInterface).GroupName(GroupName);
|
||||||
const TSharedPtr<STrackBody> NewTrackBody = SNew(STrackBody).TrackHead(NewTrackHead).MainWidgetInterface(MainWidgetInterface);
|
const TSharedPtr<STrackBody> NewTrackBody = SNew(STrackBody).TrackHead(NewTrackHead).MainWidgetInterface(MainWidgetInterface);
|
||||||
NewTrackBody->CallRender();
|
NewTrackBody->CallRender();
|
||||||
TrackGroupInstances.Add(FSingleTrackGroupInstance(NewTrackHead, NewTrackBody, GroupName));
|
TrackGroupInstances.Add(FSingleTrackGroupInstance(NewTrackHead, NewTrackBody, GroupName));
|
||||||
}
|
}
|
||||||
|
|
||||||
void SCutTimeline::AddNewTrackToGroup(FString GroupName, FTrackData TrackData)
|
void SCutTimeline::AddNewTrackToGroup(FString GroupName, FTrackData TrackData, ETrackType GroupType)
|
||||||
{
|
{
|
||||||
bool bHasGroup = false;
|
bool bHasGroup = false;
|
||||||
for (FTrackGroup& Group : TrackGroups)
|
for (FTrackGroup& Group : TrackGroups)
|
||||||
@ -386,11 +386,12 @@ void SCutTimeline::AddNewTrackToGroup(FString GroupName, FTrackData TrackData)
|
|||||||
// Add New Group
|
// Add New Group
|
||||||
FTrackGroup NewGroup(GroupName);
|
FTrackGroup NewGroup(GroupName);
|
||||||
NewGroup.TrackDataArray.Add(TrackData);
|
NewGroup.TrackDataArray.Add(TrackData);
|
||||||
|
NewGroup.GroupType = GroupType;
|
||||||
TrackGroups.Add(NewGroup);
|
TrackGroups.Add(NewGroup);
|
||||||
}
|
}
|
||||||
AddNewTrack(TrackData, 0, GroupName);
|
AddNewTrack(TrackData, 0, GroupName);
|
||||||
RenderGroup();
|
RenderGroup();
|
||||||
MainWidgetInterface->OnAddNewTrack(TrackData.TrackType);
|
MainWidgetInterface->OnAddNewTrack(GroupType);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -416,6 +417,7 @@ void SCutTimeline::OnGroupNameEdited(FString NewText, FString OldText)
|
|||||||
|
|
||||||
if (TSharedPtr<STrackHead> Head = StaticCastSharedPtr<STrackHead>(SingleTrackGroupInstance.Head))
|
if (TSharedPtr<STrackHead> Head = StaticCastSharedPtr<STrackHead>(SingleTrackGroupInstance.Head))
|
||||||
{
|
{
|
||||||
|
Head->GroupName = NewText;
|
||||||
if (Head->TrackData.TrackType == ETrackType::PlayerTrack)
|
if (Head->TrackData.TrackType == ETrackType::PlayerTrack)
|
||||||
{
|
{
|
||||||
Head->TrackData.TrackName = NewText;
|
Head->TrackData.TrackName = NewText;
|
||||||
@ -424,6 +426,7 @@ void SCutTimeline::OnGroupNameEdited(FString NewText, FString OldText)
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
MainWidgetInterface->OnAddNewTrack(ETrackType::PlayerTrack);
|
||||||
RenderGroup();
|
RenderGroup();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -443,7 +446,7 @@ void SCutTimeline::RenderGroup()
|
|||||||
SNew(SBox)
|
SNew(SBox)
|
||||||
.HAlign(HAlign_Fill)
|
.HAlign(HAlign_Fill)
|
||||||
.VAlign(VAlign_Fill)
|
.VAlign(VAlign_Fill)
|
||||||
.HeightOverride(FGlobalData::DefaultTrackHeight * TrackGroups[i].TrackDataArray.Num())
|
.HeightOverride(FGlobalData::DefaultTrackHeight * (TrackGroups[i].GroupIsCollapsed ? 1 : TrackGroups[i].TrackDataArray.Num()))
|
||||||
.WidthOverride(24)
|
.WidthOverride(24)
|
||||||
[
|
[
|
||||||
SNew(SOverlay)
|
SNew(SOverlay)
|
||||||
@ -466,15 +469,43 @@ void SCutTimeline::RenderGroup()
|
|||||||
OnGroupNameEdited(NewText.ToString(), TrackGroups[i].GroupName);
|
OnGroupNameEdited(NewText.ToString(), TrackGroups[i].GroupName);
|
||||||
})
|
})
|
||||||
]
|
]
|
||||||
|
+ SOverlay::Slot()
|
||||||
|
.HAlign(HAlign_Center)
|
||||||
|
.VAlign(VAlign_Bottom)
|
||||||
|
.Padding(0, 0, 0, 4)
|
||||||
|
[
|
||||||
|
SNew(SImage)
|
||||||
|
.OnMouseButtonDown_Lambda([this, i](const FGeometry& Geometry, const FPointerEvent& MouseEvent)
|
||||||
|
{
|
||||||
|
if (TrackGroups[i].TrackDataArray.Num() > 1)
|
||||||
|
{
|
||||||
|
TrackGroups[i].GroupIsCollapsed = !TrackGroups[i].GroupIsCollapsed;
|
||||||
|
RenderGroup();
|
||||||
|
}
|
||||||
|
return FReply::Handled();
|
||||||
|
})
|
||||||
|
.Image(TrackGroups[i].GroupIsCollapsed ? FUtils::GetBrushFromImage(FUtils::GetResourcesPath(TEXT("Expaned.png")), {32, 16}) : FUtils::GetBrushFromImage(FUtils::GetResourcesPath(TEXT("Collapse.png")), {32, 16}))
|
||||||
|
]
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
|
|
||||||
// Add Instances to Group
|
// Add Instances to Group
|
||||||
|
int32 TrackIndex = 0;
|
||||||
|
FString LastGroupName;
|
||||||
for (FSingleTrackGroupInstance SingleTrackGroupInstance : TrackGroupInstances)
|
for (FSingleTrackGroupInstance SingleTrackGroupInstance : TrackGroupInstances)
|
||||||
{
|
{
|
||||||
|
if (LastGroupName != TrackGroups[i].GroupName)
|
||||||
|
{
|
||||||
|
TrackIndex = 0;
|
||||||
|
}
|
||||||
if (SingleTrackGroupInstance.GroupName == TrackGroups[i].GroupName)
|
if (SingleTrackGroupInstance.GroupName == TrackGroups[i].GroupName)
|
||||||
{
|
{
|
||||||
|
LastGroupName = SingleTrackGroupInstance.GroupName;
|
||||||
|
if (TrackGroups[i].GroupIsCollapsed == true && TrackIndex > 0)
|
||||||
|
{
|
||||||
|
TrackIndex++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
TrackHeadScrollBox->AddSlot()
|
TrackHeadScrollBox->AddSlot()
|
||||||
[
|
[
|
||||||
SingleTrackGroupInstance.GetHead().ToSharedRef()
|
SingleTrackGroupInstance.GetHead().ToSharedRef()
|
||||||
@ -484,6 +515,7 @@ void SCutTimeline::RenderGroup()
|
|||||||
SingleTrackGroupInstance.GetBody().ToSharedRef()
|
SingleTrackGroupInstance.GetBody().ToSharedRef()
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
TrackIndex++;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -23,6 +23,8 @@ struct FTrackGroup
|
|||||||
GroupName = InGroupName;
|
GroupName = InGroupName;
|
||||||
}
|
}
|
||||||
FString GroupName = "组";
|
FString GroupName = "组";
|
||||||
|
ETrackType GroupType = ETrackType::None;
|
||||||
|
bool GroupIsCollapsed = false;
|
||||||
TArray<FTrackData> TrackDataArray;
|
TArray<FTrackData> TrackDataArray;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -38,6 +40,7 @@ struct FSingleTrackGroupInstance
|
|||||||
TSharedPtr<SWidget> GetHead() const;
|
TSharedPtr<SWidget> GetHead() const;
|
||||||
TSharedPtr<SWidget> GetBody() const;
|
TSharedPtr<SWidget> GetBody() const;
|
||||||
FString GroupName;
|
FString GroupName;
|
||||||
|
|
||||||
TSharedPtr<IWidgetInterface> Head;
|
TSharedPtr<IWidgetInterface> Head;
|
||||||
TSharedPtr<IWidgetInterface> Body;
|
TSharedPtr<IWidgetInterface> Body;
|
||||||
};
|
};
|
||||||
@ -60,7 +63,7 @@ public:
|
|||||||
void Construct(const FArguments& InArgs);
|
void Construct(const FArguments& InArgs);
|
||||||
virtual void Tick(const FGeometry& AllottedGeometry, const double InCurrentTime, const float InDeltaTime) override;
|
virtual void Tick(const FGeometry& AllottedGeometry, const double InCurrentTime, const float InDeltaTime) override;
|
||||||
float TimeSpace = 0.0f;
|
float TimeSpace = 0.0f;
|
||||||
void AddNewTrackToGroup(FString GroupName, FTrackData TrackData);
|
void AddNewTrackToGroup(FString GroupName, FTrackData TrackData, ETrackType GroupType = ETrackType::None);
|
||||||
void SetAutoPlay(bool bStart);
|
void SetAutoPlay(bool bStart);
|
||||||
bool AutoPlaying = false;
|
bool AutoPlaying = false;
|
||||||
|
|
||||||
|
@ -17,10 +17,19 @@ void SPlayerLight::Construct(const FArguments& InArgs)
|
|||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
SNew(SScaleBox)
|
SNew(SScaleBox)
|
||||||
|
[
|
||||||
|
SNew(SVerticalBox)
|
||||||
|
+ SVerticalBox::Slot()
|
||||||
[
|
[
|
||||||
SAssignNew(PlayerLightImage, SImage)
|
SAssignNew(PlayerLightImage, SImage)
|
||||||
.Image(SlateDynamicImageBrush)
|
.Image(SlateDynamicImageBrush)
|
||||||
]
|
]
|
||||||
|
+ SVerticalBox::Slot()
|
||||||
|
[
|
||||||
|
SNew(STextBlock)
|
||||||
|
.Text(FText::FromString(Name))
|
||||||
|
]
|
||||||
|
]
|
||||||
];
|
];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -7,13 +7,16 @@
|
|||||||
|
|
||||||
|
|
||||||
#include "AudioDevice.h"
|
#include "AudioDevice.h"
|
||||||
|
#include "SCutTimeline.h"
|
||||||
#include "SlateOptMacros.h"
|
#include "SlateOptMacros.h"
|
||||||
#include "Commands/TimelineClipCommands.h"
|
#include "Commands/TimelineClipCommands.h"
|
||||||
#include "Cut5/WidgetInterface.h"
|
#include "Cut5/WidgetInterface.h"
|
||||||
#include "Cut5/Utils/Utils.h"
|
#include "Cut5/Utils/Utils.h"
|
||||||
|
#include "DragDropOperator/DragDropOperator.h"
|
||||||
#include "Engine/Engine.h"
|
#include "Engine/Engine.h"
|
||||||
#include "Engine/Texture2D.h"
|
#include "Engine/Texture2D.h"
|
||||||
#include "Presets/SClipCursor.h"
|
#include "Presets/SClipCursor.h"
|
||||||
|
#include "Rendering/DrawElementPayloads.h"
|
||||||
#include "Slate/Private/Framework/Application/Menu.h"
|
#include "Slate/Private/Framework/Application/Menu.h"
|
||||||
|
|
||||||
extern "C"
|
extern "C"
|
||||||
@ -43,17 +46,19 @@ FReply STimelineClip::OnBorderMouseButtonDown(const FGeometry& Geometry, const F
|
|||||||
}
|
}
|
||||||
|
|
||||||
MainWidgetInterface->SelectClip(ClipData->ClipGuid);
|
MainWidgetInterface->SelectClip(ClipData->ClipGuid);
|
||||||
if (ClipData->PresetType != EPresetType::NotAPresets)
|
// if (ClipData->PresetType != EPresetType::NotAPresets)
|
||||||
{
|
// {
|
||||||
for (int32 i = 0; i < ClipData->Cursors.Num(); i++)
|
// for (int32 i = 0; i < ClipData->Cursors.Num(); i++)
|
||||||
{
|
// {
|
||||||
TSharedPtr<SClipCursor> ClipCursor = SNew(SClipCursor);
|
// TSharedPtr<SClipCursor> ClipCursor = SNew(SClipCursor).CursorData(&ClipData->Cursors[i]); // .RenderTransform(FSlateRenderTransform(FVector2D(0, 0)));
|
||||||
ClipOverlay->AddSlot()
|
// ClipOverlay->AddSlot()
|
||||||
[
|
// .HAlign(HAlign_Left)
|
||||||
ClipCursor.ToSharedRef()
|
// .VAlign(VAlign_Center)
|
||||||
];
|
// [
|
||||||
}
|
// ClipCursor.ToSharedRef()
|
||||||
}
|
// ];
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
const FVector2D LocalPos = Geometry.AbsoluteToLocal(PointerEvent.GetScreenSpacePosition());
|
const FVector2D LocalPos = Geometry.AbsoluteToLocal(PointerEvent.GetScreenSpacePosition());
|
||||||
|
|
||||||
@ -97,6 +102,7 @@ void STimelineClip::Construct(const FArguments& InArgs)
|
|||||||
MainWidgetInterface = InArgs._MainWidgetInterface;
|
MainWidgetInterface = InArgs._MainWidgetInterface;
|
||||||
Body = InArgs._Body;
|
Body = InArgs._Body;
|
||||||
SetRenderTransform(FSlateRenderTransform(FVector2D(ClipData->ClipStartFrame * FGlobalData::DefaultTimeTickSpace, 0)));
|
SetRenderTransform(FSlateRenderTransform(FVector2D(ClipData->ClipStartFrame * FGlobalData::DefaultTimeTickSpace, 0)));
|
||||||
|
TSharedPtr<SClipCursor> ClipCursor = SNew(SClipCursor).RenderTransform(FSlateRenderTransform(FVector2D(0, 0)));
|
||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
SAssignNew(ClipDataBox, SBox)
|
SAssignNew(ClipDataBox, SBox)
|
||||||
@ -113,12 +119,29 @@ void STimelineClip::Construct(const FArguments& InArgs)
|
|||||||
.BorderBackgroundColor(ClipData->ClipColors[0])
|
.BorderBackgroundColor(ClipData->ClipColors[0])
|
||||||
.OnMouseButtonDown(this, &STimelineClip::OnBorderMouseButtonDown)
|
.OnMouseButtonDown(this, &STimelineClip::OnBorderMouseButtonDown)
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
]
|
]
|
||||||
];
|
];
|
||||||
if (ClipData->ClipType == ETrackType::AudioTrack)
|
if (ClipData->ClipType == ETrackType::AudioTrack)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
if (MainWidgetInterface->GetCutTimeline()->SelectedClipGUID == ClipData->ClipGuid)
|
||||||
|
{
|
||||||
|
for (int32 i = 0; i < ClipData->Cursors.Num(); i++)
|
||||||
|
{
|
||||||
|
TSharedPtr<SClipCursor> NewClipCursor = SNew(SClipCursor).CursorData(&ClipData->Cursors[i])
|
||||||
|
.TimelineClip(this)
|
||||||
|
.ClipData(ClipData).RenderTransform(FSlateRenderTransform(FVector2D(ClipData->Cursors[i].CursorFrameOffset * FGlobalData::DefaultTimeTickSpace - 11, 0)));
|
||||||
|
ClipOverlay->AddSlot()
|
||||||
|
.HAlign(HAlign_Left)
|
||||||
|
.VAlign(VAlign_Center)
|
||||||
|
[
|
||||||
|
NewClipCursor.ToSharedRef()
|
||||||
|
];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -253,6 +276,16 @@ void STimelineClip::Seek(int32 Frame)
|
|||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
case ETrackType::AtomSphereLightTrack:
|
||||||
|
{
|
||||||
|
const int32 Offset = Frame - ClipData->ClipStartFrame;
|
||||||
|
const int32 SeekMovieFrame = ClipData->VideoStartFrame + Offset;
|
||||||
|
if (SeekMovieFrame < ClipData->PlayerLightData.Num())
|
||||||
|
{
|
||||||
|
MainWidgetInterface->OnUpdatePlayers(Body, ClipData->PlayerLightData[SeekMovieFrame]);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -266,6 +299,7 @@ void STimelineClip::UpdatePosition(int32 StartFrame)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const int32 NewPosX = StartFrame * FGlobalData::DefaultTimeTickSpace;
|
const int32 NewPosX = StartFrame * FGlobalData::DefaultTimeTickSpace;
|
||||||
|
GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Red, FString::FromInt(NewPosX));
|
||||||
SetRenderTransform(FSlateRenderTransform(FVector2D(NewPosX, 0)));
|
SetRenderTransform(FSlateRenderTransform(FVector2D(NewPosX, 0)));
|
||||||
ClipDataBox->SetWidthOverride((ClipData->ClipEndFrame - StartFrame) * FGlobalData::DefaultTimeTickSpace);
|
ClipDataBox->SetWidthOverride((ClipData->ClipEndFrame - StartFrame) * FGlobalData::DefaultTimeTickSpace);
|
||||||
if (ClipData->ClipType == ETrackType::VideoTrack)
|
if (ClipData->ClipType == ETrackType::VideoTrack)
|
||||||
@ -273,6 +307,7 @@ void STimelineClip::UpdatePosition(int32 StartFrame)
|
|||||||
ClipData->VideoStartFrame += StartFrame - ClipData->ClipStartFrame;
|
ClipData->VideoStartFrame += StartFrame - ClipData->ClipStartFrame;
|
||||||
}
|
}
|
||||||
ClipData->ClipStartFrame = StartFrame;
|
ClipData->ClipStartFrame = StartFrame;
|
||||||
|
GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Red, FString::FromInt(ClipData->ClipStartFrame));
|
||||||
}
|
}
|
||||||
|
|
||||||
void STimelineClip::UpdateLength(int32 EndFrame)
|
void STimelineClip::UpdateLength(int32 EndFrame)
|
||||||
@ -283,6 +318,7 @@ void STimelineClip::UpdateLength(int32 EndFrame)
|
|||||||
ClipData->VideoEndFrame += EndFrame - ClipData->ClipEndFrame;
|
ClipData->VideoEndFrame += EndFrame - ClipData->ClipEndFrame;
|
||||||
}
|
}
|
||||||
ClipData->ClipEndFrame = EndFrame;
|
ClipData->ClipEndFrame = EndFrame;
|
||||||
|
GEngine->AddOnScreenDebugMessage(-1, 10.0f, FColor::Red, FString::FromInt(ClipData->ClipEndFrame));
|
||||||
}
|
}
|
||||||
|
|
||||||
void STimelineClip::UpdateMove(int32 X, int32 DragOffset)
|
void STimelineClip::UpdateMove(int32 X, int32 DragOffset)
|
||||||
@ -293,6 +329,7 @@ void STimelineClip::UpdateMove(int32 X, int32 DragOffset)
|
|||||||
ClipDataBox->SetWidthOverride(Length * FGlobalData::DefaultTimeTickSpace);
|
ClipDataBox->SetWidthOverride(Length * FGlobalData::DefaultTimeTickSpace);
|
||||||
SetRenderTransform(FSlateRenderTransform(FVector2D(ClipData->ClipStartFrame * FGlobalData::DefaultTimeTickSpace, 0)));
|
SetRenderTransform(FSlateRenderTransform(FVector2D(ClipData->ClipStartFrame * FGlobalData::DefaultTimeTickSpace, 0)));
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -307,12 +344,33 @@ int32 STimelineClip::OnPaint(const FPaintArgs& Args, const FGeometry& AllottedGe
|
|||||||
FSlateWindowElementList& OutDrawElements, int32 LayerId, const FWidgetStyle& InWidgetStyle,
|
FSlateWindowElementList& OutDrawElements, int32 LayerId, const FWidgetStyle& InWidgetStyle,
|
||||||
bool bParentEnabled) const
|
bool bParentEnabled) const
|
||||||
{
|
{
|
||||||
const FSlateBrush Brush;
|
// const FSlateBrush Brush;
|
||||||
FSlateDrawElement::MakeBox(OutDrawElements, LayerId, AllottedGeometry.ToPaintGeometry(),
|
// FSlateDrawElement::MakeBox(OutDrawElements, LayerId, AllottedGeometry.ToPaintGeometry(),
|
||||||
&Brush, ESlateDrawEffect::None, FColor(0.5, 0.3, 0.1, 1.0));
|
// &Brush, ESlateDrawEffect::None, FColor(0.5, 0.3, 0.1, 1.0));
|
||||||
|
if (ClipData->PresetType == EPresetType::Gradient)
|
||||||
|
{
|
||||||
|
TArray<FSlateGradientStop> GradientStops;
|
||||||
|
for (int32 i = 0; i < ClipData->Cursors.Num(); i++)
|
||||||
|
{
|
||||||
|
GradientStops.Add(FSlateGradientStop(FVector2D(ClipData->Cursors[i].CursorFrameOffset * FGlobalData::DefaultTimeTickSpace, 0), ClipData->Cursors[i].Color));
|
||||||
|
}
|
||||||
|
|
||||||
|
FSlateDrawElement::MakeGradient(OutDrawElements, LayerId, AllottedGeometry.ToPaintGeometry(),
|
||||||
|
GradientStops,
|
||||||
|
EOrientation::Orient_Vertical, ESlateDrawEffect::None);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return SCompoundWidget::OnPaint(Args, AllottedGeometry, MyCullingRect, OutDrawElements, LayerId, InWidgetStyle,
|
return SCompoundWidget::OnPaint(Args, AllottedGeometry, MyCullingRect, OutDrawElements, LayerId, InWidgetStyle,
|
||||||
bParentEnabled);
|
bParentEnabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
FReply STimelineClip::OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent)
|
||||||
|
{
|
||||||
|
DragDropOperator* DragDropOperation = DragDropOperator::GetDragDropOperator();
|
||||||
|
DragDropOperation->OnDragOver(MyGeometry, DragDropEvent);
|
||||||
|
return SCompoundWidget::OnDragOver(MyGeometry, DragDropEvent);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -51,7 +51,7 @@ public:
|
|||||||
int64 LastTimeStamp = 0;
|
int64 LastTimeStamp = 0;
|
||||||
virtual int32 OnPaint(const FPaintArgs& Args, const FGeometry& AllottedGeometry, const FSlateRect& MyCullingRect, FSlateWindowElementList& OutDrawElements, int32 LayerId, const FWidgetStyle& InWidgetStyle, bool bParentEnabled) const override;
|
virtual int32 OnPaint(const FPaintArgs& Args, const FGeometry& AllottedGeometry, const FSlateRect& MyCullingRect, FSlateWindowElementList& OutDrawElements, int32 LayerId, const FWidgetStyle& InWidgetStyle, bool bParentEnabled) const override;
|
||||||
PaStream* Stream = nullptr;
|
PaStream* Stream = nullptr;
|
||||||
|
virtual FReply OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent) override;
|
||||||
TSharedPtr<SOverlay> ClipOverlay;
|
TSharedPtr<SOverlay> ClipOverlay;
|
||||||
TSharedPtr<FUICommandList> CommandList;
|
TSharedPtr<FUICommandList> CommandList;
|
||||||
|
|
||||||
|
@ -12,6 +12,7 @@ void STimelineProperty::Construct(const FArguments& InArgs)
|
|||||||
{
|
{
|
||||||
TimelinePropertyData = InArgs._TimelinePropertyData;
|
TimelinePropertyData = InArgs._TimelinePropertyData;
|
||||||
MainWindow = InArgs._MainWindow;
|
MainWindow = InArgs._MainWindow;
|
||||||
|
MainInterface = InArgs._MainInterface;
|
||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
SNew(SBox)
|
SNew(SBox)
|
||||||
@ -56,10 +57,13 @@ FReply STimelineProperty::OnMouseButtonDown(const FGeometry& MyGeometry, const F
|
|||||||
FReply STimelineProperty::OnDragDetected(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent)
|
FReply STimelineProperty::OnDragDetected(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent)
|
||||||
{
|
{
|
||||||
UE_LOG(LogTemp, Warning, TEXT("On Drag Detected"));
|
UE_LOG(LogTemp, Warning, TEXT("On Drag Detected"));
|
||||||
const TSharedPtr<FTrackClipDragOperation> Operation = MakeShared<FTrackClipDragOperation>();
|
const TSharedPtr<FDeviceDragDrop> Operation = MakeShared<FDeviceDragDrop>();
|
||||||
Operation->TimelinePropertyData = &TimelinePropertyData;
|
// Operation->TimelinePropertyData = &TimelinePropertyData;
|
||||||
Operation->DraggingWidget = SharedThis(this);
|
Operation->DraggingWidget = SharedThis(this);
|
||||||
Operation->DragDropType = FCutDragDropBase::EType::TrackClip;
|
Operation->DragDropType = FCutDragDropBase::EType::Device;
|
||||||
|
Operation->MainInterface = MainInterface;
|
||||||
|
Operation->DeviceName = TimelinePropertyData.Name;
|
||||||
|
Operation->TrackType = TimelinePropertyData.Type;
|
||||||
return FReply::Handled().BeginDragDrop(Operation.ToSharedRef());
|
return FReply::Handled().BeginDragDrop(Operation.ToSharedRef());
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -20,12 +20,14 @@ public:
|
|||||||
}
|
}
|
||||||
SLATE_ARGUMENT(FTimelinePropertyData, TimelinePropertyData)
|
SLATE_ARGUMENT(FTimelinePropertyData, TimelinePropertyData)
|
||||||
SLATE_ARGUMENT(TSharedPtr<SCutMainWindow>, MainWindow)
|
SLATE_ARGUMENT(TSharedPtr<SCutMainWindow>, MainWindow)
|
||||||
|
SLATE_ARGUMENT(ICutMainWidgetInterface*, MainInterface)
|
||||||
SLATE_END_ARGS()
|
SLATE_END_ARGS()
|
||||||
|
|
||||||
/** Constructs this widget with InArgs */
|
/** Constructs this widget with InArgs */
|
||||||
void Construct(const FArguments& InArgs);
|
void Construct(const FArguments& InArgs);
|
||||||
FTimelinePropertyData TimelinePropertyData;
|
FTimelinePropertyData TimelinePropertyData;
|
||||||
TSharedPtr<SCutMainWindow> MainWindow;
|
TSharedPtr<SCutMainWindow> MainWindow;
|
||||||
|
ICutMainWidgetInterface* MainInterface;
|
||||||
virtual FReply OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
virtual FReply OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
||||||
virtual FReply OnDragDetected(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
virtual FReply OnDragDetected(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
||||||
};
|
};
|
||||||
|
@ -12,6 +12,7 @@ BEGIN_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
|||||||
|
|
||||||
void STimelinePropertyPanel::Construct(const FArguments& InArgs)
|
void STimelinePropertyPanel::Construct(const FArguments& InArgs)
|
||||||
{
|
{
|
||||||
|
MainInterface = InArgs._MainInterface;
|
||||||
MainWindow = InArgs._MainWindow;
|
MainWindow = InArgs._MainWindow;
|
||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
@ -81,8 +82,8 @@ void STimelinePropertyPanel::Construct(const FArguments& InArgs)
|
|||||||
{
|
{
|
||||||
return FReply::Handled();
|
return FReply::Handled();
|
||||||
}
|
}
|
||||||
const FTrackData PlayerData(TEXT("玩家"), ETrackType::PlayerTrack);
|
const FTrackData PlayerData(TEXT("玩家"), ETrackType::AtomSphereLightTrack);
|
||||||
MainWindow->CutTimeline->AddNewTrackToGroup(TEXT("未命名"), PlayerData);
|
MainWindow->CutTimeline->AddNewTrackToGroup(TEXT("未命名"), PlayerData, ETrackType::PlayerTrack);
|
||||||
return FReply::Handled();
|
return FReply::Handled();
|
||||||
})
|
})
|
||||||
]
|
]
|
||||||
@ -111,6 +112,7 @@ void STimelinePropertyPanel::AddNewSelection(FTimelinePropertyData TimelinePrope
|
|||||||
SNew(STimelineProperty)
|
SNew(STimelineProperty)
|
||||||
.TimelinePropertyData(TimelinePropertyData)
|
.TimelinePropertyData(TimelinePropertyData)
|
||||||
.MainWindow(MainWindow)
|
.MainWindow(MainWindow)
|
||||||
|
.MainInterface(MainInterface)
|
||||||
];
|
];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -17,6 +17,7 @@ public:
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
SLATE_ARGUMENT(TSharedPtr<SCutMainWindow>, MainWindow)
|
SLATE_ARGUMENT(TSharedPtr<SCutMainWindow>, MainWindow)
|
||||||
|
SLATE_ARGUMENT(ICutMainWidgetInterface*, MainInterface)
|
||||||
SLATE_END_ARGS()
|
SLATE_END_ARGS()
|
||||||
|
|
||||||
/** Constructs this widget with InArgs */
|
/** Constructs this widget with InArgs */
|
||||||
@ -26,8 +27,10 @@ public:
|
|||||||
|
|
||||||
virtual FReply OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent) override;
|
virtual FReply OnDragOver(const FGeometry& MyGeometry, const FDragDropEvent& DragDropEvent) override;
|
||||||
|
|
||||||
|
ICutMainWidgetInterface* MainInterface;
|
||||||
private:
|
private:
|
||||||
int32 MaxRowIndex = 3;
|
int32 MaxRowIndex = 3;
|
||||||
TSharedPtr<SCutMainWindow> MainWindow;
|
TSharedPtr<SCutMainWindow> MainWindow;
|
||||||
TSharedPtr<SGridPanel> GridPanel;
|
TSharedPtr<SGridPanel> GridPanel;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
@ -162,4 +162,15 @@ void STrackBody::Seek(int32 Frame)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void STrackBody::DeleteUseLessClips()
|
||||||
|
{
|
||||||
|
for (int32 i = 0; i < TrackHead->TrackData.ClipData.Num(); i++)
|
||||||
|
{
|
||||||
|
if (!TrackHead->TrackData.ClipData[i].ResourcePropertyDataPtr->bIsValid)
|
||||||
|
{
|
||||||
|
GEngine->AddOnScreenDebugMessage(-1, 5.0f, FColor::Red, TEXT("DeleteUseLessClips"));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -44,6 +44,6 @@ public:
|
|||||||
TrackBodyBox->SetWidthOverride(FGlobalData::TrackLength * FGlobalData::DefaultTimeTickSpace);
|
TrackBodyBox->SetWidthOverride(FGlobalData::TrackLength * FGlobalData::DefaultTimeTickSpace);
|
||||||
};
|
};
|
||||||
virtual void Seek(int32 Frame) override;
|
virtual void Seek(int32 Frame) override;
|
||||||
|
virtual void DeleteUseLessClips() override;
|
||||||
TSharedPtr<FUICommandList> CommandList;
|
TSharedPtr<FUICommandList> CommandList;
|
||||||
};
|
};
|
||||||
|
@ -12,7 +12,7 @@ void STrackHead::Construct(const FArguments& InArgs)
|
|||||||
TrackData = InArgs._TrackData;
|
TrackData = InArgs._TrackData;
|
||||||
CutTimeline = InArgs._CutTimeline;
|
CutTimeline = InArgs._CutTimeline;
|
||||||
MainWidgetInterface = InArgs._MainWidgetInterface;
|
MainWidgetInterface = InArgs._MainWidgetInterface;
|
||||||
|
GroupName = InArgs._GroupName;
|
||||||
TSharedPtr<SImage> Image = SNew(SImage);
|
TSharedPtr<SImage> Image = SNew(SImage);
|
||||||
ChildSlot
|
ChildSlot
|
||||||
[
|
[
|
||||||
|
@ -17,6 +17,7 @@ public:
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
SLATE_ARGUMENT(FTrackData, TrackData);
|
SLATE_ARGUMENT(FTrackData, TrackData);
|
||||||
|
SLATE_ARGUMENT(FString, GroupName);
|
||||||
SLATE_ARGUMENT(TSharedPtr<SCutTimeline>, CutTimeline);
|
SLATE_ARGUMENT(TSharedPtr<SCutTimeline>, CutTimeline);
|
||||||
SLATE_ARGUMENT(ICutMainWidgetInterface*, MainWidgetInterface);
|
SLATE_ARGUMENT(ICutMainWidgetInterface*, MainWidgetInterface);
|
||||||
SLATE_END_ARGS()
|
SLATE_END_ARGS()
|
||||||
@ -27,6 +28,6 @@ public:
|
|||||||
FTrackData TrackData;
|
FTrackData TrackData;
|
||||||
TSharedPtr<SCutTimeline> CutTimeline;
|
TSharedPtr<SCutTimeline> CutTimeline;
|
||||||
ICutMainWidgetInterface* MainWidgetInterface;
|
ICutMainWidgetInterface* MainWidgetInterface;
|
||||||
|
FString GroupName;
|
||||||
virtual FReply OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
virtual FReply OnMouseButtonDown(const FGeometry& MyGeometry, const FPointerEvent& MouseEvent) override;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user