add conf mode, with encoder to regulate parking spots
This commit is contained in:
parent
1518fbf51a
commit
5b2e505571
@ -4,14 +4,15 @@
|
||||
enum LCDScreenState {
|
||||
DISPLAY_DEFAULT_MESSAGE = 0,
|
||||
DISPLAY_TEMPERATURE,
|
||||
DISPLAY_PARKING_SPOTS
|
||||
DISPLAY_PARKING_SPOTS,
|
||||
CONFIGURATION_SCREEN
|
||||
};
|
||||
|
||||
class LCDScreen {
|
||||
|
||||
private:
|
||||
LiquidCrystal_I2C lcd = LiquidCrystal_I2C(0x27,20,4);
|
||||
LCDScreenState current_state;
|
||||
LCDScreenState current_state = 0;
|
||||
String default_message = "Bem vindo!";
|
||||
|
||||
public:
|
||||
@ -64,6 +65,23 @@ class LCDScreen {
|
||||
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(){
|
||||
if (this->current_state == 2){
|
||||
return this->ordered_states[0];
|
||||
|
||||
@ -9,6 +9,7 @@
|
||||
#include "CarSpotController.cpp";
|
||||
#include "JoyStickController.cpp";
|
||||
#include "ButtonController.cpp";
|
||||
#include "EncoderController.cpp";
|
||||
|
||||
#define ULTRASONIC_SENSOR_PIN_TRIG 11
|
||||
#define ULTRASONIC_SENSOR_PIN_ECHO 12
|
||||
@ -22,10 +23,18 @@
|
||||
#define STEPPER_B_PLUS_PIN 5
|
||||
#define STEPPER_A_PLUS_PIN 4
|
||||
#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 STEP_MOTOR_STEPS 200
|
||||
|
||||
enum ProgramState {
|
||||
CONFIG_MODE,
|
||||
APP_MODE
|
||||
};
|
||||
|
||||
OneWire oneWire(TEMP_SENSOR_PIN);
|
||||
DallasTemperature temperature_sensors(&oneWire);
|
||||
|
||||
@ -36,29 +45,69 @@ CarSpotController car_spot_controller = CarSpotController(PARK_SLOTS);
|
||||
JoystickController joystick = JoystickController(JOYSTICK_X_PIN, JOYSTICK_Y_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);
|
||||
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;
|
||||
|
||||
ProgramState program_state = CONFIG_MODE;
|
||||
|
||||
void setup() {
|
||||
Serial.begin(9600);
|
||||
Serial.begin(115200);
|
||||
dist_sensor.configure_pins();
|
||||
barrier.configure_pins();
|
||||
temperature_sensors.begin();
|
||||
joystick.configure_pins();
|
||||
button.configure_pins();
|
||||
stepper.setSpeed(60);
|
||||
encoder.configure_pins();
|
||||
screen.init();
|
||||
}
|
||||
|
||||
|
||||
void loop() {
|
||||
|
||||
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();
|
||||
|
||||
if (button.is_pressed()){
|
||||
barrier_last_time_opened = current_time;
|
||||
if (!car_spot_controller.is_empty() && barrier.is_closed()){
|
||||
@ -88,7 +137,6 @@ void loop() {
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
if (current_time - temperature_last_time_measured >= 1000){
|
||||
temperature_last_time_measured = current_time;
|
||||
temperature_sensors.setWaitForConversion(false);
|
||||
@ -96,7 +144,6 @@ void loop() {
|
||||
temperature_in_c = temperature_sensors.getTempCByIndex(0);
|
||||
}
|
||||
|
||||
|
||||
if (joystick.is_moving_right() && current_time - joystick_last_time_activated >= 450){
|
||||
joystick_last_time_activated = current_time;
|
||||
screen.set_state((screen.get_next_state()));
|
||||
@ -106,10 +153,15 @@ void loop() {
|
||||
screen.set_state(screen.get_previous_state());
|
||||
}
|
||||
|
||||
|
||||
if (current_time - screen_last_time_updated >= 500){
|
||||
screen_last_time_updated = current_time;
|
||||
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