XML更新
This commit is contained in:
parent
c0a718501a
commit
bb383e8f70
@ -69,18 +69,7 @@ void FSoundThread::Stop()
|
|||||||
int FSoundThread::PaStreamCallback(const void* input, void* output, unsigned long frameCount,
|
int FSoundThread::PaStreamCallback(const void* input, void* output, unsigned long frameCount,
|
||||||
const PaStreamCallbackTimeInfo* timeInfo, PaStreamCallbackFlags statusFlags, void* userData)
|
const PaStreamCallbackTimeInfo* timeInfo, PaStreamCallbackFlags statusFlags, void* userData)
|
||||||
{
|
{
|
||||||
// FSoundThread* This = static_cast<FSoundThread*>(userData);
|
|
||||||
//
|
|
||||||
// TArray<uint8, TInlineAllocator<11760>> ResultData;
|
|
||||||
// const int32 FrameLength = This->Audio.Num();
|
|
||||||
// for (int32 i = This->SeekedFrame * (This->SampleRate / FGlobalData::GlobalFPS) * This->ByteNum * 2; i < This->SeekedFrame * (This->SampleRate / FGlobalData::GlobalFPS) * This->ByteNum * 2 + frameCount && i < FrameLength; ++i)
|
|
||||||
// {
|
|
||||||
// if (ResultData.Num() < i && i > 0)
|
|
||||||
// {
|
|
||||||
// ResultData.Add(This->Audio[i]);
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// output = ResultData.GetData();
|
|
||||||
return paContinue;
|
return paContinue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -265,6 +265,16 @@ bool FUtils::DetectDragTypeCanDrop(const FClipData& DraggingType, const ETrackTy
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (DropTrackType == ETrackType::ProjectorTrack)
|
||||||
|
{
|
||||||
|
if (DraggingType.ClipType == ETrackType::ProjectorTrack)
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
@ -293,13 +303,9 @@ void FUtils::CreateDefaultTimelineSave(const FString& SavedPath, const FTimeline
|
|||||||
|
|
||||||
TArray<FEncodeVideoInfo> FUtils::TrackEncodeVideo(const FTrackData& TrackData, const FString& ExportPath)
|
TArray<FEncodeVideoInfo> FUtils::TrackEncodeVideo(const FTrackData& TrackData, const FString& ExportPath)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
|
||||||
TArray<FClipData> ClipData = TrackData.ClipData;
|
TArray<FClipData> ClipData = TrackData.ClipData;
|
||||||
ClipData.Sort([](const FClipData& A, const FClipData& B) {return A.ClipStartFrame < B.ClipStartFrame; });
|
ClipData.Sort([](const FClipData& A, const FClipData& B) {return A.ClipStartFrame < B.ClipStartFrame; });
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int32 i = 0;
|
int32 i = 0;
|
||||||
TArray<FEncodeVideoInfo> EncodeVideoInfos;
|
TArray<FEncodeVideoInfo> EncodeVideoInfos;
|
||||||
for (FClipData& TempClipData : ClipData)
|
for (FClipData& TempClipData : ClipData)
|
||||||
@ -314,9 +320,10 @@ TArray<FEncodeVideoInfo> FUtils::TrackEncodeVideo(const FTrackData& TrackData, c
|
|||||||
FString StartTime = FString::Printf(TEXT("%02d:%02d:%02d"), StartTimespan.GetHours(), StartTimespan.GetMinutes(), StartTimespan.GetSeconds());
|
FString StartTime = FString::Printf(TEXT("%02d:%02d:%02d"), StartTimespan.GetHours(), StartTimespan.GetMinutes(), StartTimespan.GetSeconds());
|
||||||
FString EndTime = FString::Printf(TEXT("%02d:%02d:%02d"), EndTimespan.GetHours(), EndTimespan.GetMinutes(), EndTimespan.GetSeconds());
|
FString EndTime = FString::Printf(TEXT("%02d:%02d:%02d"), EndTimespan.GetHours(), EndTimespan.GetMinutes(), EndTimespan.GetSeconds());
|
||||||
FString InputFile = "\"" + TempClipData.ResourcePropertyDataPtr->MoviePath + "\"";
|
FString InputFile = "\"" + TempClipData.ResourcePropertyDataPtr->MoviePath + "\"";
|
||||||
|
|
||||||
FString OutputFile = "\"" + FPaths::ConvertRelativePathToFull(ExportPath + FString::FromInt(i) + TEXT(".mp4")) + "\"";
|
|
||||||
|
|
||||||
|
|
||||||
|
FString OutputFile = "\"" + FPaths::ConvertRelativePathToFull(ExportPath / FPaths::GetBaseFilename(TempClipData.MoviePath, true) + FString::FromInt(i) + TEXT(".mp4")) + "\"";
|
||||||
|
GEngine->AddOnScreenDebugMessage(-1, 5.f, FColor::Green, FString::Printf(TEXT("OutputFile %s"), *OutputFile));
|
||||||
int32 StartFrame = (TempClipData.VideoStartFrame) % static_cast<int>(FGlobalData::GlobalFPS);;
|
int32 StartFrame = (TempClipData.VideoStartFrame) % static_cast<int>(FGlobalData::GlobalFPS);;
|
||||||
int32 EndFrame = (TempClipData.VideoEndFrame) % static_cast<int>(FGlobalData::GlobalFPS);
|
int32 EndFrame = (TempClipData.VideoEndFrame) % static_cast<int>(FGlobalData::GlobalFPS);
|
||||||
|
|
||||||
@ -327,7 +334,7 @@ TArray<FEncodeVideoInfo> FUtils::TrackEncodeVideo(const FTrackData& TrackData, c
|
|||||||
FPlatformProcess::CreateProc(*GetFfmepg(), *Command, true, false, false, nullptr, 0, nullptr, nullptr);
|
FPlatformProcess::CreateProc(*GetFfmepg(), *Command, true, false, false, nullptr, 0, nullptr, nullptr);
|
||||||
|
|
||||||
EncodeVideoInfo.EncodedVideoTimeCode = FGlobalData::GetTimeData(TempClipData.ClipStartFrame);
|
EncodeVideoInfo.EncodedVideoTimeCode = FGlobalData::GetTimeData(TempClipData.ClipStartFrame);
|
||||||
EncodeVideoInfo.EncodedVideoName = ExportPath + FString::FromInt(i) + TEXT(".mp4");
|
EncodeVideoInfo.EncodedVideoName = ExportPath / FPaths::GetBaseFilename(TempClipData.MoviePath, true) + FString::FromInt(i) + TEXT(".mp4");
|
||||||
EncodeVideoInfo.ClipStartFrame = TempClipData.ClipStartFrame;
|
EncodeVideoInfo.ClipStartFrame = TempClipData.ClipStartFrame;
|
||||||
EncodeVideoInfo.ClipEndFrame = TempClipData.ClipEndFrame;
|
EncodeVideoInfo.ClipEndFrame = TempClipData.ClipEndFrame;
|
||||||
|
|
||||||
|
@ -7,5 +7,7 @@ void FTimelineClipCommands::RegisterCommands()
|
|||||||
UI_COMMAND(Break, "分割", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
UI_COMMAND(Break, "分割", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
UI_COMMAND(Fill2Start, "填充到开头", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
UI_COMMAND(Fill2Start, "填充到开头", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
UI_COMMAND(Fill2End, "填充到结尾", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
UI_COMMAND(Fill2End, "填充到结尾", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
|
UI_COMMAND(Cycle, "循环", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
|
UI_COMMAND(CancelCycle, "取消循环", "Executes My TimelineClipCommands", EUserInterfaceActionType::Button, FInputChord());
|
||||||
}
|
}
|
||||||
#undef LOCTEXT_NAMESPACE
|
#undef LOCTEXT_NAMESPACE
|
@ -21,4 +21,6 @@ public:
|
|||||||
TSharedPtr<FUICommandInfo> Break;
|
TSharedPtr<FUICommandInfo> Break;
|
||||||
TSharedPtr<FUICommandInfo> Fill2Start;
|
TSharedPtr<FUICommandInfo> Fill2Start;
|
||||||
TSharedPtr<FUICommandInfo> Fill2End;
|
TSharedPtr<FUICommandInfo> Fill2End;
|
||||||
|
TSharedPtr<FUICommandInfo> CancelCycle;
|
||||||
|
TSharedPtr<FUICommandInfo> Cycle;
|
||||||
};
|
};
|
@ -279,6 +279,18 @@ struct CUT5_API FPresetsCustomData
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct CUT5_API FVolumeData
|
||||||
|
{
|
||||||
|
int32 VolumeOffset = 0;
|
||||||
|
int32 Volume = 100;
|
||||||
|
|
||||||
|
friend FArchive& operator<<(FArchive& Ar, FVolumeData& VolumeData)
|
||||||
|
{
|
||||||
|
Ar << VolumeData.VolumeOffset;
|
||||||
|
Ar << VolumeData.Volume;
|
||||||
|
return Ar;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
struct CUT5_API FClipData
|
struct CUT5_API FClipData
|
||||||
{
|
{
|
||||||
@ -308,6 +320,8 @@ struct CUT5_API FClipData
|
|||||||
Ar << ClipData.bCanDrag;
|
Ar << ClipData.bCanDrag;
|
||||||
Ar << ClipData.PresetsCustomData;
|
Ar << ClipData.PresetsCustomData;
|
||||||
Ar << ClipData.MovieBrushesPath;
|
Ar << ClipData.MovieBrushesPath;
|
||||||
|
Ar << ClipData.VolumeData;
|
||||||
|
Ar << ClipData.bIsCycle;
|
||||||
return Ar;
|
return Ar;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -323,6 +337,8 @@ struct CUT5_API FClipData
|
|||||||
|
|
||||||
int32 ClipStartFrame = 0;
|
int32 ClipStartFrame = 0;
|
||||||
int32 ClipEndFrame = 10;
|
int32 ClipEndFrame = 10;
|
||||||
|
TArray<FVolumeData> VolumeData;
|
||||||
|
bool bIsCycle = false;
|
||||||
|
|
||||||
TArray<FLinearColor> ClipColors;
|
TArray<FLinearColor> ClipColors;
|
||||||
|
|
||||||
@ -338,9 +354,6 @@ struct CUT5_API FClipData
|
|||||||
TArray<FSlateBrush> MovieBrushes;
|
TArray<FSlateBrush> MovieBrushes;
|
||||||
TArray<FString> MovieBrushesPath;
|
TArray<FString> MovieBrushesPath;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
TArray<FSlateBrush> AudioBrushes;
|
TArray<FSlateBrush> AudioBrushes;
|
||||||
TArray<float> AudioBrushLength;
|
TArray<float> AudioBrushLength;
|
||||||
int32 AudioBrushNum = 0;
|
int32 AudioBrushNum = 0;
|
||||||
|
@ -637,7 +637,7 @@ int32 SCutMainWindow::OnPaint(const FPaintArgs& Args, const FGeometry& AllottedG
|
|||||||
|
|
||||||
FSlateDrawElement::MakeBox(
|
FSlateDrawElement::MakeBox(
|
||||||
OutDrawElements,
|
OutDrawElements,
|
||||||
LayerId + 4,
|
LayerId + 9,
|
||||||
AllottedGeometry.ToPaintGeometry(FVector2f(2, CutTimeline->GetCachedGeometry().Size.Y), FSlateLayoutTransform(FVector2f(RenderLineTime, AllottedGeometry.GetLocalSize().Y - CutTimeline->GetCachedGeometry().GetLocalSize().Y))),
|
AllottedGeometry.ToPaintGeometry(FVector2f(2, CutTimeline->GetCachedGeometry().Size.Y), FSlateLayoutTransform(FVector2f(RenderLineTime, AllottedGeometry.GetLocalSize().Y - CutTimeline->GetCachedGeometry().GetLocalSize().Y))),
|
||||||
&Brush,
|
&Brush,
|
||||||
ESlateDrawEffect::None,
|
ESlateDrawEffect::None,
|
||||||
@ -1490,11 +1490,11 @@ tinyxml2::XMLElement* SCutMainWindow::GetDeviceElement(tinyxml2::XMLElement* Par
|
|||||||
const FClipData& TempClipData = TrackData.ClipData[k];
|
const FClipData& TempClipData = TrackData.ClipData[k];
|
||||||
tinyxml2::XMLElement* Event1 = Event_List->InsertNewChildElement("Event");
|
tinyxml2::XMLElement* Event1 = Event_List->InsertNewChildElement("Event");
|
||||||
Event1->InsertNewChildElement("Value")->InsertNewText("1");
|
Event1->InsertNewChildElement("Value")->InsertNewText("1");
|
||||||
Event1->InsertNewChildElement("Timecode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipStartFrame)))));
|
Event1->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipStartFrame)))));
|
||||||
|
|
||||||
tinyxml2::XMLElement* Event2 = Event_List->InsertNewChildElement("Event");
|
tinyxml2::XMLElement* Event2 = Event_List->InsertNewChildElement("Event");
|
||||||
Event2->InsertNewChildElement("Value")->InsertNewText("0");
|
Event2->InsertNewChildElement("Value")->InsertNewText("0");
|
||||||
Event2->InsertNewChildElement("Timecode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipEndFrame)))));
|
Event2->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipEndFrame)))));
|
||||||
Count++;
|
Count++;
|
||||||
}
|
}
|
||||||
if (Count == 0)
|
if (Count == 0)
|
||||||
@ -1536,13 +1536,7 @@ tinyxml2::XMLElement* SCutMainWindow::GetDeviceElement(tinyxml2::XMLElement* Par
|
|||||||
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::Breathe)
|
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::Breathe)
|
||||||
{
|
{
|
||||||
tinyxml2::XMLElement* NewSpeicalEffect = SpeicalEffect->InsertNewChildElement("Special_Effect");
|
tinyxml2::XMLElement* NewSpeicalEffect = SpeicalEffect->InsertNewChildElement("Special_Effect");
|
||||||
NewSpeicalEffect->InsertNewChildElement("Mode")->InsertNewText("0");
|
GetBreatheLight(NewSpeicalEffect, TempClipData);
|
||||||
NewSpeicalEffect->InsertNewChildElement("InitialColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("EndColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(FLinearColor::Black.ToFColor(false)))));
|
|
||||||
float PerLength = (TempClipData.PresetsCustomData.Time / TempClipData.PresetsCustomData.Times);
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("TimeLength")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), int32(PerLength * 1000))));
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipStartFrame)))));
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("Cycle")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), TempClipData.PresetsCustomData.Times)));
|
|
||||||
}
|
}
|
||||||
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::Flash)
|
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::Flash)
|
||||||
{
|
{
|
||||||
@ -1558,13 +1552,7 @@ tinyxml2::XMLElement* SCutMainWindow::GetDeviceElement(tinyxml2::XMLElement* Par
|
|||||||
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::Gradient)
|
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::Gradient)
|
||||||
{
|
{
|
||||||
tinyxml2::XMLElement* NewSpeicalEffect = SpeicalEffect->InsertNewChildElement("Special_Effect");
|
tinyxml2::XMLElement* NewSpeicalEffect = SpeicalEffect->InsertNewChildElement("Special_Effect");
|
||||||
NewSpeicalEffect->InsertNewChildElement("Mode")->InsertNewText("0");
|
GetGradientLight(NewSpeicalEffect, TempClipData);
|
||||||
NewSpeicalEffect->InsertNewChildElement("InitialColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Cursors[0].Color.ToFColor(false)))));
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("EndColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Cursors[1].Color.ToFColor(false)))));
|
|
||||||
float PerLength = (TempClipData.PresetsCustomData.Time / TempClipData.PresetsCustomData.Times) / 2;
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("TimeLength")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), int32(PerLength * 1000))));
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipStartFrame)))));
|
|
||||||
NewSpeicalEffect->InsertNewChildElement("Cycle")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), TempClipData.PresetsCustomData.Times)));
|
|
||||||
}
|
}
|
||||||
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::None)
|
if (TempClipData.PresetsCustomData.PresetCustomType == FPresetsCustomData::EPresetCustomType::None)
|
||||||
{
|
{
|
||||||
@ -1572,7 +1560,9 @@ tinyxml2::XMLElement* SCutMainWindow::GetDeviceElement(tinyxml2::XMLElement* Par
|
|||||||
NewSpeicalEffect->InsertNewChildElement("Mode")->InsertNewText("0");
|
NewSpeicalEffect->InsertNewChildElement("Mode")->InsertNewText("0");
|
||||||
NewSpeicalEffect->InsertNewChildElement("InitialColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
NewSpeicalEffect->InsertNewChildElement("InitialColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
||||||
NewSpeicalEffect->InsertNewChildElement("EndColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
NewSpeicalEffect->InsertNewChildElement("EndColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(TempClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
||||||
NewSpeicalEffect->InsertNewChildElement("TimeLength")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), -1)));
|
|
||||||
|
const int32 Frame = TempClipData.ClipEndFrame - TempClipData.ClipStartFrame;
|
||||||
|
NewSpeicalEffect->InsertNewChildElement("TimeLength")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(Frame)))));
|
||||||
NewSpeicalEffect->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipStartFrame)))));
|
NewSpeicalEffect->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(TempClipData.ClipStartFrame)))));
|
||||||
NewSpeicalEffect->InsertNewChildElement("Cycle")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), 1)));
|
NewSpeicalEffect->InsertNewChildElement("Cycle")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), 1)));
|
||||||
}
|
}
|
||||||
@ -1604,7 +1594,7 @@ tinyxml2::XMLElement* SCutMainWindow::GetDeviceElement(tinyxml2::XMLElement* Par
|
|||||||
TArray<FEncodeVideoInfo> EncodeVideoInfos = FUtils::ExportPsaf(StaticCastSharedPtr<STrackHead>(CutTimeline->TrackGroupInstances[i].Head)->TrackData, *(FGlobalData::ExportPath / "PSAF"));
|
TArray<FEncodeVideoInfo> EncodeVideoInfos = FUtils::ExportPsaf(StaticCastSharedPtr<STrackHead>(CutTimeline->TrackGroupInstances[i].Head)->TrackData, *(FGlobalData::ExportPath / "PSAF"));
|
||||||
for (int32 j = 0; j < EncodeVideoInfos.Num(); j++)
|
for (int32 j = 0; j < EncodeVideoInfos.Num(); j++)
|
||||||
{
|
{
|
||||||
auto SpeicalEffect = GuangZhenSpecialEffectList->InsertNewChildElement("SpeicalEffect");
|
auto SpeicalEffect = GuangZhenSpecialEffectList->InsertNewChildElement("SpecialEffect");
|
||||||
{
|
{
|
||||||
auto SpeicalEffectTimeCode = SpeicalEffect->InsertNewChildElement("TimeCode");
|
auto SpeicalEffectTimeCode = SpeicalEffect->InsertNewChildElement("TimeCode");
|
||||||
{
|
{
|
||||||
@ -1616,7 +1606,7 @@ tinyxml2::XMLElement* SCutMainWindow::GetDeviceElement(tinyxml2::XMLElement* Par
|
|||||||
}
|
}
|
||||||
auto SpeicalEffectLoop = SpeicalEffect->InsertNewChildElement("Loop");
|
auto SpeicalEffectLoop = SpeicalEffect->InsertNewChildElement("Loop");
|
||||||
{
|
{
|
||||||
SpeicalEffectLoop->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(0)));
|
SpeicalEffectLoop->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(1)));
|
||||||
}
|
}
|
||||||
auto SpeicalEffectMode = SpeicalEffect->InsertNewChildElement("Mode");
|
auto SpeicalEffectMode = SpeicalEffect->InsertNewChildElement("Mode");
|
||||||
{
|
{
|
||||||
@ -1669,13 +1659,13 @@ tinyxml2::XMLElement* SCutMainWindow::GetVideoElement(tinyxml2::XMLElement* Pare
|
|||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
tinyxml2::XMLElement* Timecode = Video->InsertNewChildElement("Timecode");
|
tinyxml2::XMLElement* Timecode = Video->InsertNewChildElement("TimeCode");
|
||||||
{
|
{
|
||||||
Timecode->InsertNewText(TCHAR_TO_UTF8(*FUtils::GetMsFromString(EncodeVideoInfo.EncodedVideoTimeCode)));
|
Timecode->InsertNewText(TCHAR_TO_UTF8(*FUtils::GetMsFromString(EncodeVideoInfo.EncodedVideoTimeCode)));
|
||||||
}
|
}
|
||||||
tinyxml2::XMLElement* Loop = Video->InsertNewChildElement("Loop");
|
tinyxml2::XMLElement* Loop = Video->InsertNewChildElement("Loop");
|
||||||
{
|
{
|
||||||
Loop->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(0)));
|
Loop->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(1)));
|
||||||
}
|
}
|
||||||
tinyxml2::XMLElement* Mode = Video->InsertNewChildElement("Mode");
|
tinyxml2::XMLElement* Mode = Video->InsertNewChildElement("Mode");
|
||||||
{
|
{
|
||||||
@ -1799,10 +1789,10 @@ tinyxml2::XMLElement* SCutMainWindow::GetSoundElement(tinyxml2::XMLElement* Pare
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Sound->InsertNewChildElement("Loop")->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(0)));
|
Sound->InsertNewChildElement("Loop")->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(1)));
|
||||||
Sound->InsertNewChildElement("Mode")->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(0)));
|
Sound->InsertNewChildElement("Mode")->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(0)));
|
||||||
Sound->InsertNewChildElement("Round")->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(1)));
|
Sound->InsertNewChildElement("Round")->InsertNewText(TCHAR_TO_UTF8(*FString::FromInt(1)));
|
||||||
Sound->InsertNewChildElement("Timecode")->InsertNewText(TCHAR_TO_UTF8(*FUtils::GetMsFromString(EncodeVideoInfo.EncodedVideoTimeCode)));
|
Sound->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FUtils::GetMsFromString(EncodeVideoInfo.EncodedVideoTimeCode)));
|
||||||
|
|
||||||
tinyxml2::XMLElement* RotationSpeakerEventList = Sound->InsertNewChildElement("RotationSpeakerEventList");
|
tinyxml2::XMLElement* RotationSpeakerEventList = Sound->InsertNewChildElement("RotationSpeakerEventList");
|
||||||
{
|
{
|
||||||
@ -1828,8 +1818,8 @@ tinyxml2::XMLElement* SCutMainWindow::GetVideoListElement(tinyxml2::XMLElement*
|
|||||||
{
|
{
|
||||||
if (StaticCastSharedPtr<STrackHead>(CutTimeline->TrackGroupInstances[i].Head)->TrackData.TrackType == ETrackType::VideoTrack)
|
if (StaticCastSharedPtr<STrackHead>(CutTimeline->TrackGroupInstances[i].Head)->TrackData.TrackType == ETrackType::VideoTrack)
|
||||||
{
|
{
|
||||||
FString Filename = FGuid::NewGuid().ToString();
|
FString NewExportFilePath = FGlobalData::ExportPath / "Video/";
|
||||||
FString NewExportFilePath = FGlobalData::ExportPath / "Video" / Filename;
|
GEngine->AddOnScreenDebugMessage(-1, 10.0F, FColor::White, NewExportFilePath);
|
||||||
TArray<FEncodeVideoInfo> EncodeVideoInfos = FUtils::TrackEncodeVideo(StaticCastSharedPtr<STrackHead>(CutTimeline->TrackGroupInstances[i].Head)->TrackData, NewExportFilePath);
|
TArray<FEncodeVideoInfo> EncodeVideoInfos = FUtils::TrackEncodeVideo(StaticCastSharedPtr<STrackHead>(CutTimeline->TrackGroupInstances[i].Head)->TrackData, NewExportFilePath);
|
||||||
for (FEncodeVideoInfo EncodeVideoInfo : EncodeVideoInfos)
|
for (FEncodeVideoInfo EncodeVideoInfo : EncodeVideoInfos)
|
||||||
{
|
{
|
||||||
@ -2033,7 +2023,8 @@ tinyxml2::XMLElement* SCutMainWindow::GetSpecialEffect(tinyxml2::XMLElement* Par
|
|||||||
}
|
}
|
||||||
|
|
||||||
tinyxml2::XMLElement* AutoNext = Effectxml->InsertNewChildElement("AutoNext");
|
tinyxml2::XMLElement* AutoNext = Effectxml->InsertNewChildElement("AutoNext");
|
||||||
Effectxml->InsertNewChildElement("TimeLength")->InsertNewText("-1");
|
tinyxml2::XMLElement* TimeLength = Effectxml->InsertNewChildElement("TimeLength");
|
||||||
|
TimeLength->InsertNewText("-1");
|
||||||
AutoNext->InsertNewText("0");
|
AutoNext->InsertNewText("0");
|
||||||
GetSoundListElement(Effectxml);
|
GetSoundListElement(Effectxml);
|
||||||
GetDeviceElement(Effectxml);
|
GetDeviceElement(Effectxml);
|
||||||
@ -2068,6 +2059,113 @@ tinyxml2::XMLElement* SCutMainWindow::GetTrigger(tinyxml2::XMLElement* Parent)
|
|||||||
return Trigger;
|
return Trigger;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tinyxml2::XMLElement* SCutMainWindow::GetBreatheLight(tinyxml2::XMLElement* Parent, const FClipData& ClipData)
|
||||||
|
{
|
||||||
|
Parent->InsertNewChildElement("Mode")->InsertNewText("3");
|
||||||
|
Parent->InsertNewChildElement("InitialColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
||||||
|
Parent->InsertNewChildElement("EndColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(FLinearColor::Black.ToFColor(false)))));
|
||||||
|
float PerLength = (ClipData.PresetsCustomData.Time / ClipData.PresetsCustomData.Times);
|
||||||
|
Parent->InsertNewChildElement("TimeLength")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), int32(PerLength * 1000))));
|
||||||
|
Parent->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.ClipStartFrame)))));
|
||||||
|
Parent->InsertNewChildElement("Cycle")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), static_cast<int32>(PerLength * 1000))));
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
tinyxml2::XMLElement* SCutMainWindow::GetFlashLight(tinyxml2::XMLElement* Parent, const FClipData& ClipData)
|
||||||
|
{
|
||||||
|
Parent->InsertNewChildElement("Mode")->InsertNewText("2");
|
||||||
|
Parent->InsertNewChildElement("InitialColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
||||||
|
Parent->InsertNewChildElement("EndColor")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(FLinearColor::Black.ToFColor(false)))));
|
||||||
|
float PerLength = (ClipData.PresetsCustomData.Time / ClipData.PresetsCustomData.Times);
|
||||||
|
Parent->InsertNewChildElement("TimeLength")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), int32(PerLength * 1000))));
|
||||||
|
Parent->InsertNewChildElement("TimeCode")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.ClipStartFrame)))));
|
||||||
|
Parent->InsertNewChildElement("Cycle")->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%d"), static_cast<int32>(PerLength * 1000))));
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
tinyxml2::XMLElement* SCutMainWindow::GetGradientLight(tinyxml2::XMLElement* Parent, const FClipData& ClipData)
|
||||||
|
{
|
||||||
|
if (ClipData.PresetsCustomData.Cursors.Num() == 0)
|
||||||
|
return nullptr;
|
||||||
|
|
||||||
|
if (ClipData.PresetsCustomData.Cursors[0].CursorFrameOffset > 0)
|
||||||
|
{
|
||||||
|
Parent->InsertNewChildElement("Mode")->InsertNewText("0");
|
||||||
|
Parent->InsertNewChildElement("InitialColor")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("EndColor")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),*FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[0].ToFColor(false)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("TimeLength")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.PresetsCustomData.Cursors[0].CursorFrameOffset)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("TimeCode")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.ClipStartFrame + ClipData.PresetsCustomData.Cursors[0].CursorFrameOffset)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("Cycle")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.PresetsCustomData.Cursors[0].CursorFrameOffset)))));
|
||||||
|
}
|
||||||
|
|
||||||
|
int32 Index = 0;
|
||||||
|
const int32 CursorNum = ClipData.PresetsCustomData.Cursors.Num();
|
||||||
|
for (const FCursorData& CursorData : ClipData.PresetsCustomData.Cursors)
|
||||||
|
{
|
||||||
|
if (Index == CursorNum - 1 && CursorData.CursorFrameOffset < (ClipData.ClipEndFrame - ClipData.ClipStartFrame))
|
||||||
|
{
|
||||||
|
Parent->InsertNewChildElement("Mode")->InsertNewText("0");
|
||||||
|
Parent->InsertNewChildElement("InitialColor")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[Index].ToFColor(false)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("EndColor")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),*FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[Index].ToFColor(false)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("TimeLength")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(
|
||||||
|
(ClipData.ClipEndFrame - ClipData.ClipStartFrame) -
|
||||||
|
ClipData.PresetsCustomData.Cursors[Index].CursorFrameOffset)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("TimeCode")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.ClipStartFrame + ClipData.PresetsCustomData.Cursors[Index].CursorFrameOffset)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("Cycle")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(
|
||||||
|
(ClipData.ClipEndFrame - ClipData.ClipStartFrame) -
|
||||||
|
ClipData.PresetsCustomData.Cursors[Index].CursorFrameOffset)))));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
Parent->InsertNewChildElement("Mode")->InsertNewText("1");
|
||||||
|
Parent->InsertNewChildElement("InitialColor")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"), *FUtils::Color2Hex3(CursorData.Color.ToFColor(false)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("EndColor")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),*FUtils::Color2Hex3(ClipData.PresetsCustomData.Colors[Index + 1].ToFColor(false)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("TimeLength")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(
|
||||||
|
ClipData.PresetsCustomData.Cursors[Index + 1].CursorFrameOffset - CursorData.CursorFrameOffset)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("TimeCode")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(FGlobalData::GetTimeData(ClipData.ClipStartFrame + CursorData.CursorFrameOffset)))));
|
||||||
|
|
||||||
|
Parent->InsertNewChildElement("Cycle")
|
||||||
|
->InsertNewText(TCHAR_TO_UTF8(*FString::Printf(TEXT("%ls"),
|
||||||
|
*FUtils::GetMsFromString(
|
||||||
|
FGlobalData::GetTimeData(ClipData.PresetsCustomData.Cursors[Index + 1].CursorFrameOffset - CursorData.CursorFrameOffset)))));
|
||||||
|
Index++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
int32 SCutMainWindow::GetTrackID(FGuid Guid) const
|
int32 SCutMainWindow::GetTrackID(FGuid Guid) const
|
||||||
{
|
{
|
||||||
const int32* Index = IDList.Find(Guid);
|
const int32* Index = IDList.Find(Guid);
|
||||||
@ -2099,5 +2197,13 @@ void SCutMainWindow::AddThread(const FGuid& Guid, FRunnable* InSoundThread)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SCutMainWindow::RemoveThread(const FGuid& Guid)
|
||||||
|
{
|
||||||
|
FRunnable* Thread = *Threads.Find(Guid);
|
||||||
|
Thread->Stop();
|
||||||
|
delete Thread;
|
||||||
|
Threads.Remove(Guid);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
END_SLATE_FUNCTION_BUILD_OPTIMIZATION
|
||||||
|
@ -116,6 +116,10 @@ public:
|
|||||||
tinyxml2::XMLElement* GetSpecialEffectGroup(tinyxml2::XMLElement* Parent, FEffectCardGroup* Group);
|
tinyxml2::XMLElement* GetSpecialEffectGroup(tinyxml2::XMLElement* Parent, FEffectCardGroup* Group);
|
||||||
tinyxml2::XMLElement* GetSpecialEffect(tinyxml2::XMLElement* Parent, FEffectCardProperty* Effect);
|
tinyxml2::XMLElement* GetSpecialEffect(tinyxml2::XMLElement* Parent, FEffectCardProperty* Effect);
|
||||||
tinyxml2::XMLElement* GetTrigger(tinyxml2::XMLElement* Parent);
|
tinyxml2::XMLElement* GetTrigger(tinyxml2::XMLElement* Parent);
|
||||||
|
|
||||||
|
tinyxml2::XMLElement* GetBreatheLight(tinyxml2::XMLElement* Parent, const FClipData& ClipData);
|
||||||
|
tinyxml2::XMLElement* GetFlashLight(tinyxml2::XMLElement* Parent, const FClipData& ClipData);
|
||||||
|
tinyxml2::XMLElement* GetGradientLight(tinyxml2::XMLElement* Parent, const FClipData& ClipData);
|
||||||
|
|
||||||
int32 RotatorSpeakerIndex = 0;
|
int32 RotatorSpeakerIndex = 0;
|
||||||
int32 LightArrayIndex = 0;
|
int32 LightArrayIndex = 0;
|
||||||
@ -126,6 +130,7 @@ public:
|
|||||||
TMap<FGuid, FRunnable*> Threads;
|
TMap<FGuid, FRunnable*> Threads;
|
||||||
FRunnable* GetThread(const FGuid& Guid);
|
FRunnable* GetThread(const FGuid& Guid);
|
||||||
void AddThread(const FGuid& Guid, FRunnable* InSoundThread);
|
void AddThread(const FGuid& Guid, FRunnable* InSoundThread);
|
||||||
|
void RemoveThread(const FGuid& Guid);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -51,8 +51,24 @@ FReply STimelineClip::OnBorderMouseButtonDown(const FGeometry& Geometry, const F
|
|||||||
FMenuBuilder MenuBuilder(true, CommandList);
|
FMenuBuilder MenuBuilder(true, CommandList);
|
||||||
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Remove);
|
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Remove);
|
||||||
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Break);
|
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Break);
|
||||||
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Fill2Start);
|
if (ClipData->ClipType != ETrackType::VideoTrack && ClipData->ClipType != ETrackType::AudioTrack && ClipData->ClipType != ETrackType::AudioTrackR)
|
||||||
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Fill2End);
|
{
|
||||||
|
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Fill2Start);
|
||||||
|
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Fill2End);
|
||||||
|
}
|
||||||
|
if (ClipData->ClipType != ETrackType::ProjectorTrack)
|
||||||
|
{
|
||||||
|
if (ClipData->bIsCycle)
|
||||||
|
{
|
||||||
|
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().CancelCycle);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
MenuBuilder.AddMenuEntry(FTimelineClipCommands::Get().Cycle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
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);
|
||||||
return FReply::Handled();
|
return FReply::Handled();
|
||||||
@ -136,7 +152,7 @@ FReply STimelineClip::OnBorderMouseButtonDown(const FGeometry& Geometry, const F
|
|||||||
const TSharedPtr<FClipsMoveDragDropOperation> Clip2ClipDragDropOperation = MakeShared<FClipsMoveDragDropOperation>();
|
const TSharedPtr<FClipsMoveDragDropOperation> Clip2ClipDragDropOperation = MakeShared<FClipsMoveDragDropOperation>();
|
||||||
Clip2ClipDragDropOperation->MainInterface = MainWidgetInterface;
|
Clip2ClipDragDropOperation->MainInterface = MainWidgetInterface;
|
||||||
Clip2ClipDragDropOperation->DragOffset = MainWidgetInterface->GetCutTimeline()->GetCachedGeometry().AbsoluteToLocal(PointerEvent.GetScreenSpacePosition()).X;
|
Clip2ClipDragDropOperation->DragOffset = MainWidgetInterface->GetCutTimeline()->GetCachedGeometry().AbsoluteToLocal(PointerEvent.GetScreenSpacePosition()).X;
|
||||||
float X = StaticCastSharedPtr<STrackBody>(Body)->GetCachedGeometry().AbsoluteToLocal(PointerEvent.GetScreenSpacePosition()).X / FGlobalData::DefaultTimeTickSpace;
|
const float X = StaticCastSharedPtr<STrackBody>(Body)->GetCachedGeometry().AbsoluteToLocal(PointerEvent.GetScreenSpacePosition()).X / FGlobalData::DefaultTimeTickSpace;
|
||||||
Clip2ClipDragDropOperation->OriginOffset = ClipData->ClipStartFrame - X / FGlobalData::DefaultTimeTickSpace;
|
Clip2ClipDragDropOperation->OriginOffset = ClipData->ClipStartFrame - X / FGlobalData::DefaultTimeTickSpace;
|
||||||
|
|
||||||
for (FSingleTrackGroupInstance& TrackGroupInstance : MainWidgetInterface->GetCutTimeline()->TrackGroupInstances)
|
for (FSingleTrackGroupInstance& TrackGroupInstance : MainWidgetInterface->GetCutTimeline()->TrackGroupInstances)
|
||||||
@ -229,6 +245,8 @@ void STimelineClip::Construct(const FArguments& InArgs)
|
|||||||
FRunnableThread::Create(Thread, TEXT("VideoThread"));
|
FRunnableThread::Create(Thread, TEXT("VideoThread"));
|
||||||
MainWidgetInterface->GetSelf()->AddThread(FUtils::GetVideoThreadGuid(ClipData->ClipGuid), Thread);
|
MainWidgetInterface->GetSelf()->AddThread(FUtils::GetVideoThreadGuid(ClipData->ClipGuid), Thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
if (MainWidgetInterface->GetCutTimeline()->SelectedClipGUID == ClipData->ClipGuid)
|
if (MainWidgetInterface->GetCutTimeline()->SelectedClipGUID == ClipData->ClipGuid)
|
||||||
{
|
{
|
||||||
@ -410,7 +428,7 @@ void STimelineClip::UpdatePosition(int32 StartFrame)
|
|||||||
}
|
}
|
||||||
const int32 NewPosX = StartFrame * FGlobalData::DefaultTimeTickSpace;
|
const int32 NewPosX = StartFrame * FGlobalData::DefaultTimeTickSpace;
|
||||||
|
|
||||||
if (StartFrame > 0)
|
if (ClipData->ClipType == ETrackType::VideoTrack || ClipData->ClipType == ETrackType::AudioTrack || ClipData->ClipType == ETrackType::AudioTrackR)
|
||||||
{
|
{
|
||||||
if (ClipData->VideoStartFrame + StartFrame - ClipData->ClipStartFrame < 0)
|
if (ClipData->VideoStartFrame + StartFrame - ClipData->ClipStartFrame < 0)
|
||||||
{
|
{
|
||||||
@ -418,6 +436,8 @@ void STimelineClip::UpdatePosition(int32 StartFrame)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SetRenderTransform(FSlateRenderTransform(FVector2D(NewPosX, 0)));
|
SetRenderTransform(FSlateRenderTransform(FVector2D(NewPosX, 0)));
|
||||||
@ -576,11 +596,15 @@ int32 STimelineClip::OnPaint(const FPaintArgs& Args, const FGeometry& AllottedGe
|
|||||||
|
|
||||||
if (ClipData->PresetType == EPresetType::EnableProjector)
|
if (ClipData->PresetType == EPresetType::EnableProjector)
|
||||||
{
|
{
|
||||||
FSlateDrawElement::MakeText(OutDrawElements, LayerId + 3, AllottedGeometry.ToPaintGeometry(), FText::FromString(TEXT("开启投影仪")), FAppStyle::Get().GetWidgetStyle<FTextBlockStyle>("NormalText").Font, ESlateDrawEffect::None, FLinearColor::White);
|
FSlateDrawElement::MakeText(OutDrawElements, LayerId + 9, AllottedGeometry.ToPaintGeometry(), FText::FromString(TEXT("开启投影仪")), FAppStyle::Get().GetWidgetStyle<FTextBlockStyle>("NormalText").Font, ESlateDrawEffect::None, FLinearColor::White);
|
||||||
}
|
}
|
||||||
if (ClipData->PresetType == EPresetType::DisableProjector)
|
if (ClipData->PresetType == EPresetType::DisableProjector)
|
||||||
{
|
{
|
||||||
FSlateDrawElement::MakeText(OutDrawElements, LayerId + 3, AllottedGeometry.ToPaintGeometry(), FText::FromString(TEXT("关闭投影仪")), FAppStyle::Get().GetWidgetStyle<FTextBlockStyle>("NormalText").Font, ESlateDrawEffect::None, FLinearColor::White);
|
FSlateDrawElement::MakeText(OutDrawElements, LayerId + 9, AllottedGeometry.ToPaintGeometry(), FText::FromString(TEXT("关闭投影仪")), FAppStyle::Get().GetWidgetStyle<FTextBlockStyle>("NormalText").Font, ESlateDrawEffect::None, FLinearColor::White);
|
||||||
|
}
|
||||||
|
if (ClipData->bIsCycle == true)
|
||||||
|
{
|
||||||
|
FSlateDrawElement::MakeText(OutDrawElements, LayerId + 9, AllottedGeometry.ToPaintGeometry(), FText::FromString(TEXT("循环播放")), FAppStyle::Get().GetWidgetStyle<FTextBlockStyle>("NormalText").Font, ESlateDrawEffect::None, FLinearColor::White);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -649,19 +673,19 @@ int32 STimelineClip::OnPaint(const FPaintArgs& Args, const FGeometry& AllottedGe
|
|||||||
if (PaintDragType == 0)
|
if (PaintDragType == 0)
|
||||||
{
|
{
|
||||||
const FSlateBrush Brush;
|
const FSlateBrush Brush;
|
||||||
FSlateDrawElement::MakeBox(OutDrawElements, LayerId + 3, AllottedGeometry.ToPaintGeometry(FVector2f(10, AllottedGeometry.Size.Y), FSlateLayoutTransform(FVector2f(0, 0))),
|
FSlateDrawElement::MakeBox(OutDrawElements, LayerId + 5, AllottedGeometry.ToPaintGeometry(FVector2f(10, AllottedGeometry.Size.Y), FSlateLayoutTransform(FVector2f(0, 0))),
|
||||||
&Brush, ESlateDrawEffect::None, FLinearColor(1.0, 0.0, 1.0, 1.0));
|
&Brush, ESlateDrawEffect::None, FLinearColor(1.0, 0.0, 1.0, 1.0));
|
||||||
}
|
}
|
||||||
else if (PaintDragType == 1)
|
else if (PaintDragType == 1)
|
||||||
{
|
{
|
||||||
const FSlateBrush Brush;
|
const FSlateBrush Brush;
|
||||||
FSlateDrawElement::MakeBox(OutDrawElements, LayerId + 3, AllottedGeometry.ToPaintGeometry(FVector2f(10, AllottedGeometry.Size.Y), FSlateLayoutTransform(FVector2f(AllottedGeometry.Size.X - 10, 0))),
|
FSlateDrawElement::MakeBox(OutDrawElements, LayerId + 5, AllottedGeometry.ToPaintGeometry(FVector2f(10, AllottedGeometry.Size.Y), FSlateLayoutTransform(FVector2f(AllottedGeometry.Size.X - 10, 0))),
|
||||||
&Brush, ESlateDrawEffect::None, FLinearColor(1.0, 0.0, 1.0, 1.0));
|
&Brush, ESlateDrawEffect::None, FLinearColor(1.0, 0.0, 1.0, 1.0));
|
||||||
}
|
}
|
||||||
else if (PaintDragType == 2)
|
else if (PaintDragType == 2)
|
||||||
{
|
{
|
||||||
const FSlateBrush Brush;
|
const FSlateBrush Brush;
|
||||||
FSlateDrawElement::MakeBox(OutDrawElements, LayerId + 3, AllottedGeometry.ToPaintGeometry(FVector2f(FGlobalData::DefaultTimeTickSpace, FGlobalData::DefaultTrackHeight), FSlateLayoutTransform(FVector2f(LocalPos.X, 0))),
|
FSlateDrawElement::MakeBox(OutDrawElements, LayerId + 5, AllottedGeometry.ToPaintGeometry(FVector2f(FGlobalData::DefaultTimeTickSpace, FGlobalData::DefaultTrackHeight), FSlateLayoutTransform(FVector2f(LocalPos.X, 0))),
|
||||||
&Brush, ESlateDrawEffect::None, FLinearColor(1.0, 0.0, 1.0, 1.0));
|
&Brush, ESlateDrawEffect::None, FLinearColor(1.0, 0.0, 1.0, 1.0));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -37,6 +37,8 @@ void STimelinePropertyPanel::Construct(const FArguments& InArgs)
|
|||||||
[
|
[
|
||||||
SNew(SBox)
|
SNew(SBox)
|
||||||
.Padding(0, 0 , 0, 14)
|
.Padding(0, 0 , 0, 14)
|
||||||
|
.HeightOverride(76)
|
||||||
|
.WidthOverride(236)
|
||||||
[
|
[
|
||||||
SNew(SOverlay)
|
SNew(SOverlay)
|
||||||
+ SOverlay::Slot()
|
+ SOverlay::Slot()
|
||||||
|
@ -35,6 +35,14 @@ void STrackBody::Construct(const FArguments& InArgs)
|
|||||||
{
|
{
|
||||||
Fill2End(SelectedClipGUID);
|
Fill2End(SelectedClipGUID);
|
||||||
}), FCanExecuteAction());
|
}), FCanExecuteAction());
|
||||||
|
CommandList->MapAction(FTimelineClipCommands::Get().Cycle, FExecuteAction::CreateLambda([this]()
|
||||||
|
{
|
||||||
|
SetCycle(SelectedClipGUID, true);
|
||||||
|
}), FCanExecuteAction());
|
||||||
|
CommandList->MapAction(FTimelineClipCommands::Get().CancelCycle, FExecuteAction::CreateLambda([this]()
|
||||||
|
{
|
||||||
|
SetCycle(SelectedClipGUID, false);
|
||||||
|
}), FCanExecuteAction());
|
||||||
|
|
||||||
MainWidgetInterface = InArgs._MainWidgetInterface;
|
MainWidgetInterface = InArgs._MainWidgetInterface;
|
||||||
TrackHead = InArgs._TrackHead;
|
TrackHead = InArgs._TrackHead;
|
||||||
@ -200,6 +208,18 @@ void STrackBody::Fill2End(const FGuid& Guid)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void STrackBody::SetCycle(const FGuid& Guid, bool Cycle)
|
||||||
|
{
|
||||||
|
for (int32 i = 0; i < SlateClips.Num(); i++)
|
||||||
|
{
|
||||||
|
if (TrackHead->TrackData.ClipData[i].ClipGuid == Guid)
|
||||||
|
{
|
||||||
|
TrackHead->TrackData.ClipData[i].bIsCycle = Cycle;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void STrackBody::BreakClip(const FGuid& Guid)
|
void STrackBody::BreakClip(const FGuid& Guid)
|
||||||
{
|
{
|
||||||
for (int32 i = 0; i < SlateClips.Num(); i++)
|
for (int32 i = 0; i < SlateClips.Num(); i++)
|
||||||
|
@ -36,6 +36,7 @@ public:
|
|||||||
virtual void BreakClip(const FGuid& Guid) override;
|
virtual void BreakClip(const FGuid& Guid) override;
|
||||||
void Fill2Start(const FGuid& Guid);
|
void Fill2Start(const FGuid& Guid);
|
||||||
void Fill2End(const FGuid& Guid);
|
void Fill2End(const FGuid& Guid);
|
||||||
|
void SetCycle(const FGuid& Guid, bool Cycle);
|
||||||
|
|
||||||
// virtual bool CanDragOver() override;
|
// virtual bool CanDragOver() override;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user