From b83e1bf20d98f9130674186a76d7050455baf787 Mon Sep 17 00:00:00 2001 From: jadebenn Date: Thu, 28 Dec 2023 18:21:45 -0600 Subject: [PATCH] some further bouncer refinements --- dGame/dComponents/PetComponent.cpp | 22 ++++------------------ dGame/dGameMessages/GameMessages.cpp | 2 -- 2 files changed, 4 insertions(+), 20 deletions(-) diff --git a/dGame/dComponents/PetComponent.cpp b/dGame/dComponents/PetComponent.cpp index ed0f73f8..2bb9f0e6 100644 --- a/dGame/dComponents/PetComponent.cpp +++ b/dGame/dComponents/PetComponent.cpp @@ -976,39 +976,25 @@ void PetComponent::StartInteractBouncer() { void PetComponent::HandleInteractBouncer() { if (IsHandlingInteraction()) { - auto* const owner = GetOwner(); - if (!owner) return; - const auto sysAddr = owner->GetSystemAddress(); - auto* const petSwitch = SwitchComponent::GetClosestSwitch(m_MovementAI->GetDestination()); // TODO: Find a better way to do this if (!petSwitch) return; auto* const petSwitchEntity = petSwitch->GetParentEntity(); if (!petSwitchEntity) return; - m_Parent->AddCallbackTimer(1.0f, [this, petSwitch, petSwitchEntity, sysAddr]() { - LOG_DEBUG("Callback start!"); - - const auto bouncerComp = petSwitch->GetPetBouncer(); + m_Parent->AddCallbackTimer(1.0f, [this, petSwitch, petSwitchEntity]() { + auto* const bouncerComp = petSwitch->GetPetBouncer(); const auto bouncerCompPos = bouncerComp->GetParentEntity()->GetPosition(); const auto bouncerId = bouncerComp->GetParentEntity()->GetObjectID(); - const auto petId = this->GetParentEntity()->GetObjectID(); - - RenderComponent::PlayAnimation(petSwitchEntity, u"launch"); //u"engaged"); bouncerComp->SetPetBouncerEnabled(true); GameMessages::SendRequestClientBounce(bouncerId, this->GetOwnerId(), NiPoint3::ZERO, NiPoint3::ZERO, bouncerId, true, false, UNASSIGNED_SYSTEM_ADDRESS); //TODO: Check packet captures!! bouncerComp->SetPetBouncerEnabled(false); RenderComponent::PlayAnimation(petSwitchEntity, u"up"); - - LOG_DEBUG("Callback end!"); }); - //RenderComponent::PlayAnimation(petSwitchEntity, u"launch"); //u"engaged"); - - auto* const petBouncer = petSwitch->GetPetBouncer(); - petBouncer->SetPetBouncerEnabled(true); - + RenderComponent::PlayAnimation(petSwitchEntity, u"launch"); //u"engaged"); //TODO: Check if the timing on this is right + // TODO: Need to freeze player movement until the bounce begins! Command(NiPoint3::ZERO, LWOOBJID_EMPTY, 1, PetEmote::ActivateSwitch, true); // Plays 'jump on switch' animation StopInteract(); diff --git a/dGame/dGameMessages/GameMessages.cpp b/dGame/dGameMessages/GameMessages.cpp index fd334097..c98844a0 100644 --- a/dGame/dGameMessages/GameMessages.cpp +++ b/dGame/dGameMessages/GameMessages.cpp @@ -3590,8 +3590,6 @@ void GameMessages::SendBouncerActiveStatus(LWOOBJID objectId, bool bActive, cons } void GameMessages::SendRequestClientBounce(const LWOOBJID& objectId, const LWOOBJID& bounceTargetId, const NiPoint3& bounceTargetPos, const NiPoint3& bouncedObjLinVel, const LWOOBJID& requestSourceId, const bool bAllBounced, const bool bAllowClientOverload, const SystemAddress& sysAddr) { - LOG_DEBUG("REQUEST CLIENT BOUNCE!"); - CBITSTREAM; CMSGHEADER;