Update code to use internal pull-ups + afsk

Adds afsk control via SoftModem
Switches microswitch endstop to use INPUT_PULLUP instead of circutry.
This commit is contained in:
Matt 2015-04-28 08:18:31 -04:00
parent 5cf3001b2a
commit f6dd6bf01f
1 changed files with 54 additions and 25 deletions

View File

@ -1,12 +1,14 @@
//Intval for pro trinket arduinos
//Using 12vdc motors in place of a stepper
//HBridge for motor control
//Microswitch for control
#include <SoftModem.h>
#include <ctype.h>
/*
----------------------------------------------------
Microswitch (use INPUT_PULLUP!!)
GND-----\ | \-----PIN
----------------------------------------------------
*/
@ -16,31 +18,36 @@ SoftModem modem;
/* ------------------------------------------------
* cmd
* ------------------------------------------------*/
volatile int c = 0;
volatile int cmd_fsk = 0;
volatile char cmd_fsk_char = 'x';
volatile int cmd_input = 0;
const int CMD_FORWARD = 102; //f
const char CMD_FWD_FSK = 'f';
const int CMD_BACKWARD = 98; //b
const char CMD_BKW_FSK = 'b';
const int CMD_BLACK = 110; //n
/* ------------------------------------------------
* pins
* ------------------------------------------------*/
const int PIN_INDICATOR = 13;
const int PIN_MOTOR_FORWARD = 5;
const int PIN_MOTOR_BACKWARD = 6;
const int PIN_MICRO = 2;
const int PIN_MOTOR_FORWARD = 10;
const int PIN_MOTOR_BACKWARD = 11;
const int PIN_MICRO = 8;
/* ------------------------------------------------
* loop
* ------------------------------------------------*/
const int LOOP_DELAY = 100;
const int LOOP_DELAY = 10;
/* ------------------------------------------------
* speed
* ------------------------------------------------*/
const int FWD_SPEED = 240;
const int BWD_SPEED = 240;
const int FWD_SPEED = 255;
const int BWD_SPEED = 255;
volatile boolean running = false;
volatile boolean cam_dir = true;
@ -49,6 +56,7 @@ volatile int micro_position = 0;
volatile boolean micro_primed = false;
unsigned long timer = 0;
volatile int timer_int = 0;
volatile int cam_count = 0;
volatile int cam_pos = 0;
@ -56,57 +64,78 @@ volatile int cam_pos = 0;
void setup () {
Serial.begin(9600);
Serial.flush();
modem.begin();
Pins_init();
Serial.println("Welcome to intval2.");
}
void loop () {
while (modem.available() > 0 && !running) {
c = modem.read();
Serial.println(c);
cmd_fsk = modem.read();
if (isprint(cmd_fsk)){
cmd_fsk_char = (char)cmd_fsk;
}
//Serial.println(cmd_fsk_char);
}
if (Serial.available() > 0 && !running){
cmd_input = Serial.read();
//Serial.println(cmd_input);
}
if (cmd_input == 102) {
if ((cmd_input == CMD_FORWARD
|| cmd_fsk_char == CMD_FWD_FSK)
&& !running) {
Frame(true);
}
if (running) {
Frame_check();
} else {
delay(LOOP_DELAY);
if ((cmd_input == CMD_BACKWARD
|| cmd_fsk_char == CMD_BKW_FSK)
&& !running) {
Frame(false);
}
if (cmd_input != 0
|| cmd_fsk_char != 'x') {
cmd_input = 0;
cmd_fsk = 0;
cmd_fsk_char = 'x';
}
if (running) {
Read_micro();
} else {
delay(LOOP_DELAY);
}
cmd_input = 0;
}
void Pins_init () {
pinMode(PIN_MOTOR_FORWARD, OUTPUT);
pinMode(PIN_MOTOR_BACKWARD, OUTPUT);
pinMode(PIN_MICRO, INPUT);
pinMode(PIN_MICRO, INPUT_PULLUP);
pinMode(PIN_INDICATOR, OUTPUT);
}
void Frame (boolean dir) {
//Serial.println("Starting Frame()...");
Time_start();
cam_dir = dir;
if (cam_dir) {
// Serial.println("Forward");
analogWrite(PIN_MOTOR_FORWARD, FWD_SPEED);
analogWrite(PIN_MOTOR_BACKWARD, 0);
} else {
//Serial.println("Backwards");
analogWrite(PIN_MOTOR_BACKWARD, BWD_SPEED);
analogWrite(PIN_MOTOR_FORWARD, 0);
}
Indicator(true);
running = true;
micro_primed = false;
cmd_input = 0;
}
void Frame_check () {
void Read_micro () {
micro_position = digitalRead(PIN_MICRO);
//Serial.println(micro_position);
if (micro_position == LOW && micro_primed == false) {
micro_primed = true;
Serial.println("Frame micro_primed");
//Serial.println("Frame micro_primed");
} else if (micro_position == HIGH && micro_primed == true) {
Stop();
}
@ -117,7 +146,7 @@ void Stop () {
analogWrite(PIN_MOTOR_FORWARD, 0);
analogWrite(PIN_MOTOR_BACKWARD, 0);
Serial.println("Frame ran");
//Serial.println("Frame ran");
Time_end();
cam_count++;
@ -138,9 +167,9 @@ void Time_start () {
void Time_end () {
timer = millis() - timer;
int timer_int = int(timer);
Serial.print(timer_int);
Serial.println("ms");
timer_int = int(timer);
//Serial.print(timer_int);
//Serial.println("ms");
}
void Indicator (boolean state) {