diff --git a/EndlessVendetta/Content/Dialogue/BP_ChoiceButton.uasset b/EndlessVendetta/Content/Dialogue/BP_ChoiceButton.uasset new file mode 100644 index 00000000..99fe8f57 --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/BP_ChoiceButton.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:92491ea67e7c30c15a81fb5f3f5ea677337f308489c06b92509a99b0fc6ad5bb +size 47654 diff --git a/EndlessVendetta/Content/Dialogue/BP_DialogueUI.uasset b/EndlessVendetta/Content/Dialogue/BP_DialogueUI.uasset index 5a865577..085864ef 100644 --- a/EndlessVendetta/Content/Dialogue/BP_DialogueUI.uasset +++ b/EndlessVendetta/Content/Dialogue/BP_DialogueUI.uasset @@ -1,3 +1,3 @@ version https://git-lfs.github.com/spec/v1 -oid sha256:6d51f9881a6133d0034410344d0809ed18ed108981b46507868b51c2bcacd7b6 -size 287864 +oid sha256:35908c5dcdb5143afd98a83341d8cb46d90ab1430b3d365f1b4707d85c793c70 +size 224018 diff --git a/EndlessVendetta/Content/Dialogue/D_Mayor_Tutorial.uasset b/EndlessVendetta/Content/Dialogue/D_Mayor_Tutorial.uasset new file mode 100644 index 00000000..c8a1e2e7 --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/D_Mayor_Tutorial.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:5b1e0389b55c1a3619cc6d04739ca92ebf332e67c2f9fce20a7d9a240d7fc654 +size 87783 diff --git a/EndlessVendetta/Content/Dialogue/TestDialogueCube.uasset b/EndlessVendetta/Content/Dialogue/TestDialogueCube.uasset new file mode 100644 index 00000000..c527979a --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/TestDialogueCube.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:1f02a139ca0765bc88152d89b253c76f11837193aaaaf1822f950d38578cc5e1 +size 2455 diff --git a/EndlessVendetta/Content/Dialogue/Testing/BP_Mayor.uasset b/EndlessVendetta/Content/Dialogue/Testing/BP_Mayor.uasset new file mode 100644 index 00000000..86869ecb --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/BP_Mayor.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:4280fd261e4b0d85f410669264906255cdcc74e55477faa4fe5e46c3d33aeee4 +size 30273 diff --git a/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle.uasset b/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle.uasset new file mode 100644 index 00000000..5ad7be4d --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:8f6e6d75f641a2e7dd11f95db5bfc72cde7bb66e942831962061901cf79f21b3 +size 785162 diff --git a/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle_PhysicsAsset.uasset b/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle_PhysicsAsset.uasset new file mode 100644 index 00000000..fb0f6134 --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle_PhysicsAsset.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:e7d59d593d60ea9144d8f0632eb29ee2d1ee92fcbe20e5fccb7a34505beb9a71 +size 16250 diff --git a/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle_Skeleton.uasset b/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle_Skeleton.uasset new file mode 100644 index 00000000..5a52dca2 --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/Catman_Idle_Skeleton.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:97c387ee6c4607c9a841c13d5f309ce7e48158b7db0521f0f9c65549324c326e +size 13447 diff --git a/EndlessVendetta/Content/Dialogue/Testing/Material.uasset b/EndlessVendetta/Content/Dialogue/Testing/Material.uasset new file mode 100644 index 00000000..9eab430c --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/Material.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:f3d1f8b1ff90eb9ba3ff2dc40dc19d0deef6e69dc213255bee4f7748e4b04346 +size 7914 diff --git a/EndlessVendetta/Content/Dialogue/Testing/Material_001.uasset b/EndlessVendetta/Content/Dialogue/Testing/Material_001.uasset new file mode 100644 index 00000000..bc52c384 --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/Material_001.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:656790daef70f5db329953fe750bd011cc50dd34ff9b0ba51bb2e26476d85972 +size 8143 diff --git a/EndlessVendetta/Content/Dialogue/Testing/Material_002.uasset b/EndlessVendetta/Content/Dialogue/Testing/Material_002.uasset new file mode 100644 index 00000000..83dce43a --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/Material_002.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:b041ea1092257c487bab6aef0483e5e6c950a6f90474bdaf4dd9976c5fee72bb +size 8143 diff --git a/EndlessVendetta/Content/Dialogue/Testing/TestDialogueCube.uasset b/EndlessVendetta/Content/Dialogue/Testing/TestDialogueCube.uasset new file mode 100644 index 00000000..c12313ff --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/TestDialogueCube.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:e7323a610767b1f1cc758dd6fa1c9cb34407545561ad153e0ad0ac12cb78f894 +size 28384 diff --git a/EndlessVendetta/Content/Dialogue/Testing/TestDialogueTree.uasset b/EndlessVendetta/Content/Dialogue/Testing/TestDialogueTree.uasset new file mode 100644 index 00000000..5f598325 --- /dev/null +++ b/EndlessVendetta/Content/Dialogue/Testing/TestDialogueTree.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:ec1e794ed8e8a4409f4bc77584623c727508513bf407e4059ce1e4a41b8d90c1 +size 24487 diff --git a/EndlessVendetta/Content/Dialogue/test.uasset b/EndlessVendetta/Content/Dialogue/test.uasset deleted file mode 100644 index c8e7f317..00000000 --- a/EndlessVendetta/Content/Dialogue/test.uasset +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:af6de724c9c9f4c366b93b385ebe76dc85d3dbfdde418ecc65fe7492d76c6c4f -size 16429 diff --git a/EndlessVendetta/Content/__ExternalActors__/Levels/EnemyAITest/E/WM/7S8OEF1ALOX6NKI759UPUB.uasset b/EndlessVendetta/Content/__ExternalActors__/Levels/EnemyAITest/E/WM/7S8OEF1ALOX6NKI759UPUB.uasset new file mode 100644 index 00000000..33189d8b --- /dev/null +++ b/EndlessVendetta/Content/__ExternalActors__/Levels/EnemyAITest/E/WM/7S8OEF1ALOX6NKI759UPUB.uasset @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:4e230c10405edc83911b7a264e397dfa14d304c5492cfdd64add703df2b758b6 +size 4769 diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.cpp b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.cpp index f87077dc..f11997ca 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.cpp +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.cpp @@ -25,6 +25,21 @@ void UAC_PlayerDialogueInterpreter::BeginPlay() // ... } +FDialogueCharacter* UAC_PlayerDialogueInterpreter::GetCharacterSpeakingFromEnum(ECharacterSpeaking CharacterSpeakingEnum) const +{ + switch (CharacterSpeakingEnum) + { + case ECharacterSpeaking::Character1: + return &CurrentDialogueTree->Character1; + case ECharacterSpeaking::Character2: + return &CurrentDialogueTree->Character2; + case ECharacterSpeaking::Character3: + return &CurrentDialogueTree->Character3; + case ECharacterSpeaking::Character4: + return &CurrentDialogueTree->Character4; + } + return nullptr; +} // Called every frame void UAC_PlayerDialogueInterpreter::TickComponent(float DeltaTime, ELevelTick TickType, FActorComponentTickFunction* ThisTickFunction) @@ -38,6 +53,8 @@ void UAC_PlayerDialogueInterpreter::StartDialogue(UDialogueTree* DialogueTree) { CurrentDialogueTree = DialogueTree; CurrentTextNode = Cast(DialogueTree->RootNodes[0]->ChildrenNodes[0]); + if (!IsValid(CurrentTextNode)) return; + CurrentCharacterSpeaking = *GetCharacterSpeakingFromEnum(CurrentTextNode->DialogueCharacterSpeaking); OnStartDialogue.Broadcast(CurrentTextNode); if (APlayerController* PlayerController = GetWorld()->GetFirstPlayerController()) @@ -66,6 +83,7 @@ void UAC_PlayerDialogueInterpreter::NextDialogue() else { CurrentTextNode = Cast(CurrentTextNode->ChildrenNodes[0]); + CurrentCharacterSpeaking = *GetCharacterSpeakingFromEnum(CurrentTextNode->DialogueCharacterSpeaking); OnNextDialogue.Broadcast(CurrentTextNode); CurrentChoiceNode = nullptr; } @@ -83,6 +101,7 @@ void UAC_PlayerDialogueInterpreter::MakeChoiceDialogue(const int Choice) else { CurrentTextNode = Cast(CurrentChoiceNode->ChildrenNodes[Choice]); + CurrentCharacterSpeaking = *GetCharacterSpeakingFromEnum(CurrentTextNode->DialogueCharacterSpeaking); OnNextDialogue.Broadcast(CurrentTextNode); CurrentChoiceNode = nullptr; } @@ -92,6 +111,7 @@ void UAC_PlayerDialogueInterpreter::EndDialogue() { CurrentChoiceNode = nullptr; CurrentTextNode = nullptr; + CurrentCharacterSpeaking = FDialogueCharacter(); OnEndDialogue.Broadcast(); if (APlayerController* PlayerController = GetWorld()->GetFirstPlayerController()) diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.h b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.h index 31da0195..4da84a18 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.h +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/AC_PlayerDialogueInterpreter.h @@ -37,6 +37,8 @@ public: UPROPERTY(BlueprintReadOnly, VisibleAnywhere, Category = "Dialogue") UDialogueTree* CurrentDialogueTree; + UPROPERTY(BlueprintReadOnly, VisibleAnywhere, Category = "Dialogue") + FDialogueCharacter CurrentCharacterSpeaking; protected: // Called when the game starts @@ -47,6 +49,7 @@ private: UDialogueTextNode* CurrentTextNode; UPROPERTY() UDialogueChoiceNode* CurrentChoiceNode; + FDialogueCharacter* GetCharacterSpeakingFromEnum(ECharacterSpeaking CharacterSpeakingEnum) const; public: // Called every frame diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.cpp b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.cpp index 2758d6af..00c3b94f 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.cpp +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.cpp @@ -1,4 +1,6 @@ #include "DialogueChoiceNode.h" + +#include "DialogueEdge.h" #include "DialogueTree.h" #define LOCTEXT_NAMESPACE "UDialogueChoiceNode" @@ -14,6 +16,33 @@ UDialogueChoiceNode::UDialogueChoiceNode() #if WITH_EDITOR +FText UDialogueChoiceNode::GetNodeTitle() const +{ + bool bHasValidNumberOfChoices = false; + if (Choices.Num() == ChildrenNodes.Num()) bHasValidNumberOfChoices = true; + for (int i = 0; i < Edges.Num(); i++) + { + if (!bHasValidNumberOfChoices) + { + Cast(Edges[ChildrenNodes[i]])->EdgeColour = FLinearColor::Red; + Cast(Edges[ChildrenNodes[i]])->SetNodeTitle(FText::FromString("INVALID")); + } + else if (Choices[i].Len() > 15) + { + FString Substring = Choices[i].Left(15); + Substring.Append("..."); + Cast(Edges[ChildrenNodes[i]])->SetNodeTitle(FText::FromString(Substring)); + } + else + { + Cast(Edges[ChildrenNodes[i]])->SetNodeTitle(FText::FromString(Choices[i])); + Cast(Edges[ChildrenNodes[i]])->EdgeColour = FLinearColor::White; + } + } + const FText ChoiceNodeTitle = NodeTitle.IsEmpty() ? LOCTEXT("Choice Node", "Choice Node") : NodeTitle; + return FText::Format(LOCTEXT("Choice Node Title", "{0} [{1}]"), ChoiceNodeTitle, FText::AsNumber(Choices.Num())); +} + FLinearColor UDialogueChoiceNode::GetBackgroundColor() const { const UDialogueTree* DialogueTree = Cast(GetGraph()); diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.h b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.h index 0b0550b2..9f38ede7 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.h +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueChoiceNode.h @@ -13,13 +13,10 @@ public: UDialogueChoiceNode(); UPROPERTY(EditDefaultsOnly, BlueprintReadOnly, Category = "Dialogue") - FString Choice1Text = "None"; - UPROPERTY(EditDefaultsOnly, BlueprintReadOnly, Category = "Dialogue") - FString Choice2Text = "None"; - UPROPERTY(EditDefaultsOnly, BlueprintReadOnly, Category = "Dialogue") - FString Choice3Text = "None"; + TArray Choices; #if WITH_EDITOR + virtual FText GetNodeTitle() const override; virtual FLinearColor GetBackgroundColor() const override; #endif }; diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueEdge.h b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueEdge.h index ef92beff..3613f00d 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueEdge.h +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueEdge.h @@ -6,11 +6,14 @@ UCLASS(Blueprintable) -class UDialogueEdge: public UGenericGraphEdge +class UDialogueEdge : public UGenericGraphEdge { GENERATED_BODY() - // public: - // UPROPERTY(EditDefaultsOnly, BlueprintReadOnly, Category = "Dialogue") - // FText Selection; -}; \ No newline at end of file + UDialogueEdge(); +}; + +inline UDialogueEdge::UDialogueEdge() +{ + bShouldDrawTitle = true; +} diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueRootNode.cpp b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueRootNode.cpp index 43a8ab4b..a4981347 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueRootNode.cpp +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueRootNode.cpp @@ -23,7 +23,7 @@ FLinearColor UDialogueRootNode::GetBackgroundColor() const if (const UDialogueTree* DialogueTree = Cast(GetGraph()); DialogueTree == nullptr) return Super::GetBackgroundColor(); - return FLinearColor(1.f, 1.f, 1.f, 1.f); + return FLinearColor(0.f, 1.f, 0.f, 1.f); } #endif diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTextNode.h b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTextNode.h index af556e4b..4eb9f33d 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTextNode.h +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTextNode.h @@ -30,9 +30,7 @@ public: #if WITH_EDITOR virtual FText GetNodeTitle() const override; - virtual void SetNodeTitle(const FText& NewTitle) override; - virtual FLinearColor GetBackgroundColor() const override; #endif }; diff --git a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTree.h b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTree.h index ed992455..92f3f1bd 100644 --- a/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTree.h +++ b/EndlessVendetta/Source/EndlessVendetta/DialogueSystem/DialogueTree.h @@ -12,9 +12,9 @@ struct FDialogueCharacter UPROPERTY(BlueprintReadOnly, EditDefaultsOnly, Category = "Dialogue") FName CharacterName; UPROPERTY(BlueprintReadOnly, EditDefaultsOnly, Category = "Dialogue") - FLinearColor DialogueNodeBgColor; - UPROPERTY(BlueprintReadOnly, EditDefaultsOnly, Category = "Dialogue") UTexture2D* DialogueCharacterPortrait; + UPROPERTY(BlueprintReadOnly, EditDefaultsOnly, Category = "Node") + FLinearColor DialogueNodeBgColor; }; UCLASS(Blueprintable)