This commit is contained in:
Johannes Wendel
2020-01-15 16:20:07 +01:00
5 changed files with 71 additions and 15 deletions

View File

@@ -25,19 +25,68 @@ void DriverBoardPinController::activate(items::DriverBoardItem &driver_board_ite
{
std::lock_guard<std::mutex> guard(*output_item_mutex);
write_pin(driver_board_item.get_address(), true);
uint8_t address = driver_board_item.get_address();
this->select_mux(address/8);
this->select_adress(address);
write_pin(this->data_pin, true);
}
void DriverBoardPinController::deactivate(items::DriverBoardItem &driver_board_item)
{
std::lock_guard<std::mutex> guard(*output_item_mutex);
write_pin(driver_board_item.get_address(), false);
uint8_t address = driver_board_item.get_address();
this->select_mux(address/8);
this->select_adress(address);
write_pin(this->data_pin, false);
}
void DriverBoardPinController::write_pin(uint8_t pin, bool value) const
{
PinController::write_pin(pin, value);
this->write_pin(pin, value);
}
void DriverBoardPinController::select_adress(uint8_t address)
{
address = address / 8;
this->write_pin(this->address_pins[0], address & 0b001);
this->write_pin(this->address_pins[1], address & 0b010);
this->write_pin(this->address_pins[2], address & 0b100);
}
void DriverBoardPinController::set_address_pins(std::array<uint8_t, 3> address_pins)
{
this->address_pins = address_pins;
}
void DriverBoardPinController::set_mux_pins(std::array<uint8_t, 13> mux_enable_pins)
{
this->mux_enable_pins = mux_enable_pins;
}
void DriverBoardPinController::set_data_pin(uint8_t data_pin)
{
this->data_pin = data_pin;
}
void DriverBoardPinController::set_run_pin(uint8_t run_pin)
{
this->run_pin = run_pin;
}
void DriverBoardPinController::select_mux(uint8_t mux)
{
this->deselect_all_muxes();
this->write_pin(this->mux_enable_pins[mux], 1);
}
void DriverBoardPinController::deselect_all_muxes()
{
for(auto pin : mux_enable_pins)
{
this->write_pin(pin, 0);
}
}
}

View File

@@ -28,11 +28,24 @@ public:
void activate(items::DriverBoardItem & driver_board_item);
void deactivate(items::DriverBoardItem & driver_board_item);
void set_address_pins(std::array<uint8_t, 3> address_pins);
void set_mux_pins(std::array<uint8_t, 13> mux_enable_pins);
void set_data_pin(uint8_t data_pin);
void set_run_pin(uint8_t run_pin);
private:
void deselect_all_muxes();
void select_mux(uint8_t mux);
void select_adress(uint8_t address);
void write_pin(uint8_t pin, bool value) const;
private:
std::shared_ptr<std::mutex> output_item_mutex;
std::array<uint8_t, 3> address_pins;
std::array<uint8_t, 13> mux_enable_pins;
uint8_t data_pin;
uint8_t run_pin;
};
}

View File

@@ -15,7 +15,7 @@ namespace detail
SoundBoardPinController::SoundBoardPinController(std::shared_ptr<std::mutex> output_item_mutex,
uint8_t fire_address,
const std::vector<uint8_t> address_pins) :
const std::array<uint8_t, 7> address_pins) :
output_item_mutex{output_item_mutex},
fire_address{fire_address},
address_pins{address_pins}
@@ -71,7 +71,7 @@ void SoundBoardPinController::write_pin(const uint8_t &pin, const bool &value) c
PinController::write_pin(pin, value);
}
void SoundBoardPinController::set_address_pins(std::vector<uint8_t> address_pins)
void SoundBoardPinController::set_address_pins(std::array<uint8_t, 7> address_pins)
{
this->address_pins = address_pins;

View File

@@ -19,7 +19,7 @@ namespace detail
class SoundBoardPinController : public output::SoundBoardPinController
{
public:
explicit SoundBoardPinController(std::shared_ptr<std::mutex> output_item_mutex, uint8_t fire_address, const std::vector<uint8_t> address_pins);
explicit SoundBoardPinController(std::shared_ptr<std::mutex> output_item_mutex, uint8_t fire_address, const std::array<uint8_t, 7> address_pins);
explicit SoundBoardPinController(std::shared_ptr<std::mutex> output_item_mutex);
~SoundBoardPinController() override = default;
@@ -27,7 +27,7 @@ public:
void deactivate(const items::detail::Sound &sound);
void set_fire_address(const uint8_t & fire_address);
void set_address_pins(const std::vector<uint8_t> address_pins);
void set_address_pins(const std::array<uint8_t, 7> address_pins);
private:
void write_sound_address(const uint8_t & address) const;
@@ -40,7 +40,7 @@ private:
uint8_t pin_base;
uint8_t fire_address;
std::vector<uint8_t> address_pins;
std::array<uint8_t, 7> address_pins;
};
}

View File

@@ -52,13 +52,7 @@ void SoundFactory::set_address_pins()
{
auto address_pins = object.at(config_path::address_pins);
std::vector<uint8_t> pins;
//todo mach nen array draus
for (auto & pin_json : address_pins)
{
pins.push_back(0);
}
std::array<uint8_t, 7> pins;
for (auto & pin_json : address_pins)
{