daily_automated

This commit is contained in:
topicchi
2023-03-17 11:59:21 +00:00
parent 252ecca9cf
commit e2f276193e
4496 changed files with 1178007 additions and 0 deletions

View File

@@ -0,0 +1,108 @@
#include "IRremote.h"
//==============================================================================
// PPPP AAA N N AAA SSSS OOO N N IIIII CCCC
// P P A A NN N A A S O O NN N I C
// PPPP AAAAA N N N AAAAA SSS O O N N N I C
// P A A N NN A A S O O N NN I C
// P A A N N A A SSSS OOO N N IIIII CCCC
//==============================================================================
#define PANASONIC_BITS 48
#define PANASONIC_ADDRESS_BITS 16
#define PANASONIC_DATA_BITS 32
#define PANASONIC_HEADER_MARK 3502
#define PANASONIC_HEADER_SPACE 1750
#define PANASONIC_BIT_MARK 502
#define PANASONIC_ONE_SPACE 1244
#define PANASONIC_ZERO_SPACE 400
//+=============================================================================
#if SEND_PANASONIC
void IRsend::sendPanasonic(unsigned int address, unsigned long data) {
// Set IR carrier frequency
enableIROut(37); // 36.7kHz is the correct frequency
// Header
mark(PANASONIC_HEADER_MARK);
space(PANASONIC_HEADER_SPACE);
// Address
sendPulseDistanceWidthData(PANASONIC_BIT_MARK, PANASONIC_ONE_SPACE, PANASONIC_BIT_MARK, PANASONIC_ZERO_SPACE, address,
PANASONIC_ADDRESS_BITS);
// for (unsigned long mask = 1UL << (16 - 1); mask; mask >>= 1) {
// mark(PANASONIC_BIT_MARK);
// if (address & mask)
// space(PANASONIC_ONE_SPACE);
// else
// space(PANASONIC_ZERO_SPACE);
// }
// Data
sendPulseDistanceWidthData(PANASONIC_BIT_MARK, PANASONIC_ONE_SPACE, PANASONIC_BIT_MARK,
PANASONIC_ZERO_SPACE, data, PANASONIC_DATA_BITS);
// for (unsigned long mask = 1UL << (32 - 1); mask; mask >>= 1) {
// mark(PANASONIC_BIT_MARK);
// if (data & mask)
// space(PANASONIC_ONE_SPACE);
// else
// space(PANASONIC_ZERO_SPACE);
// }
// Footer
mark(PANASONIC_BIT_MARK);
space(0); // Always end with the LED off
}
#endif
//+=============================================================================
#if DECODE_PANASONIC
bool IRrecv::decodePanasonic() {
unsigned long address = 0;
unsigned long data = 0;
int offset = 1;
if (!MATCH_MARK(results.rawbuf[offset], PANASONIC_HEADER_MARK)) {
return false;
}
offset++;
if (!MATCH_MARK(results.rawbuf[offset], PANASONIC_HEADER_SPACE)) {
return false;
}
offset++;
address = decodePulseDistanceData(PANASONIC_ADDRESS_BITS, offset, PANASONIC_BIT_MARK, PANASONIC_ONE_SPACE,
PANASONIC_ZERO_SPACE);
data = decodePulseDistanceData(PANASONIC_DATA_BITS, offset + PANASONIC_ADDRESS_BITS, PANASONIC_BIT_MARK,
PANASONIC_ONE_SPACE, PANASONIC_ZERO_SPACE);
// // decode address
// for (int i = 0; i < PANASONIC_BITS; i++) {
// if (!MATCH_MARK(results.rawbuf[offset], PANASONIC_BIT_MARK)) {
// return false;
// }
// offset++;
//
// if (MATCH_SPACE(results.rawbuf[offset], PANASONIC_ONE_SPACE)) {
// data = (data << 1) | 1;
// } else if (MATCH_SPACE(results.rawbuf[offset], PANASONIC_ZERO_SPACE)) {
// data = (data << 1) | 0;
// } else {
// return false;
// }
// offset++;
// }
results.value = data;
results.address = address;
results.decode_type = PANASONIC;
results.bits = PANASONIC_BITS;
return true;
}
bool IRrecv::decodePanasonic(decode_results *aResults) {
bool aReturnValue = decodePanasonic();
*aResults = results;
return aReturnValue;
}
#endif