Skip to content

Commit

Permalink
Merge branch 'development'
Browse files Browse the repository at this point in the history
  • Loading branch information
schetle committed Jun 25, 2024
2 parents 497bb3c + 55768ba commit 9f24893
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 27 deletions.
1 change: 1 addition & 0 deletions Source/Rive/Private/Rive/RiveObject.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ URiveObject::URiveObject()

void URiveObject::BeginDestroy()
{
OnRiveReady.Clear();
RiveRenderTarget.Reset();

if (IsValid(Artboard))
Expand Down
59 changes: 34 additions & 25 deletions Source/Rive/Private/UMG/RiveWidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -54,14 +54,23 @@ void URiveWidget::ReleaseSlateResources(bool bReleaseChildren)
TSharedRef<SWidget> URiveWidget::RebuildWidget()
{
RiveWidget = SNew(SRiveWidget);
Setup();
return RiveWidget.ToSharedRef();
}

if (!RiveObject && RiveWidget.IsValid())
{
RiveObject = NewObject<URiveObject>();

void URiveWidget::NativeConstruct()
{
Super::NativeConstruct();
Setup();
#if WITH_EDITOR
TimerHandle.Invalidate();
GetWorld()->GetTimerManager().SetTimer(TimerHandle, [this]()
{
Setup();
}, 0.05f, false);
#else
Setup();
#endif
}

return RiveWidget.ToSharedRef();
}

void URiveWidget::SetAudioEngine(URiveAudioEngine* InAudioEngine)
Expand All @@ -85,28 +94,28 @@ URiveArtboard* URiveWidget::GetArtboard() const
return nullptr;
}

void URiveWidget::OnRiveObjectReady()
{
if (!RiveWidget.IsValid() || !GetCachedWidget()) return;
RiveObject->OnRiveReady.Remove(FrameHandle);

UE::Slate::FDeprecateVector2DResult AbsoluteSize = GetCachedGeometry().GetAbsoluteSize();

RiveObject->ResizeRenderTargets(FIntPoint(AbsoluteSize.X, AbsoluteSize.Y));
RiveWidget->SetRiveTexture(RiveObject);
RiveWidget->RegisterArtboardInputs({RiveObject->GetArtboard()});
OnRiveReady.Broadcast();
}

void URiveWidget::Setup()
{
if (!RiveObject && RiveWidget.IsValid())
if (!RiveObject || !RiveWidget.IsValid())
{
TimerHandle.Invalidate();
GetWorld()->GetTimerManager().SetTimer(TimerHandle, [this]()
{
RiveObject = NewObject<URiveObject>();
RiveObject->OnRiveReady.AddLambda([this]()
{
if (!RiveWidget.IsValid()) return;

UE::Slate::FDeprecateVector2DResult AbsoluteSize = GetCachedGeometry().GetAbsoluteSize();

RiveObject->ResizeRenderTargets(FIntPoint(AbsoluteSize.X, AbsoluteSize.Y));
RiveWidget->SetRiveTexture(RiveObject);
RiveWidget->RegisterArtboardInputs({RiveObject->GetArtboard()});
OnRiveReady.Broadcast();
});
RiveObject->Initialize(RiveDescriptor);
}, 0.05f, false);
return;
}

FrameHandle = RiveObject->OnRiveReady.AddUObject(this, &URiveWidget::OnRiveObjectReady);
RiveObject->Initialize(RiveDescriptor);
}

#undef LOCTEXT_NAMESPACE
6 changes: 4 additions & 2 deletions Source/Rive/Public/UMG/RiveWidget.h
Original file line number Diff line number Diff line change
Expand Up @@ -42,8 +42,6 @@ class RIVE_API URiveWidget : public UUserWidget

virtual TSharedRef<SWidget> RebuildWidget() override;

virtual void NativeConstruct() override;

//~ END : UWidget Interface

/**
Expand All @@ -70,13 +68,17 @@ class RIVE_API URiveWidget : public UUserWidget

UPROPERTY(BlueprintReadOnly, Transient, Category = Rive)
TObjectPtr<URiveAudioEngine> RiveAudioEngine;

private:
void OnRiveObjectReady();

// Runtime objects
UPROPERTY(Transient)
TObjectPtr<URiveObject> RiveObject;

void Setup();
TSharedPtr<SRiveWidget> RiveWidget;
FTimerHandle TimerHandle;
FDelegateHandle FrameHandle;

};

0 comments on commit 9f24893

Please sign in to comment.