mcopy/ino/mcopy_cam_canon_ble/mcopy_cam_canon_ble.ino

152 lines
2.7 KiB
Arduino
Raw Normal View History

2023-02-28 04:16:44 +00:00
/**
*
* Camera Remote Menu
*
*
*
*
*
* Camera Settings
*
*
*
*
*
**/
#include "CanonBLERemote.h"
#include <Arduino.h>
2023-03-05 00:04:55 +00:00
#include "McopySerial.h"
#define LOG_LOCAL_LEVEL ESP_LOG_INFO
#include "esp_log.h"
#include <esp32-hal-log.h>
2023-03-03 15:13:40 +00:00
#define SHUTTTER_BTN 12
#define RELAY_PIN 14
2023-03-26 20:06:08 +00:00
#define RED_LED 23
#define GREEN_LED 22
2023-03-03 15:13:40 +00:00
const String name_remote = "mcopy";
CanonBLERemote canon_ble(name_remote);
2023-03-26 20:06:08 +00:00
McopySerial mc;
2023-03-03 15:13:40 +00:00
volatile boolean connected = false;
volatile long now;
volatile long last = -1;
2023-04-12 18:52:05 +00:00
volatile long cameraFrame = 2000;
2023-03-03 15:13:40 +00:00
volatile char cmdChar = 'z';
void setup()
{
esp_log_level_set("*", ESP_LOG_INFO);
pins();
2023-03-26 20:06:08 +00:00
mc.begin(mc.CAMERA_IDENTIFIER);
canon_ble.init();
2023-03-26 20:06:08 +00:00
delay(1000);
2023-03-03 15:13:40 +00:00
}
void pins () {
pinMode(SHUTTTER_BTN, INPUT_PULLUP);
pinMode(RED_LED, OUTPUT);
pinMode(GREEN_LED, OUTPUT);
digitalWrite(RED_LED, LOW);
2023-04-12 18:52:05 +00:00
digitalWrite(GREEN_LED, LOW);
}
2023-03-03 15:13:40 +00:00
void connectBLE () {
2023-04-14 00:39:24 +00:00
digitalWrite(RED_LED, HIGH);
digitalWrite(GREEN_LED, LOW);
do {
2023-04-12 18:52:05 +00:00
mc.log("Pairing...");
}
while(!canon_ble.pair(10));
connected = true;
digitalWrite(RED_LED, LOW);
2023-03-26 20:06:08 +00:00
digitalWrite(GREEN_LED, HIGH);
delay(1000);
mc.log("Camera paired");
mc.log(canon_ble.getPairedAddressString());
}
void loop()
{
2023-03-03 15:13:40 +00:00
now = millis();
cmdChar = mc.loop();
cmd(cmdChar);
// Shutter
2023-03-03 15:13:40 +00:00
if (digitalRead(SHUTTTER_BTN) == LOW && last + 1000 < now){
2023-04-12 18:52:05 +00:00
camera();
}
if (connected && !canon_ble.isConnected()) {
connected = false;
}
2023-04-14 00:39:24 +00:00
if (!connected) {
connectBLE();
}
2023-03-03 15:13:40 +00:00
}
void cmd (char val) {
2023-04-14 00:39:24 +00:00
if (val == mc.CAMERA && connected) {
2023-04-12 18:52:05 +00:00
camera();
} else if (val == mc.CAMERA_FORWARD) {
camera_direction(true);
} else if (val == mc.CAMERA_BACKWARD) {
camera_direction(false);
} else if (val == mc.STATE) {
state();
}
}
2023-04-12 18:52:05 +00:00
void camera () {
long start = now;
long end;
digitalWrite(GREEN_LED, HIGH);
digitalWrite(RED_LED, HIGH);
mc.log("Shutter pressed");
2023-03-03 15:13:40 +00:00
if(!canon_ble.trigger()){
2023-04-12 18:52:05 +00:00
mc.log("camera() failed");
2023-03-03 15:13:40 +00:00
}
2023-04-12 18:52:05 +00:00
end = millis();
delay(cameraFrame - (end - start));
2023-03-26 20:06:08 +00:00
digitalWrite(GREEN_LED, HIGH);
digitalWrite(RED_LED, LOW);
2023-03-03 15:13:40 +00:00
last = millis();
mc.confirm(mc.CAMERA);
2023-04-12 18:52:05 +00:00
}
//null route direction
void camera_direction (boolean state) {
if (state) {
mc.confirm(mc.CAMERA_FORWARD);
mc.log("camera_direction(true)");
} else {
mc.confirm(mc.CAMERA_BACKWARD);
mc.log("camera_direction(false)");
}
}
void state () {
String stateString = String(mc.CAMERA_EXPOSURE);
stateString += String(cameraFrame);
stateString += String(mc.STATE);
mc.print(stateString);
}