Start work on secondary projector feature
This commit is contained in:
parent
48b86ebc93
commit
7398f7993d
|
@ -101,7 +101,8 @@
|
||||||
"light_identifier" : "o",
|
"light_identifier" : "o",
|
||||||
"proj_light_identifier" : "q",
|
"proj_light_identifier" : "q",
|
||||||
"proj_cam_light_identifier" : "r",
|
"proj_cam_light_identifier" : "r",
|
||||||
"proj_cam_identifier" : "s"
|
"proj_cam_identifier" : "s",
|
||||||
|
"proj_second_identifier" : "t"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -301,6 +301,8 @@ mcopy.arduino.distinguish = async function () {
|
||||||
type = 'projector,camera,light'
|
type = 'projector,camera,light'
|
||||||
} else if (data === mcopy.cfg.arduino.cmd.proj_cam_identifier) {
|
} else if (data === mcopy.cfg.arduino.cmd.proj_cam_identifier) {
|
||||||
type = 'projector,camera'
|
type = 'projector,camera'
|
||||||
|
} else if (data === mcopy.cfg.ardino.cmd.proj_second_identifier) {
|
||||||
|
type = 'projector_second'
|
||||||
}
|
}
|
||||||
return resolve(type)
|
return resolve(type)
|
||||||
}
|
}
|
||||||
|
|
12
app/main.js
12
app/main.js
|
@ -250,6 +250,15 @@ dev.connectDevice = async function (device, type) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
log.info(`Connected to ${device} as PROJECTOR`, 'SERIAL', true, true)
|
log.info(`Connected to ${device} as PROJECTOR`, 'SERIAL', true, true)
|
||||||
|
} else if (type === 'projector_second') {
|
||||||
|
dev.connected.projector_second = device
|
||||||
|
arduino.alias('projector_second', device)
|
||||||
|
try {
|
||||||
|
connectSuccess = await arduino.connect('projector_second', device, false)
|
||||||
|
} catch (err) {
|
||||||
|
console.error(err)
|
||||||
|
return false
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return connectSuccess
|
return connectSuccess
|
||||||
}
|
}
|
||||||
|
@ -266,7 +275,8 @@ dev.all = async function (devices) {
|
||||||
dev.connected = {
|
dev.connected = {
|
||||||
projector : false,
|
projector : false,
|
||||||
camera : false,
|
camera : false,
|
||||||
light : false
|
light : false,
|
||||||
|
projector_second : false
|
||||||
}
|
}
|
||||||
|
|
||||||
let checklist = []
|
let checklist = []
|
||||||
|
|
Binary file not shown.
|
@ -0,0 +1,120 @@
|
||||||
|
boolean debug_state = false;
|
||||||
|
|
||||||
|
//const int proj_pin = 5; //relay 4
|
||||||
|
//const int proj_time = {{proj.time}};
|
||||||
|
//const int proj_delay = {{proj.delay}};
|
||||||
|
|
||||||
|
boolean proj_dir = true;
|
||||||
|
|
||||||
|
const char cmd_projector = 'p';
|
||||||
|
const char cmd_proj_forward = 'g';
|
||||||
|
const char cmd_proj_backward = 'h';
|
||||||
|
|
||||||
|
const char cmd_debug = 'd';
|
||||||
|
const char cmd_connect = 'i';
|
||||||
|
volatile char cmd_char = 'z';
|
||||||
|
const char cmd_mcopy_identifier = 'm';
|
||||||
|
const char cmd_proj_identifier = 't'; //projector second
|
||||||
|
|
||||||
|
const int serialDelay = 5;
|
||||||
|
|
||||||
|
void setup() {
|
||||||
|
Serial.begin(57600);
|
||||||
|
Serial.flush();
|
||||||
|
Serial.setTimeout(serialDelay);
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
if (Serial.available()) {
|
||||||
|
/* read the most recent byte */
|
||||||
|
cmd_char = (char)Serial.read();
|
||||||
|
}
|
||||||
|
if (cmd_char != 'z') {
|
||||||
|
cmd(cmd_char);
|
||||||
|
cmd_char = 'z';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void cmd (char val) {
|
||||||
|
if (val == cmd_debug) {
|
||||||
|
debug();
|
||||||
|
} else if (val == cmd_connect) {
|
||||||
|
connect();
|
||||||
|
} else if (val == cmd_mcopy_identifier) {
|
||||||
|
identify();
|
||||||
|
} else if (val == cmd_projector) {
|
||||||
|
proj_start();
|
||||||
|
} else if (val == cmd_proj_forward) {
|
||||||
|
proj_direction(true);
|
||||||
|
} else if (val == cmd_proj_backward) {
|
||||||
|
proj_direction(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
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_proj_identifier);
|
||||||
|
log("identify()");
|
||||||
|
}
|
||||||
|
|
||||||
|
void proj_start () {
|
||||||
|
if (proj_dir) {
|
||||||
|
digitalWrite(proj_fwd_pin, HIGH);
|
||||||
|
digitalWrite(proj_bwd_pin, LOW);
|
||||||
|
} else {
|
||||||
|
digitalWrite(proj_bwd_pin, HIGH);
|
||||||
|
digitalWrite(proj_fwd_pin, LOW);
|
||||||
|
}
|
||||||
|
proj_running = true;
|
||||||
|
delay(500); // Let bump pass out of microswitch
|
||||||
|
|
||||||
|
//delay(1300); //TEMPORARY DELAY FOR TESTING TIMING
|
||||||
|
}
|
||||||
|
|
||||||
|
void proj_reading () {
|
||||||
|
proj_micro_raw = digitalRead(proj_micro_pin);
|
||||||
|
if (proj_micro_raw == 1) {
|
||||||
|
//do nothing
|
||||||
|
} else if (proj_micro_raw == 0) {
|
||||||
|
proj_stop();
|
||||||
|
}
|
||||||
|
//delay(1); //needed?
|
||||||
|
}
|
||||||
|
|
||||||
|
void proj_stop () {
|
||||||
|
digitalWrite(proj_bwd_pin, LOW);
|
||||||
|
digitalWrite(proj_fwd_pin, LOW);
|
||||||
|
|
||||||
|
proj_running = false;
|
||||||
|
|
||||||
|
Serial.println(cmd_projector);
|
||||||
|
log("projector()");
|
||||||
|
}
|
||||||
|
|
||||||
|
void proj_direction (boolean state) {
|
||||||
|
proj_dir = state;
|
||||||
|
if (state) {
|
||||||
|
Serial.println(cmd_proj_forward);
|
||||||
|
log("proj_direction -> true");
|
||||||
|
} else {
|
||||||
|
Serial.println(cmd_proj_backward);
|
||||||
|
log("proj_direction -> false");
|
||||||
|
}
|
||||||
|
//delay(50); //delay after direction change to account for slippage of the belt
|
||||||
|
}
|
||||||
|
|
||||||
|
void log (String msg) {
|
||||||
|
if (debug_state) {
|
||||||
|
Serial.println(msg);
|
||||||
|
}
|
||||||
|
}
|
|
@ -79,6 +79,13 @@ module female_jk103 () {
|
||||||
difference () {
|
difference () {
|
||||||
body();
|
body();
|
||||||
translate([0, 0, 25]) rotate([0, 180, 0]) jk_pins(0.5, 25);
|
translate([0, 0, 25]) rotate([0, 180, 0]) jk_pins(0.5, 25);
|
||||||
|
translate([0, 0, -3]) rotate([0, 0, 180]) male_jk103_neg();
|
||||||
|
//bolt
|
||||||
|
translate([15, 0, 5]) rotate([0,90,0]) cylinder(r = 1, h = 20, center = true, $fn = 40);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//rotate([180, 0, 0]) male_jk103();
|
||||||
|
//male_jk103_back();
|
||||||
|
female_jk103();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue