NerfUS mobile node that manages a target for the Nerf gun firing range

Dependencies:   LedController mbed-rtos mbed NerfUSXbee Servomotor TargetManager

Fork of NerfUS by NerfUS

source/TargetManager.cpp

Committer:
Maxime Dupuis
Date:
2017-04-09
Revision:
38:70a1c8bd2877
Parent:
37:8fc7845ae95b
Child:
39:a98413395b20

File content as of revision 38:70a1c8bd2877:

#include "TargetManager.hpp"

TargetManager::TargetManager(std::vector<TargetInterface*>& targets,
		std::vector<NerfusTickerInterface*>& nerfus_tickers) :
	targets(targets),
	nerfus_tickers(nerfus_tickers)
{
	for(int i=0; i<targets.size(); i++)
	{
		is_active_target.push_back(false);
	}
}

void TargetManager::execute(const TargetInfo& target_info)
{
	TargetInterface& target = *(targets[target_info.id]);

	if(target_info.type == TARGET_TYPE_ALLY)
	{
		target.ally_command();
	}
	else
	{
		target.enemy_command();
	}

	is_active_target[target_info.id] = true;

	nerfus_tickers[target_info.id]->start(target_info.timeout_ms);
}

void TargetManager::execute(const std::vector<uint8_t>& target_info_bytes, int *address)
{
	const int id = target_info_bytes[0];
	const TargetType type = (target_info_bytes[1] == 0) ? TARGET_TYPE_ALLY : TARGET_TYPE_ENEMY;
	const int timeout_msb = target_info_bytes[2];
	const int timeout_lsb = target_info_bytes[3];
	const int timeout = (timeout_msb << 8) + timeout_lsb;
	const TargetInfo target_info = make_TargetInfo(id, type, timeout);
	execute(target_info);
}

void TargetManager::target_hit(int target_number)
{
	if(is_active_target[target_number])
	{
		targets[target_number]->hit(nerfus_tickers[target_number]->get_time_ms());
		nerfus_tickers[target_number]->stop();
		is_active_target[target_number] = false;
	}
}

void TargetManager::target_missed(int target_number)
{
	if(is_active_target[target_number])
	{
		targets[target_number]->timeout(nerfus_tickers[target_number]->get_time_ms());
		nerfus_tickers[target_number]->stop();
		is_active_target[target_number] = false;
	}
}