Rewrite arri_s_firmware to use McopySerial
This commit is contained in:
parent
ef54e61494
commit
ca22a3ba4b
|
@ -1,6 +1,6 @@
|
||||||
#include <Adafruit_MotorShield.h>
|
#include <Adafruit_MotorShield.h>
|
||||||
|
#include "McopySerial.h"
|
||||||
|
|
||||||
volatile boolean debug_state = true;
|
|
||||||
volatile boolean cam_dir = true;
|
volatile boolean cam_dir = true;
|
||||||
volatile boolean running = true;
|
volatile boolean running = true;
|
||||||
|
|
||||||
|
@ -9,90 +9,56 @@ const int fullRotation = 3 * stepsPerRevolution;
|
||||||
const int openRotationForward = 300;
|
const int openRotationForward = 300;
|
||||||
const int openRotationBackward = 300;
|
const int openRotationBackward = 300;
|
||||||
|
|
||||||
//CAMERA COMMANDS
|
volatile char cmdChar = 'z';
|
||||||
const char cmd_camera = 'c';
|
volatile long now;
|
||||||
const char cmd_cam_forward = 'e';
|
volatile long cameraFrame = -1;
|
||||||
const char cmd_cam_backward = 'f';
|
|
||||||
|
|
||||||
const char cmd_debug = 'd';
|
|
||||||
const char cmd_connect = 'i';
|
|
||||||
volatile char cmd_char = 'z';
|
|
||||||
const char cmd_mcopy_identifier = 'm';
|
|
||||||
const char cmd_cam_identifier = 'k';
|
|
||||||
|
|
||||||
const int serialDelay = 5;
|
|
||||||
|
|
||||||
Adafruit_MotorShield AFMS = Adafruit_MotorShield();
|
Adafruit_MotorShield AFMS = Adafruit_MotorShield();
|
||||||
//Set up for a 200step motor (NEMA 17)
|
//Set up for a 200step motor (NEMA 17)
|
||||||
Adafruit_StepperMotor *stepper = AFMS.getStepper(stepsPerRevolution, 2);
|
Adafruit_StepperMotor *stepper = AFMS.getStepper(stepsPerRevolution, 2);
|
||||||
|
|
||||||
|
McopySerial mc;
|
||||||
|
|
||||||
void setupMotor () {
|
void setupMotor () {
|
||||||
//TWBR = ((F_CPU /400000l) - 16) / 2; // Change the i2c clock to 400KHz
|
//TWBR = ((F_CPU /400000l) - 16) / 2; // Change the i2c clock to 400KHz
|
||||||
if (!AFMS.begin()) { // default frequency 1.6KHz
|
if (!AFMS.begin()) { // default frequency 1.6KHz
|
||||||
log("Could not find Motor Shield. Check wiring.");
|
mc.log("Could not find Motor Shield. Check wiring.");
|
||||||
while (1);
|
while (1);
|
||||||
}
|
}
|
||||||
|
|
||||||
log("Motor Shield found.");
|
mc.log("Motor Shield found.");
|
||||||
stepper->setSpeed(600);
|
stepper->setSpeed(600);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setup() {
|
void setup() {
|
||||||
Serial.begin(57600);
|
mc.begin(mc.CAMERA_IDENTIFIER);
|
||||||
setupMotor();
|
setupMotor();
|
||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
if (Serial.available()) {
|
now = millis();
|
||||||
// read the most recent byte
|
cmdChar = mc.loop();
|
||||||
cmd_char = (char)Serial.read();
|
cmd(cmdChar);
|
||||||
}
|
|
||||||
if (cmd_char != 'z') {
|
|
||||||
cmd(cmd_char);
|
|
||||||
cmd_char = 'z';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmd (char val) {
|
void cmd (char val) {
|
||||||
if (val == cmd_debug) {
|
if (val == mc.CAMERA_FORWARD) {
|
||||||
debug();
|
setDir(true);
|
||||||
} else if (val == cmd_connect) {
|
} else if (val == mc.CAMERA_BACKWARD) {
|
||||||
connect();
|
|
||||||
} else if (val == cmd_mcopy_identifier) {
|
|
||||||
identify();
|
|
||||||
} else if (val == cmd_cam_forward) {
|
|
||||||
setDir(true); //explicit
|
|
||||||
} else if (val == cmd_cam_backward) {
|
|
||||||
setDir(false);
|
setDir(false);
|
||||||
} else if (val == cmd_camera) {
|
} else if (val == mc.CAMERA) {
|
||||||
cam();
|
cam();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void debug () {
|
|
||||||
debug_state = true;
|
|
||||||
Serial.println(cmd_debug);
|
|
||||||
log("debugging enabled");
|
|
||||||
}
|
|
||||||
|
|
||||||
void connect () {
|
|
||||||
Serial.println(cmd_connect);
|
|
||||||
log("connect()");
|
|
||||||
}
|
|
||||||
|
|
||||||
void identify () {
|
|
||||||
Serial.println(cmd_cam_identifier);
|
|
||||||
log("identify()");
|
|
||||||
}
|
|
||||||
|
|
||||||
void setDir (boolean dir) {
|
void setDir (boolean dir) {
|
||||||
cam_dir = dir;
|
cam_dir = dir;
|
||||||
if (cam_dir) {
|
if (cam_dir) {
|
||||||
Serial.println(cmd_cam_forward);
|
mc.confirm(mc.CAMERA_FORWARD);
|
||||||
log("setDir = true");
|
mc.log("setDir = true");
|
||||||
} else {
|
} else {
|
||||||
Serial.println(cmd_cam_backward);
|
mc.confirm(mc.CAMERA_BACKWARD);
|
||||||
log("setDir -> false");
|
mc.log("setDir -> false");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -100,18 +66,23 @@ void cam () {
|
||||||
long startTime = millis();
|
long startTime = millis();
|
||||||
if (cam_dir) {
|
if (cam_dir) {
|
||||||
stepper->step(fullRotation, FORWARD, DOUBLE);
|
stepper->step(fullRotation, FORWARD, DOUBLE);
|
||||||
Serial.println(cmd_cam_forward);
|
mc.log("cam() -> forward");
|
||||||
log("cam -> forward");
|
|
||||||
} else {
|
} else {
|
||||||
stepper->step(fullRotation, BACKWARD, DOUBLE);
|
stepper->step(fullRotation, BACKWARD, DOUBLE);
|
||||||
Serial.println(cmd_cam_backward);
|
mc.log("cam() -> backward");
|
||||||
log("cam -> backward");
|
|
||||||
}
|
}
|
||||||
log(String(millis() - startTime));
|
mc.confirm(mc.CAMERA);
|
||||||
|
if (cameraFrame == -1) {
|
||||||
|
cameraFrame = millis() - startTime;
|
||||||
|
} else {
|
||||||
|
cameraFrame = round((cameraFrame + (millis() - startTime)) / 2);
|
||||||
|
}
|
||||||
|
mc.log(String(cameraFrame));
|
||||||
}
|
}
|
||||||
|
|
||||||
void log (String msg) {
|
void state () {
|
||||||
if (debug_state) {
|
String stateString = String(mc.CAMERA_EXPOSURE);
|
||||||
Serial.println(msg);
|
stateString += String(cameraFrame);
|
||||||
}
|
stateString += String(mc.STATE);
|
||||||
|
mc.print(stateString);
|
||||||
}
|
}
|
Loading…
Reference in New Issue