Added CHDK support
Added CHDK support to take pictures instead of doing an IR command, see more about how to use it here http://captain-slow.dk/2014/03/09/3d-printing-timelapses/
This commit is contained in:
parent
765b2da3d4
commit
09af1b90b8
1 changed files with 39 additions and 13 deletions
|
@ -314,6 +314,12 @@ bool Stopped=false;
|
||||||
bool CooldownNoWait = true;
|
bool CooldownNoWait = true;
|
||||||
bool target_direction;
|
bool target_direction;
|
||||||
|
|
||||||
|
//Insert variables if CHDK is defined
|
||||||
|
#ifdef CHDK
|
||||||
|
unsigned long chdkHigh = 0;
|
||||||
|
boolean chdkActive = false;
|
||||||
|
#endif
|
||||||
|
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
//=============================Routines======================================
|
//=============================Routines======================================
|
||||||
//===========================================================================
|
//===========================================================================
|
||||||
|
@ -2588,23 +2594,33 @@ void process_commands()
|
||||||
#endif //PIDTEMP
|
#endif //PIDTEMP
|
||||||
case 240: // M240 Triggers a camera by emulating a Canon RC-1 : http://www.doc-diy.net/photo/rc-1_hacked/
|
case 240: // M240 Triggers a camera by emulating a Canon RC-1 : http://www.doc-diy.net/photo/rc-1_hacked/
|
||||||
{
|
{
|
||||||
#if defined(PHOTOGRAPH_PIN) && PHOTOGRAPH_PIN > -1
|
#ifdef CHDK
|
||||||
const uint8_t NUM_PULSES=16;
|
|
||||||
const float PULSE_LENGTH=0.01524;
|
SET_OUTPUT(CHDK);
|
||||||
for(int i=0; i < NUM_PULSES; i++) {
|
WRITE(CHDK, HIGH);
|
||||||
WRITE(PHOTOGRAPH_PIN, HIGH);
|
chdkHigh = millis();
|
||||||
_delay_ms(PULSE_LENGTH);
|
chdkActive = true;
|
||||||
WRITE(PHOTOGRAPH_PIN, LOW);
|
|
||||||
_delay_ms(PULSE_LENGTH);
|
#else
|
||||||
|
|
||||||
|
#if defined(PHOTOGRAPH_PIN) && PHOTOGRAPH_PIN > -1
|
||||||
|
const uint8_t NUM_PULSES=16;
|
||||||
|
const float PULSE_LENGTH=0.01524;
|
||||||
|
for(int i=0; i < NUM_PULSES; i++) {
|
||||||
|
WRITE(PHOTOGRAPH_PIN, HIGH);
|
||||||
|
_delay_ms(PULSE_LENGTH);
|
||||||
|
WRITE(PHOTOGRAPH_PIN, LOW);
|
||||||
|
_delay_ms(PULSE_LENGTH);
|
||||||
}
|
}
|
||||||
delay(7.33);
|
delay(7.33);
|
||||||
for(int i=0; i < NUM_PULSES; i++) {
|
for(int i=0; i < NUM_PULSES; i++) {
|
||||||
WRITE(PHOTOGRAPH_PIN, HIGH);
|
WRITE(PHOTOGRAPH_PIN, HIGH);
|
||||||
_delay_ms(PULSE_LENGTH);
|
_delay_ms(PULSE_LENGTH);
|
||||||
WRITE(PHOTOGRAPH_PIN, LOW);
|
WRITE(PHOTOGRAPH_PIN, LOW);
|
||||||
_delay_ms(PULSE_LENGTH);
|
_delay_ms(PULSE_LENGTH);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
#endif //chdk end if
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
#ifdef DOGLCD
|
#ifdef DOGLCD
|
||||||
|
@ -3353,6 +3369,16 @@ void manage_inactivity()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef CHDK //Check if pin should be set to LOW after M240 set it to HIGH
|
||||||
|
if (chdkActive)
|
||||||
|
{
|
||||||
|
chdkActive = false;
|
||||||
|
if (millis()-chdkHigh < CHDK_DELAY) return;
|
||||||
|
WRITE(CHDK, LOW);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#if defined(KILL_PIN) && KILL_PIN > -1
|
#if defined(KILL_PIN) && KILL_PIN > -1
|
||||||
if( 0 == READ(KILL_PIN) )
|
if( 0 == READ(KILL_PIN) )
|
||||||
kill();
|
kill();
|
||||||
|
|
Loading…
Add table
Reference in a new issue