Infrared remote library for Arduino: send and receive infrared signals with multiple protocols Port from Arduino-IRremote https://github.com/z3t0/Arduino-IRremote

Dependents:   mbed-os-example-FinalReal mbed-os-example-FinalReal

Committer:
eunmango
Date:
Sun Jun 16 04:36:58 2019 +0000
Revision:
8:0650578366fd
Parent:
0:70c8e56bac45
dd

Who changed what in which revision?

UserRevisionLine numberNew contents of line
yuhki50 0:70c8e56bac45 1 #include "IRremote.h"
yuhki50 0:70c8e56bac45 2 #include "IRremoteInt.h"
yuhki50 0:70c8e56bac45 3
yuhki50 0:70c8e56bac45 4 //==============================================================================
yuhki50 0:70c8e56bac45 5 // N N EEEEE CCCC
yuhki50 0:70c8e56bac45 6 // NN N E C
yuhki50 0:70c8e56bac45 7 // N N N EEE C
yuhki50 0:70c8e56bac45 8 // N NN E C
yuhki50 0:70c8e56bac45 9 // N N EEEEE CCCC
yuhki50 0:70c8e56bac45 10 //==============================================================================
yuhki50 0:70c8e56bac45 11
yuhki50 0:70c8e56bac45 12 #define NEC_BITS 32
yuhki50 0:70c8e56bac45 13 #define NEC_HDR_MARK 9000
yuhki50 0:70c8e56bac45 14 #define NEC_HDR_SPACE 4500
yuhki50 0:70c8e56bac45 15 #define NEC_BIT_MARK 560
yuhki50 0:70c8e56bac45 16 #define NEC_ONE_SPACE 1690
yuhki50 0:70c8e56bac45 17 #define NEC_ZERO_SPACE 560
yuhki50 0:70c8e56bac45 18 #define NEC_RPT_SPACE 2250
yuhki50 0:70c8e56bac45 19
yuhki50 0:70c8e56bac45 20 //+=============================================================================
yuhki50 0:70c8e56bac45 21 #if SEND_NEC
yuhki50 0:70c8e56bac45 22 void IRsend::sendNEC (unsigned long data, int nbits)
yuhki50 0:70c8e56bac45 23 {
eunmango 8:0650578366fd 24 // Set IR carrier frequency
eunmango 8:0650578366fd 25 enableIROut(38);
yuhki50 0:70c8e56bac45 26
eunmango 8:0650578366fd 27 // Header
eunmango 8:0650578366fd 28 mark(NEC_HDR_MARK);
eunmango 8:0650578366fd 29 space(NEC_HDR_SPACE);
yuhki50 0:70c8e56bac45 30
eunmango 8:0650578366fd 31 // Data
eunmango 8:0650578366fd 32 for (unsigned long mask = 1UL << (nbits - 1); mask; mask >>= 1) {
eunmango 8:0650578366fd 33 if (data & mask) {
eunmango 8:0650578366fd 34 mark(NEC_BIT_MARK);
eunmango 8:0650578366fd 35 space(NEC_ONE_SPACE);
eunmango 8:0650578366fd 36 } else {
eunmango 8:0650578366fd 37 mark(NEC_BIT_MARK);
eunmango 8:0650578366fd 38 space(NEC_ZERO_SPACE);
eunmango 8:0650578366fd 39 }
eunmango 8:0650578366fd 40 }
yuhki50 0:70c8e56bac45 41
eunmango 8:0650578366fd 42 // Footer
eunmango 8:0650578366fd 43 mark(NEC_BIT_MARK);
eunmango 8:0650578366fd 44 space(0); // Always end with the LED off
yuhki50 0:70c8e56bac45 45 }
yuhki50 0:70c8e56bac45 46 #endif
yuhki50 0:70c8e56bac45 47
yuhki50 0:70c8e56bac45 48 //+=============================================================================
yuhki50 0:70c8e56bac45 49 // NECs have a repeat only 4 items long
yuhki50 0:70c8e56bac45 50 //
yuhki50 0:70c8e56bac45 51 #if DECODE_NEC
yuhki50 0:70c8e56bac45 52 bool IRrecv::decodeNEC (decode_results *results)
yuhki50 0:70c8e56bac45 53 {
eunmango 8:0650578366fd 54 long data = 0; // We decode in to here; Start with nothing
eunmango 8:0650578366fd 55 int offset = 1; // Index in to results; Skip first entry!?
yuhki50 0:70c8e56bac45 56
eunmango 8:0650578366fd 57 // Check header "mark"
eunmango 8:0650578366fd 58 if (!MATCH_MARK(results->rawbuf[offset], NEC_HDR_MARK)) return false ;
eunmango 8:0650578366fd 59 offset++;
yuhki50 0:70c8e56bac45 60
eunmango 8:0650578366fd 61 // Check for repeat
eunmango 8:0650578366fd 62 /*if ( (irparams.rawlen == 4)
eunmango 8:0650578366fd 63 && MATCH_SPACE(results->rawbuf[offset ], NEC_RPT_SPACE)
eunmango 8:0650578366fd 64 && MATCH_MARK (results->rawbuf[offset+1], NEC_BIT_MARK )
eunmango 8:0650578366fd 65 ) {
eunmango 8:0650578366fd 66 results->bits = 0;
eunmango 8:0650578366fd 67 results->value = REPEAT;
eunmango 8:0650578366fd 68 results->decode_type = NEC;
eunmango 8:0650578366fd 69 return true;
eunmango 8:0650578366fd 70 }
eunmango 8:0650578366fd 71 */
yuhki50 0:70c8e56bac45 72
eunmango 8:0650578366fd 73 // Check we have enough data
eunmango 8:0650578366fd 74 if (irparams.rawlen < (2 * NEC_BITS) + 4) return false ;
eunmango 8:0650578366fd 75
eunmango 8:0650578366fd 76 // Check header "space"
eunmango 8:0650578366fd 77 if (!MATCH_SPACE(results->rawbuf[offset], NEC_HDR_SPACE)) return false ;
eunmango 8:0650578366fd 78 offset++;
yuhki50 0:70c8e56bac45 79
eunmango 8:0650578366fd 80 int forInverse[32] = {0};
eunmango 8:0650578366fd 81 int j = 31;
eunmango 8:0650578366fd 82 // Build the data
eunmango 8:0650578366fd 83 for (int i = 0; i < NEC_BITS; i++) {
eunmango 8:0650578366fd 84 // Check data "mark"
eunmango 8:0650578366fd 85 if (!MATCH_MARK(results->rawbuf[offset], NEC_BIT_MARK)) return false ;
eunmango 8:0650578366fd 86 offset++;
yuhki50 0:70c8e56bac45 87 // Suppend this bit
eunmango 8:0650578366fd 88 if (MATCH_SPACE(results->rawbuf[offset], NEC_ONE_SPACE ))
eunmango 8:0650578366fd 89 forInverse[i] = 1;
eunmango 8:0650578366fd 90 else if (MATCH_SPACE(results->rawbuf[offset], NEC_ZERO_SPACE))
eunmango 8:0650578366fd 91 forInverse[i] = 0;
eunmango 8:0650578366fd 92 else return false ;
eunmango 8:0650578366fd 93 offset++;
eunmango 8:0650578366fd 94
eunmango 8:0650578366fd 95 }
eunmango 8:0650578366fd 96
yuhki50 0:70c8e56bac45 97
eunmango 8:0650578366fd 98 for(int j = 0; j < 8; j++){ //
eunmango 8:0650578366fd 99 data = (data << 1) | forInverse[j];
eunmango 8:0650578366fd 100 }
eunmango 8:0650578366fd 101 for(int j = 8; j < 16; j++){ //
eunmango 8:0650578366fd 102 data = (data << 1) | forInverse[j];
eunmango 8:0650578366fd 103 }
eunmango 8:0650578366fd 104 for(int j = 23; j > 15; j--){ //
eunmango 8:0650578366fd 105 data = (data << 1) | forInverse[j];
eunmango 8:0650578366fd 106 }
eunmango 8:0650578366fd 107 for(int j = 31; j > 23; j--){ //
eunmango 8:0650578366fd 108 data = (data << 1) | forInverse[j];
eunmango 8:0650578366fd 109 }
yuhki50 0:70c8e56bac45 110
eunmango 8:0650578366fd 111
eunmango 8:0650578366fd 112
eunmango 8:0650578366fd 113
eunmango 8:0650578366fd 114 // Success
eunmango 8:0650578366fd 115 results->bits = NEC_BITS;
eunmango 8:0650578366fd 116 results->value = data;
eunmango 8:0650578366fd 117 results->decode_type = NEC;
eunmango 8:0650578366fd 118
eunmango 8:0650578366fd 119 return true;
yuhki50 0:70c8e56bac45 120 }
eunmango 8:0650578366fd 121 #endif