Updated Cursor for Change when Hovering on Interactable Object
This commit is contained in:
parent
ba4e8bf07c
commit
d17ba9e064
BIN
Content/Blueprints/Display_UI/BP_CrossHair.uasset
(Stored with Git LFS)
BIN
Content/Blueprints/Display_UI/BP_CrossHair.uasset
(Stored with Git LFS)
Binary file not shown.
BIN
Content/Blueprints/Display_UI/InteracableIcon.uasset
(Stored with Git LFS)
Normal file
BIN
Content/Blueprints/Display_UI/InteracableIcon.uasset
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -143,14 +143,17 @@ void UDialogueNPC::TickComponent(float DeltaTime, ELevelTick TickType, FActorCom
|
|||||||
void UDialogueNPC::StartDialogue()
|
void UDialogueNPC::StartDialogue()
|
||||||
{
|
{
|
||||||
Cast<ATempCharacter>(GetWorld()->GetFirstPlayerController()->GetPawn())->bIsInDialogue = true;
|
Cast<ATempCharacter>(GetWorld()->GetFirstPlayerController()->GetPawn())->bIsInDialogue = true;
|
||||||
Cast<ATempCharacter>(GetWorld()->GetFirstPlayerController()->GetPawn())->InventoryWidget->SetVisibility(ESlateVisibility::Hidden);
|
FOutputDeviceNull AR;
|
||||||
Cast<ATempCharacter>(GetWorld()->GetFirstPlayerController()->GetPawn())->EscapeMenuWidget->SetVisibility(ESlateVisibility::Hidden);
|
const FString Command333 = FString::Printf(TEXT("CloseInventory"));
|
||||||
|
GetWorld()->GetFirstPlayerController()->GetPawn()->CallFunctionByNameWithArguments(*Command333, AR, nullptr, true);
|
||||||
|
const FString Command69 = FString::Printf(TEXT("CloseEscapeMenu"));
|
||||||
|
GetWorld()->GetFirstPlayerController()->GetPawn()->CallFunctionByNameWithArguments(*Command69, AR, nullptr, true);
|
||||||
|
Cast<ATempCharacter>(GetWorld()->GetFirstPlayerController()->GetPawn())->CrossHairWidget->SetVisibility(ESlateVisibility::Hidden);
|
||||||
bIsInDialogue = true;
|
bIsInDialogue = true;
|
||||||
Quests.Empty();
|
Quests.Empty();
|
||||||
BlueprintFunctions.Empty();
|
BlueprintFunctions.Empty();
|
||||||
ItemIndexes.Empty();
|
ItemIndexes.Empty();
|
||||||
QuestFlags.Empty();
|
QuestFlags.Empty();
|
||||||
FOutputDeviceNull AR;
|
|
||||||
const FString Command = FString::Printf(TEXT("SetRootDialoguePath"));
|
const FString Command = FString::Printf(TEXT("SetRootDialoguePath"));
|
||||||
GetOwner()->CallFunctionByNameWithArguments(*Command, AR, nullptr, true);
|
GetOwner()->CallFunctionByNameWithArguments(*Command, AR, nullptr, true);
|
||||||
if (IsValid(RootDialoguePath)) CurrentDialogueStringPath = RootDialoguePath->Dialogue;
|
if (IsValid(RootDialoguePath)) CurrentDialogueStringPath = RootDialoguePath->Dialogue;
|
||||||
@ -195,6 +198,7 @@ void UDialogueNPC::EndDialogue()
|
|||||||
PlayerController->SetIgnoreLookInput(false);
|
PlayerController->SetIgnoreLookInput(false);
|
||||||
PlayerController->SetInputMode(FInputModeGameOnly());
|
PlayerController->SetInputMode(FInputModeGameOnly());
|
||||||
PlayerController->bShowMouseCursor = false;
|
PlayerController->bShowMouseCursor = false;
|
||||||
|
Cast<ATempCharacter>(GetWorld()->GetFirstPlayerController()->GetPawn())->CrossHairWidget->SetVisibility(ESlateVisibility::HitTestInvisible);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include "the_twilight_abyss/MerchantInteraction/Interaction.h"
|
#include "the_twilight_abyss/MerchantInteraction/Interaction.h"
|
||||||
#include <Runtime/Engine/Classes/Kismet/GameplayStatics.h>
|
#include <Runtime/Engine/Classes/Kismet/GameplayStatics.h>
|
||||||
#include "Components/PawnNoiseEmitterComponent.h"
|
#include "Components/PawnNoiseEmitterComponent.h"
|
||||||
|
#include "Blueprint/WidgetBlueprintLibrary.h"
|
||||||
#include "Kismet/KismetMathLibrary.h"
|
#include "Kismet/KismetMathLibrary.h"
|
||||||
|
|
||||||
|
|
||||||
@ -20,6 +21,11 @@ ATempCharacter::ATempCharacter()
|
|||||||
Inventory = CreateDefaultSubobject<UInventoryComponent>("Inventory");
|
Inventory = CreateDefaultSubobject<UInventoryComponent>("Inventory");
|
||||||
Inventory->MaxItemSlots = 10;
|
Inventory->MaxItemSlots = 10;
|
||||||
this->GetCharacterMovement()->GetNavAgentPropertiesRef().bCanCrouch = true;
|
this->GetCharacterMovement()->GetNavAgentPropertiesRef().bCanCrouch = true;
|
||||||
|
|
||||||
|
if (static ConstructorHelpers::FObjectFinder<UTexture2D> CrossHairTexture(TEXT("Texture2D'/Game/Blueprints/Display_UI/InteracableIcon.InteracableIcon'")); IsValid(CrossHairTexture.Object))
|
||||||
|
{
|
||||||
|
InteractableCrossHair = CrossHairTexture.Object;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Called when the game starts or when spawned
|
// Called when the game starts or when spawned
|
||||||
@ -48,6 +54,7 @@ void ATempCharacter::BeginPlay()
|
|||||||
//Widget Refs
|
//Widget Refs
|
||||||
CrossHairWidget = CreateWidget<UUserWidget>(GetWorld(), CrossHairSub);
|
CrossHairWidget = CreateWidget<UUserWidget>(GetWorld(), CrossHairSub);
|
||||||
CrossHairWidget->SetVisibility(ESlateVisibility::Visible);
|
CrossHairWidget->SetVisibility(ESlateVisibility::Visible);
|
||||||
|
CrossHair = Cast<UImage>(CrossHairWidget->GetWidgetFromName(TEXT("Crosshair")));
|
||||||
CrossHairWidget->AddToViewport();
|
CrossHairWidget->AddToViewport();
|
||||||
|
|
||||||
InventoryWidget = CreateWidget<UUserWidget>(GetWorld(), InventoryMenuSub);
|
InventoryWidget = CreateWidget<UUserWidget>(GetWorld(), InventoryMenuSub);
|
||||||
@ -107,6 +114,37 @@ void ATempCharacter::Tick(float DeltaTime)
|
|||||||
FirstPlayerController->DeprojectMousePositionToWorld(WidgetLocation, VectorRotation);
|
FirstPlayerController->DeprojectMousePositionToWorld(WidgetLocation, VectorRotation);
|
||||||
WidgetPointer->SetWorldLocationAndRotation(WidgetLocation, VectorRotation.Rotation().Quaternion());
|
WidgetPointer->SetWorldLocationAndRotation(WidgetLocation, VectorRotation.Rotation().Quaternion());
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const FVector Start = ThisCamera->GetComponentLocation();
|
||||||
|
const FVector End = Start + TraceDistance * ThisCamera->GetForwardVector();
|
||||||
|
FCollisionQueryParams TraceParams;
|
||||||
|
TraceParams.AddIgnoredActor(this);
|
||||||
|
if (FHitResult OutResult = FHitResult(); GetWorld()->LineTraceSingleByChannel(OutResult, Start, End, ECC_Pawn, TraceParams))
|
||||||
|
{
|
||||||
|
if (!IsValid(OutResult.GetActor()))
|
||||||
|
{
|
||||||
|
CrossHair->SetBrush(FSlateBrush());
|
||||||
|
CrossHair->SetDesiredSizeOverride(FVector2D(5, 5));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (OutResult.GetActor()->ActorHasTag("Probertium") || OutResult.GetActor()->ActorHasTag("Iroquid")
|
||||||
|
|| OutResult.GetActor()->ActorHasTag("Azos") || OutResult.GetActor()->ActorHasTag("Eis")
|
||||||
|
|| OutResult.GetActor()->ActorHasTag("NPC") || OutResult.GetActor()->FindComponentByClass<UInventoryComponent>())
|
||||||
|
{
|
||||||
|
CrossHair->SetBrush(UWidgetBlueprintLibrary::MakeBrushFromTexture(InteractableCrossHair));
|
||||||
|
CrossHair->SetDesiredSizeOverride(FVector2D(43.6, 51.3));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
CrossHair->SetBrush(FSlateBrush());
|
||||||
|
CrossHair->SetDesiredSizeOverride(FVector2D(5, 5));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CrossHair->SetBrush(FSlateBrush());
|
||||||
|
CrossHair->SetDesiredSizeOverride(FVector2D(5, 5));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Gives the character the functionality
|
// Gives the character the functionality
|
||||||
@ -134,8 +172,8 @@ void ATempCharacter::KeyPressed()
|
|||||||
void ATempCharacter::LineTraceLogic()
|
void ATempCharacter::LineTraceLogic()
|
||||||
{
|
{
|
||||||
//UE_LOG(LogTemp, Display, TEXT("LineTraceLogic activated"));
|
//UE_LOG(LogTemp, Display, TEXT("LineTraceLogic activated"));
|
||||||
float GlobalTrace = TraceDistance;
|
|
||||||
ThisCamera = Cast<UCameraComponent>(this->FindComponentByClass<UCameraComponent>());
|
ThisCamera = Cast<UCameraComponent>(this->FindComponentByClass<UCameraComponent>());
|
||||||
|
float GlobalTrace = TraceDistance;
|
||||||
FVector Start = ThisCamera->GetComponentLocation();
|
FVector Start = ThisCamera->GetComponentLocation();
|
||||||
FVector End = Start + GlobalTrace * ThisCamera->GetForwardVector();
|
FVector End = Start + GlobalTrace * ThisCamera->GetForwardVector();
|
||||||
FCollisionQueryParams TraceParams;
|
FCollisionQueryParams TraceParams;
|
||||||
@ -253,7 +291,7 @@ void ATempCharacter::InputEnabler()
|
|||||||
{
|
{
|
||||||
PlayerCharacter->EnableInput(GetWorld()->GetFirstPlayerController());
|
PlayerCharacter->EnableInput(GetWorld()->GetFirstPlayerController());
|
||||||
}
|
}
|
||||||
|
|
||||||
UE_LOG(LogTemp, Display, TEXT("Enabling Inputs"));
|
UE_LOG(LogTemp, Display, TEXT("Enabling Inputs"));
|
||||||
disableTab = true;
|
disableTab = true;
|
||||||
TraceDistance = 300;
|
TraceDistance = 300;
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
#include "Engine/PostProcessVolume.h"
|
#include "Engine/PostProcessVolume.h"
|
||||||
#include "Components/WidgetInteractionComponent.h"
|
#include "Components/WidgetInteractionComponent.h"
|
||||||
#include "../TurnBasedCombatV2/TurnBaseCombatV2.h"
|
#include "../TurnBasedCombatV2/TurnBaseCombatV2.h"
|
||||||
|
#include "Components/Image.h"
|
||||||
#include "TempCharacter.generated.h"
|
#include "TempCharacter.generated.h"
|
||||||
|
|
||||||
UCLASS()
|
UCLASS()
|
||||||
@ -24,6 +25,9 @@ public:
|
|||||||
UPROPERTY(BlueprintReadOnly)
|
UPROPERTY(BlueprintReadOnly)
|
||||||
bool bIsInDialogue = false;
|
bool bIsInDialogue = false;
|
||||||
|
|
||||||
|
UPROPERTY(EditAnywhere, BlueprintReadWrite)
|
||||||
|
UTexture2D* InteractableCrossHair;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// Called when the game starts or when spawned
|
// Called when the game starts or when spawned
|
||||||
virtual void BeginPlay() override;
|
virtual void BeginPlay() override;
|
||||||
@ -42,6 +46,9 @@ protected:
|
|||||||
UPROPERTY()
|
UPROPERTY()
|
||||||
ATurnBaseCombatV2* CombatSystem;
|
ATurnBaseCombatV2* CombatSystem;
|
||||||
|
|
||||||
|
UPROPERTY()
|
||||||
|
UImage* CrossHair;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
// Called every frame
|
// Called every frame
|
||||||
virtual void Tick(float DeltaTime) override;
|
virtual void Tick(float DeltaTime) override;
|
||||||
|
BIN
UI designs/hand-pointer-icon.png
(Stored with Git LFS)
Normal file
BIN
UI designs/hand-pointer-icon.png
(Stored with Git LFS)
Normal file
Binary file not shown.
@ -1,5 +1,6 @@
|
|||||||
<wpf:ResourceDictionary xml:space="preserve" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:s="clr-namespace:System;assembly=mscorlib" xmlns:ss="urn:shemas-jetbrains-com:settings-storage-xaml" xmlns:wpf="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
|
<wpf:ResourceDictionary xml:space="preserve" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:s="clr-namespace:System;assembly=mscorlib" xmlns:ss="urn:shemas-jetbrains-com:settings-storage-xaml" xmlns:wpf="http://schemas.microsoft.com/winfx/2006/xaml/presentation">
|
||||||
<s:Boolean x:Key="/Default/UserDictionary/Words/=Azos/@EntryIndexedValue">True</s:Boolean>
|
<s:Boolean x:Key="/Default/UserDictionary/Words/=Azos/@EntryIndexedValue">True</s:Boolean>
|
||||||
|
<s:Boolean x:Key="/Default/UserDictionary/Words/=Iroquid/@EntryIndexedValue">True</s:Boolean>
|
||||||
<s:Boolean x:Key="/Default/UserDictionary/Words/=Iroquoid/@EntryIndexedValue">True</s:Boolean>
|
<s:Boolean x:Key="/Default/UserDictionary/Words/=Iroquoid/@EntryIndexedValue">True</s:Boolean>
|
||||||
<s:Boolean x:Key="/Default/UserDictionary/Words/=Probertium/@EntryIndexedValue">True</s:Boolean>
|
<s:Boolean x:Key="/Default/UserDictionary/Words/=Probertium/@EntryIndexedValue">True</s:Boolean>
|
||||||
<s:Boolean x:Key="/Default/UserDictionary/Words/=UFUNCTION/@EntryIndexedValue">True</s:Boolean></wpf:ResourceDictionary>
|
<s:Boolean x:Key="/Default/UserDictionary/Words/=UFUNCTION/@EntryIndexedValue">True</s:Boolean></wpf:ResourceDictionary>
|
Loading…
Reference in New Issue
Block a user