Update stable version 24/05/2025 #2
@ -4,14 +4,15 @@
|
|||||||
enum LCDScreenState {
|
enum LCDScreenState {
|
||||||
DISPLAY_DEFAULT_MESSAGE = 0,
|
DISPLAY_DEFAULT_MESSAGE = 0,
|
||||||
DISPLAY_TEMPERATURE,
|
DISPLAY_TEMPERATURE,
|
||||||
DISPLAY_PARKING_SPOTS
|
DISPLAY_PARKING_SPOTS,
|
||||||
|
CONFIGURATION_SCREEN
|
||||||
};
|
};
|
||||||
|
|
||||||
class LCDScreen {
|
class LCDScreen {
|
||||||
|
|
||||||
private:
|
private:
|
||||||
LiquidCrystal_I2C lcd = LiquidCrystal_I2C(0x27,20,4);
|
LiquidCrystal_I2C lcd = LiquidCrystal_I2C(0x27,20,4);
|
||||||
LCDScreenState current_state;
|
LCDScreenState current_state = 0;
|
||||||
String default_message = "Bem vindo!";
|
String default_message = "Bem vindo!";
|
||||||
|
|
||||||
public:
|
public:
|
||||||
@ -64,6 +65,23 @@ class LCDScreen {
|
|||||||
lcd.print(free_spots);
|
lcd.print(free_spots);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void display_configuration_screen(int total_spots){
|
||||||
|
if (this->current_state != CONFIGURATION_SCREEN){
|
||||||
|
this->current_state = CONFIGURATION_SCREEN;
|
||||||
|
this->clear();
|
||||||
|
lcd.setCursor(0, 0);
|
||||||
|
lcd.print("Conf. Mode");
|
||||||
|
}
|
||||||
|
lcd.setCursor(0, 1);
|
||||||
|
lcd.print("Total Spots = ");
|
||||||
|
if (total_spots < 10){
|
||||||
|
lcd.print("0");
|
||||||
|
lcd.print(total_spots);
|
||||||
|
}else {
|
||||||
|
lcd.print(total_spots);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
LCDScreenState get_next_state(){
|
LCDScreenState get_next_state(){
|
||||||
if (this->current_state == 2){
|
if (this->current_state == 2){
|
||||||
return this->ordered_states[0];
|
return this->ordered_states[0];
|
||||||
|
|||||||
@ -9,6 +9,7 @@
|
|||||||
#include "CarSpotController.cpp";
|
#include "CarSpotController.cpp";
|
||||||
#include "JoyStickController.cpp";
|
#include "JoyStickController.cpp";
|
||||||
#include "ButtonController.cpp";
|
#include "ButtonController.cpp";
|
||||||
|
#include "EncoderController.cpp";
|
||||||
|
|
||||||
#define ULTRASONIC_SENSOR_PIN_TRIG 11
|
#define ULTRASONIC_SENSOR_PIN_TRIG 11
|
||||||
#define ULTRASONIC_SENSOR_PIN_ECHO 12
|
#define ULTRASONIC_SENSOR_PIN_ECHO 12
|
||||||
@ -22,10 +23,18 @@
|
|||||||
#define STEPPER_B_PLUS_PIN 5
|
#define STEPPER_B_PLUS_PIN 5
|
||||||
#define STEPPER_A_PLUS_PIN 4
|
#define STEPPER_A_PLUS_PIN 4
|
||||||
#define STEPPER_A_MINUS_PIN 2
|
#define STEPPER_A_MINUS_PIN 2
|
||||||
|
#define ENCODER_CLK_PIN 7
|
||||||
|
#define ENCODER_DT_PIN A2
|
||||||
|
#define ENCODER_SW_PIN A3
|
||||||
|
|
||||||
#define PARK_SLOTS 3
|
#define PARK_SLOTS 3
|
||||||
#define STEP_MOTOR_STEPS 200
|
#define STEP_MOTOR_STEPS 200
|
||||||
|
|
||||||
|
enum ProgramState {
|
||||||
|
CONFIG_MODE,
|
||||||
|
APP_MODE
|
||||||
|
};
|
||||||
|
|
||||||
OneWire oneWire(TEMP_SENSOR_PIN);
|
OneWire oneWire(TEMP_SENSOR_PIN);
|
||||||
DallasTemperature temperature_sensors(&oneWire);
|
DallasTemperature temperature_sensors(&oneWire);
|
||||||
|
|
||||||
@ -36,29 +45,69 @@ CarSpotController car_spot_controller = CarSpotController(PARK_SLOTS);
|
|||||||
JoystickController joystick = JoystickController(JOYSTICK_X_PIN, JOYSTICK_Y_PIN);
|
JoystickController joystick = JoystickController(JOYSTICK_X_PIN, JOYSTICK_Y_PIN);
|
||||||
ButtonController button = ButtonController(BUTTON_PIN);
|
ButtonController button = ButtonController(BUTTON_PIN);
|
||||||
Stepper stepper(STEP_MOTOR_STEPS, STEPPER_B_MINUS_PIN, STEPPER_B_PLUS_PIN, STEPPER_A_PLUS_PIN, STEPPER_A_MINUS_PIN);
|
Stepper stepper(STEP_MOTOR_STEPS, STEPPER_B_MINUS_PIN, STEPPER_B_PLUS_PIN, STEPPER_A_PLUS_PIN, STEPPER_A_MINUS_PIN);
|
||||||
|
EncoderController encoder = EncoderController(ENCODER_DT_PIN, ENCODER_CLK_PIN,ENCODER_SW_PIN);
|
||||||
|
|
||||||
unsigned long current_time, sensor_last_time_readed, barrier_last_time_opened, temperature_last_time_measured, joystick_last_time_activated, joystick_last_time_readed, screen_last_time_updated;
|
unsigned long current_time, sensor_last_time_readed, barrier_last_time_opened, temperature_last_time_measured, joystick_last_time_activated, joystick_last_time_readed, screen_last_time_updated, encoder_last_time_readed;
|
||||||
|
|
||||||
float temperature_in_c = 0;
|
float temperature_in_c = 0;
|
||||||
|
|
||||||
|
ProgramState program_state = CONFIG_MODE;
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin(9600);
|
Serial.begin(115200);
|
||||||
dist_sensor.configure_pins();
|
dist_sensor.configure_pins();
|
||||||
barrier.configure_pins();
|
barrier.configure_pins();
|
||||||
temperature_sensors.begin();
|
temperature_sensors.begin();
|
||||||
joystick.configure_pins();
|
joystick.configure_pins();
|
||||||
button.configure_pins();
|
button.configure_pins();
|
||||||
stepper.setSpeed(60);
|
stepper.setSpeed(60);
|
||||||
|
encoder.configure_pins();
|
||||||
screen.init();
|
screen.init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
|
|
||||||
current_time = millis();
|
current_time = millis();
|
||||||
|
|
||||||
|
switch (program_state){
|
||||||
|
case CONFIG_MODE:
|
||||||
|
run_config_mode();
|
||||||
|
break;
|
||||||
|
case APP_MODE:
|
||||||
|
run_program();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void run_config_mode (){
|
||||||
|
static bool is_first_time = true;
|
||||||
|
if (is_first_time){
|
||||||
|
screen.display_configuration_screen(car_spot_controller.get_total_spots());
|
||||||
|
is_first_time = false;
|
||||||
|
}
|
||||||
|
encoder.read();
|
||||||
|
if (encoder.rotated_clockwise()){
|
||||||
|
if (car_spot_controller.get_total_spots() < 15){
|
||||||
|
car_spot_controller.increment_total_spots();
|
||||||
|
screen.display_configuration_screen(car_spot_controller.get_total_spots());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (encoder.rotated_counterclockwise()){
|
||||||
|
if (car_spot_controller.get_total_spots() > 1 && car_spot_controller.get_occupied_spots() < car_spot_controller.get_total_spots()){
|
||||||
|
car_spot_controller.decrement_total_spots();
|
||||||
|
screen.display_configuration_screen(car_spot_controller.get_total_spots());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (encoder.button_pressed()){
|
||||||
|
program_state = APP_MODE;
|
||||||
|
screen.set_state(0);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void run_program(){
|
||||||
|
|
||||||
button.read();
|
button.read();
|
||||||
|
|
||||||
if (button.is_pressed()){
|
if (button.is_pressed()){
|
||||||
barrier_last_time_opened = current_time;
|
barrier_last_time_opened = current_time;
|
||||||
if (!car_spot_controller.is_empty() && barrier.is_closed()){
|
if (!car_spot_controller.is_empty() && barrier.is_closed()){
|
||||||
@ -88,7 +137,6 @@ void loop() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (current_time - temperature_last_time_measured >= 1000){
|
if (current_time - temperature_last_time_measured >= 1000){
|
||||||
temperature_last_time_measured = current_time;
|
temperature_last_time_measured = current_time;
|
||||||
temperature_sensors.setWaitForConversion(false);
|
temperature_sensors.setWaitForConversion(false);
|
||||||
@ -96,7 +144,6 @@ void loop() {
|
|||||||
temperature_in_c = temperature_sensors.getTempCByIndex(0);
|
temperature_in_c = temperature_sensors.getTempCByIndex(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (joystick.is_moving_right() && current_time - joystick_last_time_activated >= 450){
|
if (joystick.is_moving_right() && current_time - joystick_last_time_activated >= 450){
|
||||||
joystick_last_time_activated = current_time;
|
joystick_last_time_activated = current_time;
|
||||||
screen.set_state((screen.get_next_state()));
|
screen.set_state((screen.get_next_state()));
|
||||||
@ -106,10 +153,15 @@ void loop() {
|
|||||||
screen.set_state(screen.get_previous_state());
|
screen.set_state(screen.get_previous_state());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (current_time - screen_last_time_updated >= 500){
|
if (current_time - screen_last_time_updated >= 500){
|
||||||
screen_last_time_updated = current_time;
|
screen_last_time_updated = current_time;
|
||||||
screen.display(temperature_in_c,car_spot_controller.get_total_spots(), car_spot_controller.get_occupied_spots());
|
screen.display(temperature_in_c,car_spot_controller.get_total_spots(), car_spot_controller.get_occupied_spots());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
encoder.read();
|
||||||
|
if (encoder.button_pressed()){
|
||||||
|
program_state = CONFIG_MODE;
|
||||||
|
screen.display_configuration_screen(car_spot_controller.get_total_spots());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
Loading…
x
Reference in New Issue
Block a user