mcopy/ino/mcopy_cam_canon/mcopy_cam_canon.ino

117 lines
1.9 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>
#include "TickTwo.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
#define LED 22
void blink();
2023-03-03 15:13:40 +00:00
volatile bool ledState;
2023-03-03 15:13:40 +00:00
const String name_remote = "mcopy";
CanonBLERemote canon_ble(name_remote);
TickTwo blinker(blink, 500);
McopySerial mc(McopySerial::CAMERA_IDENTIFIER);
2023-03-03 15:13:40 +00:00
volatile boolean connected = false;
volatile long now;
volatile long last = -1;
volatile byte cmd;
void blink(){
digitalWrite(LED, ledState);
ledState = !ledState;
}
void setup()
{
esp_log_level_set("*", ESP_LOG_INFO);
pinMode(SHUTTTER_BTN, INPUT_PULLUP);
pinMode(LED, OUTPUT);
mc.begin();
canon_ble.init();
delay(1000);
blinker.start();
2023-03-03 15:13:40 +00:00
}
2023-03-03 15:13:40 +00:00
void connectBLE () {
do {
Serial.println("Pairing...");
}
while(!canon_ble.pair(10));
connected = true;
blinker.pause();
blinker.interval(100);
digitalWrite(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();
cmd = mc.loop();
if (cmd == McopySerial::CAMERA && last + 1000 < now) {
2023-03-03 15:13:40 +00:00
shutter();
}
// Shutter
2023-03-03 15:13:40 +00:00
if (digitalRead(SHUTTTER_BTN) == LOW && last + 1000 < now){
shutter();
}
blinker.update();
if (connected && !canon_ble.isConnected()) {
connected = false;
//mc.log("Disconnected");
blinker.interval(500);
2023-03-03 15:13:40 +00:00
blinker.resume();
}
2023-03-03 15:13:40 +00:00
}
void shutter () {
digitalWrite(LED, LOW);
blinker.resume();
mc.log("Shutter pressed");
2023-03-03 15:13:40 +00:00
if(!canon_ble.trigger()){
mc.log("Trigger Failed");
2023-03-03 15:13:40 +00:00
}
blinker.pause();
digitalWrite(LED, HIGH);
last = millis();
}