Files
jaildoctors_dilemma/source/item_tracker.cpp
2025-02-26 13:07:41 +01:00

91 lines
2.0 KiB
C++

#include "item_tracker.h"
// [SINGLETON]
ItemTracker *ItemTracker::item_tracker_ = nullptr;
// [SINGLETON] Crearemos el objeto con esta función estática
void ItemTracker::init()
{
ItemTracker::item_tracker_ = new ItemTracker();
}
// [SINGLETON] Destruiremos el objeto con esta función estática
void ItemTracker::destroy()
{
delete ItemTracker::item_tracker_;
}
// [SINGLETON] Con este método obtenemos el objeto y podemos trabajar con él
ItemTracker *ItemTracker::get()
{
return ItemTracker::item_tracker_;
}
// Comprueba si el objeto ya ha sido cogido
bool ItemTracker::hasBeenPicked(const std::string &name, SDL_Point pos)
{
// Primero busca si ya hay una entrada con ese nombre
if (const int index = findByName(name); index != -1)
{
// Luego busca si existe ya una entrada con esa posición
if (findByPos(index, pos) != -1)
{
return true;
}
}
return false;
}
// Añade el objeto a la lista de objetos cogidos
void ItemTracker::addItem(const std::string &name, SDL_Point pos)
{
// Comprueba si el objeto no ha sido recogido con anterioridad
if (!hasBeenPicked(name, pos))
{
// Primero busca si ya hay una entrada con ese nombre
if (const int index = findByName(name); index != -1)
{
list.at(index).pos.push_back(pos);
}
// En caso contrario crea la entrada
else
{
list.emplace_back(name, pos);
}
}
}
// Busca una entrada en la lista por nombre
int ItemTracker::findByName(std::string name)
{
int i = 0;
for (const auto &l : list)
{
if (l.name == name)
{
return i;
}
i++;
}
return -1;
}
// Busca una entrada en la lista por posición
int ItemTracker::findByPos(int index, SDL_Point pos)
{
int i = 0;
for (const auto &l : list[index].pos)
{
if ((l.x == pos.x) && (l.y == pos.y))
{
return i;
}
i++;
}
return -1;
}