Add more statistic tracking (#4837)
+ Added possible 1.8 stats + Added stat tracking for 1.8.2 + Added stat tracking for 1.9 + Added the breed cow achievement Co-authored-by: 12xx12 <12xx12100@gmail.com>
This commit is contained in:
parent
2d197e147e
commit
c2f8ceb554
@ -303,6 +303,8 @@ bool cBeaconEntity::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
|
|
||||||
bool cBeaconEntity::UsedBy(cPlayer * a_Player)
|
bool cBeaconEntity::UsedBy(cPlayer * a_Player)
|
||||||
{
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::InteractWithBeacon);
|
||||||
|
|
||||||
cWindow * Window = GetWindow();
|
cWindow * Window = GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
{
|
{
|
||||||
|
@ -156,6 +156,8 @@ bool cBrewingstandEntity::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
|
|
||||||
bool cBrewingstandEntity::UsedBy(cPlayer * a_Player)
|
bool cBrewingstandEntity::UsedBy(cPlayer * a_Player)
|
||||||
{
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::InteractWithBrewingstand);
|
||||||
|
|
||||||
cWindow * Window = GetWindow();
|
cWindow * Window = GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
{
|
{
|
||||||
|
@ -105,6 +105,15 @@ bool cChestEntity::UsedBy(cPlayer * a_Player)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (m_BlockType == E_BLOCK_CHEST)
|
||||||
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::OpenChest);
|
||||||
|
}
|
||||||
|
else // E_BLOCK_TRAPPED_CHEST
|
||||||
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::TriggerTrappedChest);
|
||||||
|
}
|
||||||
|
|
||||||
// If the window is not created, open it anew:
|
// If the window is not created, open it anew:
|
||||||
cWindow * Window = PrimaryChest->GetWindow();
|
cWindow * Window = PrimaryChest->GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
|
@ -153,6 +153,15 @@ void cDropSpenserEntity::SendTo(cClientHandle & a_Client)
|
|||||||
|
|
||||||
bool cDropSpenserEntity::UsedBy(cPlayer * a_Player)
|
bool cDropSpenserEntity::UsedBy(cPlayer * a_Player)
|
||||||
{
|
{
|
||||||
|
if (m_BlockType == E_BLOCK_DISPENSER)
|
||||||
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::InspectDispenser);
|
||||||
|
}
|
||||||
|
else // E_BLOCK_DROPPER
|
||||||
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::InspectDropper);
|
||||||
|
}
|
||||||
|
|
||||||
cWindow * Window = GetWindow();
|
cWindow * Window = GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
{
|
{
|
||||||
|
@ -61,6 +61,9 @@ bool cEnderChestEntity::UsedBy(cPlayer * a_Player)
|
|||||||
// Obstruction, don't open
|
// Obstruction, don't open
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::OpenEnderchest);
|
||||||
|
|
||||||
// If the window is not created, open it anew:
|
// If the window is not created, open it anew:
|
||||||
cWindow * Window = GetWindow();
|
cWindow * Window = GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
|
@ -59,6 +59,8 @@ bool cFlowerPotEntity::UsedBy(cPlayer * a_Player)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::PotFlower);
|
||||||
|
|
||||||
cItem SelectedItem = a_Player->GetInventory().GetEquippedItem();
|
cItem SelectedItem = a_Player->GetInventory().GetEquippedItem();
|
||||||
if (IsFlower(SelectedItem.m_ItemType, SelectedItem.m_ItemDamage))
|
if (IsFlower(SelectedItem.m_ItemType, SelectedItem.m_ItemDamage))
|
||||||
{
|
{
|
||||||
|
@ -139,6 +139,8 @@ bool cFurnaceEntity::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
|
|
||||||
bool cFurnaceEntity::UsedBy(cPlayer * a_Player)
|
bool cFurnaceEntity::UsedBy(cPlayer * a_Player)
|
||||||
{
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::InteractWithFurnace);
|
||||||
|
|
||||||
cWindow * Window = GetWindow();
|
cWindow * Window = GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
{
|
{
|
||||||
|
@ -106,6 +106,8 @@ void cHopperEntity::SendTo(cClientHandle & a_Client)
|
|||||||
|
|
||||||
bool cHopperEntity::UsedBy(cPlayer * a_Player)
|
bool cHopperEntity::UsedBy(cPlayer * a_Player)
|
||||||
{
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::InspectHopper);
|
||||||
|
|
||||||
// If the window is not created, open it anew:
|
// If the window is not created, open it anew:
|
||||||
cWindow * Window = GetWindow();
|
cWindow * Window = GetWindow();
|
||||||
if (Window == nullptr)
|
if (Window == nullptr)
|
||||||
|
@ -70,6 +70,8 @@ bool cJukeboxEntity::UsedBy(cPlayer * a_Player)
|
|||||||
const cItem & HeldItem = a_Player->GetEquippedItem();
|
const cItem & HeldItem = a_Player->GetEquippedItem();
|
||||||
if (PlayRecord(HeldItem.m_ItemType) && !a_Player->IsGameModeCreative())
|
if (PlayRecord(HeldItem.m_ItemType) && !a_Player->IsGameModeCreative())
|
||||||
{
|
{
|
||||||
|
a_Player->GetStatManager().AddValue(Statistic::PlayRecord);
|
||||||
|
|
||||||
a_Player->GetInventory().RemoveOneEquippedItem();
|
a_Player->GetInventory().RemoveOneEquippedItem();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
#include "NoteEntity.h"
|
#include "NoteEntity.h"
|
||||||
#include "../World.h"
|
#include "../World.h"
|
||||||
#include "json/value.h"
|
#include "json/value.h"
|
||||||
|
#include "../Entities/Player.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -33,7 +34,7 @@ void cNoteEntity::CopyFrom(const cBlockEntity & a_Src)
|
|||||||
|
|
||||||
bool cNoteEntity::UsedBy(cPlayer * a_Player)
|
bool cNoteEntity::UsedBy(cPlayer * a_Player)
|
||||||
{
|
{
|
||||||
UNUSED(a_Player);
|
a_Player->GetStatManager().AddValue(Statistic::TuneNoteblock);
|
||||||
IncrementNote();
|
IncrementNote();
|
||||||
MakeSound();
|
MakeSound();
|
||||||
return true;
|
return true;
|
||||||
|
@ -128,6 +128,7 @@ bool cBlockBedHandler::OnUse(
|
|||||||
SetBedPos(a_Player, a_BlockPos);
|
SetBedPos(a_Player, a_BlockPos);
|
||||||
SetBedOccupationState(a_ChunkInterface, a_Player.GetLastBedPos(), true);
|
SetBedOccupationState(a_ChunkInterface, a_Player.GetLastBedPos(), true);
|
||||||
a_Player.SetIsInBed(true);
|
a_Player.SetIsInBed(true);
|
||||||
|
a_Player.GetStatManager().AddValue(Statistic::SleepInBed);
|
||||||
|
|
||||||
// Fast-forward the time if all players in the world are in their beds:
|
// Fast-forward the time if all players in the world are in their beds:
|
||||||
auto TimeFastForwardTester = [](cPlayer & a_OtherPlayer)
|
auto TimeFastForwardTester = [](cPlayer & a_OtherPlayer)
|
||||||
|
@ -36,6 +36,7 @@ public:
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
a_Player.GetStatManager().AddValue(Statistic::EatCakeSlice);
|
||||||
if (Meta >= 5)
|
if (Meta >= 5)
|
||||||
{
|
{
|
||||||
a_ChunkInterface.DigBlock(a_WorldInterface, a_BlockPos);
|
a_ChunkInterface.DigBlock(a_WorldInterface, a_BlockPos);
|
||||||
|
@ -54,6 +54,7 @@ public:
|
|||||||
if (!a_Player.IsGameModeCreative())
|
if (!a_Player.IsGameModeCreative())
|
||||||
{
|
{
|
||||||
a_Player.ReplaceOneEquippedItemTossRest(cItem(E_ITEM_WATER_BUCKET));
|
a_Player.ReplaceOneEquippedItemTossRest(cItem(E_ITEM_WATER_BUCKET));
|
||||||
|
a_Player.GetStatManager().AddValue(Statistic::UseCauldron);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -68,6 +69,7 @@ public:
|
|||||||
{
|
{
|
||||||
a_Player.ReplaceOneEquippedItemTossRest(cItem(E_ITEM_BUCKET));
|
a_Player.ReplaceOneEquippedItemTossRest(cItem(E_ITEM_BUCKET));
|
||||||
}
|
}
|
||||||
|
a_Player.GetStatManager().AddValue(Statistic::FillCauldron);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -34,6 +34,8 @@ public:
|
|||||||
const Vector3i a_CursorPos
|
const Vector3i a_CursorPos
|
||||||
) override
|
) override
|
||||||
{
|
{
|
||||||
|
a_Player.GetStatManager().AddValue(Statistic::InteractWithCraftingTable);
|
||||||
|
|
||||||
cWindow * Window = new cCraftingWindow();
|
cWindow * Window = new cCraftingWindow();
|
||||||
a_Player.OpenWindow(*Window);
|
a_Player.OpenWindow(*Window);
|
||||||
return true;
|
return true;
|
||||||
|
@ -2109,6 +2109,7 @@ void cClientHandle::Tick(float a_Dt)
|
|||||||
LOGD("Client %s @ %s (%p) has been queued for destruction, destroying now.",
|
LOGD("Client %s @ %s (%p) has been queued for destruction, destroying now.",
|
||||||
m_Username.c_str(), m_IPString.c_str(), static_cast<void *>(this)
|
m_Username.c_str(), m_IPString.c_str(), static_cast<void *>(this)
|
||||||
);
|
);
|
||||||
|
GetPlayer()->GetStatManager().AddValue(Statistic::LeaveGame);
|
||||||
Destroy();
|
Destroy();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -334,7 +334,12 @@ void cPlayer::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
m_Stats.AddValue(Statistic::PlayOneMinute, 1);
|
m_Stats.AddValue(Statistic::PlayOneMinute);
|
||||||
|
m_Stats.AddValue(Statistic::TimeSinceDeath);
|
||||||
|
if (IsCrouched())
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(Statistic::SneakTime);
|
||||||
|
}
|
||||||
|
|
||||||
// Handle the player detach, when the player is in spectator mode
|
// Handle the player detach, when the player is in spectator mode
|
||||||
if (
|
if (
|
||||||
@ -1235,6 +1240,7 @@ void cPlayer::KilledBy(TakeDamageInfo & a_TDI)
|
|||||||
}
|
}
|
||||||
|
|
||||||
m_Stats.AddValue(Statistic::Deaths);
|
m_Stats.AddValue(Statistic::Deaths);
|
||||||
|
m_Stats.SetValue(Statistic::TimeSinceDeath, 0);
|
||||||
|
|
||||||
m_World->GetScoreBoard().AddPlayerScore(GetName(), cObjective::otDeathCount, 1);
|
m_World->GetScoreBoard().AddPlayerScore(GetName(), cObjective::otDeathCount, 1);
|
||||||
}
|
}
|
||||||
@ -2675,14 +2681,33 @@ void cPlayer::UpdateMovementStats(const Vector3d & a_DeltaPos, bool a_PreviousIs
|
|||||||
}
|
}
|
||||||
else if (IsInWater())
|
else if (IsInWater())
|
||||||
{
|
{
|
||||||
// TODO: implement differentiation between diving and swimming
|
if (m_IsHeadInWater)
|
||||||
|
{
|
||||||
m_Stats.AddValue(Statistic::WalkUnderWaterOneCm, Value);
|
m_Stats.AddValue(Statistic::WalkUnderWaterOneCm, Value);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(Statistic::WalkOnWaterOneCm, Value);
|
||||||
|
}
|
||||||
AddFoodExhaustion(0.00015 * static_cast<double>(Value));
|
AddFoodExhaustion(0.00015 * static_cast<double>(Value));
|
||||||
}
|
}
|
||||||
else if (IsOnGround())
|
else if (IsOnGround())
|
||||||
|
{
|
||||||
|
if (IsCrouched())
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(Statistic::CrouchOneCm, Value);
|
||||||
|
AddFoodExhaustion(0.0001 * static_cast<double>(Value));
|
||||||
|
}
|
||||||
|
if (IsSprinting())
|
||||||
|
{
|
||||||
|
m_Stats.AddValue(Statistic::SprintOneCm, Value);
|
||||||
|
AddFoodExhaustion(0.001 * static_cast<double>(Value));
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
m_Stats.AddValue(Statistic::WalkOneCm, Value);
|
m_Stats.AddValue(Statistic::WalkOneCm, Value);
|
||||||
AddFoodExhaustion((IsSprinting() ? 0.001 : 0.0001) * static_cast<double>(Value));
|
AddFoodExhaustion(0.0001 * static_cast<double>(Value));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -57,6 +57,7 @@ void cPassiveMonster::ResetLoveMode()
|
|||||||
m_LoveTimer = 0;
|
m_LoveTimer = 0;
|
||||||
m_MatingTimer = 0;
|
m_MatingTimer = 0;
|
||||||
m_LoveCooldown = 20 * 60 * 5; // 5 minutes
|
m_LoveCooldown = 20 * 60 * 5; // 5 minutes
|
||||||
|
m_Feeder = cUUID();
|
||||||
|
|
||||||
// when an animal is in love mode, the client only stops sending the hearts if we let them know it's in cooldown, which is done with the "age" metadata
|
// when an animal is in love mode, the client only stops sending the hearts if we let them know it's in cooldown, which is done with the "age" metadata
|
||||||
m_World->BroadcastEntityMetadata(*this);
|
m_World->BroadcastEntityMetadata(*this);
|
||||||
@ -125,6 +126,15 @@ void cPassiveMonster::Tick(std::chrono::milliseconds a_Dt, cChunk & a_Chunk)
|
|||||||
|
|
||||||
m_World->SpawnExperienceOrb(Pos.x, Pos.y, Pos.z, GetRandomProvider().RandInt(1, 6));
|
m_World->SpawnExperienceOrb(Pos.x, Pos.y, Pos.z, GetRandomProvider().RandInt(1, 6));
|
||||||
|
|
||||||
|
m_World->DoWithPlayerByUUID(m_Feeder, [&] (cPlayer & a_Player)
|
||||||
|
{
|
||||||
|
a_Player.GetStatManager().AddValue(Statistic::AnimalsBred);
|
||||||
|
if (GetMobType() == eMonsterType::mtCow)
|
||||||
|
{
|
||||||
|
a_Player.AwardAchievement(Statistic::AchBreedCow);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
});
|
||||||
m_LovePartner->ResetLoveMode();
|
m_LovePartner->ResetLoveMode();
|
||||||
ResetLoveMode();
|
ResetLoveMode();
|
||||||
}
|
}
|
||||||
@ -241,6 +251,8 @@ void cPassiveMonster::OnRightClicked(cPlayer & a_Player)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Stores feeder UUID for statistic tracking
|
||||||
|
m_Feeder = a_Player.GetUUID();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "Monster.h"
|
#include "Monster.h"
|
||||||
|
#include "../UUID.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -60,6 +61,9 @@ protected:
|
|||||||
/** The monster's breeding partner. */
|
/** The monster's breeding partner. */
|
||||||
cPassiveMonster * m_LovePartner;
|
cPassiveMonster * m_LovePartner;
|
||||||
|
|
||||||
|
/** Remembers the player is was last fed by for statistics tracking */
|
||||||
|
cUUID m_Feeder;
|
||||||
|
|
||||||
/** If above 0, the monster is in love mode, and will breed if a nearby monster is also in love mode. Decrements by 1 per tick till reaching zero. */
|
/** If above 0, the monster is in love mode, and will breed if a nearby monster is also in love mode. Decrements by 1 per tick till reaching zero. */
|
||||||
int m_LoveTimer;
|
int m_LoveTimer;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user