Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion SDK
8 changes: 4 additions & 4 deletions Server/Components/CAPI/Impl/Objects/APIs.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -821,10 +821,10 @@ OMP_CAPI(Player_GetSurfingPlayerObject, objectPtr(objectPtr player))
OMP_CAPI(Player_GetCameraTargetPlayerObject, objectPtr(objectPtr player))
{
POOL_ENTITY_RET(players, IPlayer, player, player_, nullptr);
IObject* object = player_->getCameraTargetObject();
if (object)
IPlayerCameraTargetData* data = queryExtension<IPlayerCameraTargetData>(player_);
if (!data)
{
return object;
return nullptr;
}
return nullptr;
return data->getCameraTargetPlayerObject();
}
7 changes: 6 additions & 1 deletion Server/Components/Pawn/Scripting/Object/PlayerNatives.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -287,7 +287,12 @@ SCRIPT_API(GetPlayerSurfingPlayerObjectID, int(IPlayer& player))

SCRIPT_API(GetPlayerCameraTargetPlayerObj, int(IPlayer& player))
{
IObject* object = player.getCameraTargetObject();
IPlayerCameraTargetData* data = queryExtension<IPlayerCameraTargetData>(player);
if (!data)
{
return INVALID_OBJECT_ID;
}
IPlayerObject* object = data->getCameraTargetPlayerObject();
if (object)
{
return object->getID();
Expand Down
24 changes: 12 additions & 12 deletions Server/Source/player.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -123,23 +123,23 @@ IObject* Player::getCameraTargetObject()
return nullptr;
}

IObject* object = component->get(cameraTargetObject_);
return component->get(cameraTargetObject_);
}

if (!object)
IPlayerObject* PlayerCameraTargetData::getCameraTargetPlayerObject()
{
if (!player_.enableCameraTargeting_)
{
IPlayerObjectData* data = queryExtension<IPlayerObjectData>(this);
return nullptr;
}

if (data)
{
IPlayerObject* player_object = data->get(cameraTargetObject_);
if (player_object)
{
return reinterpret_cast<IObject*>(player_object);
}
}
IPlayerObjectData* data = queryExtension<IPlayerObjectData>(&player_);
if (!data)
{
return nullptr;
}

return object;
return data->get(player_.cameraTargetObject_);
}

IPlayer* Player::getTargetPlayer()
Expand Down
26 changes: 26 additions & 0 deletions Server/Source/player_impl.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,31 @@ enum SecondarySyncUpdateType
SecondarySyncUpdateType_Trailer = (1 << 2),
};

struct Player;

class PlayerCameraTargetData final : public IPlayerCameraTargetData
{
private:
Player& player_;

public:
PlayerCameraTargetData(Player& player)
: player_(player)
{
}

IPlayerObject* getCameraTargetPlayerObject() override;

void freeExtension() override
{
delete this;
}

void reset() override
{
}
};

struct Player final : public IPlayer, public PoolIDProvider, public NoCopy
{
PlayerPool& pool_;
Expand Down Expand Up @@ -275,6 +300,7 @@ struct Player final : public IPlayer, public PoolIDProvider, public NoCopy
{
weapons_.fill({ 0, 0 });
skillLevels_.fill(MAX_SKILL_LEVEL);
addExtension(new PlayerCameraTargetData(*this), true);
}

void ban(StringView reason) override;
Expand Down
Loading