Class IRDevice
IRDevice Class
Description
A class used for managing, sending, and receiving data using IR (Infra-Red).
Syntax
class IRDevice
Members
Public Constructors |
|
---|---|
A public constructor should not be used as this class is intended to be a singleton class. Access member functions using the object instance named IR. |
|
Public Methods |
|
IRDevice::getFreq |
Get the current IR modulation frequency |
IRDevice::begin |
Allocate resources and start the IR device with a custom frequency |
IRDevice::end |
Stop the IR device operations and free up resources |
IRDevice::send |
Send IR raw data |
IRDevice::beginNEC |
Allocate resources and start the IR device with a frequency suitable for the NEC protocol |
IRDevice::sendNEC |
Send data using the NEC protocol |
IRDevice::recvNEC |
Receive data using the NEC protocol |
IRDevice::getFreq
Description
Get the current IR modulation frequency.
Syntax
uint32_t getFreq(void);
Parameters
NA
Returns
This function returns the IR modulation frequency (in Hz) set currently.
Example Code
NA
Note
“IRDevice.h” must be included to use the class function.
IRDevice::begin
Description
Select IR mode as transmitting or receiving mode on IR transmitting or receiving pin. Allocate resources and start the IR device with a custom frequency.
Syntax
void begin(uint8_t irPin, uint32_t irMode, uint32_t freq);
void begin(uint8_t receivePin, uint8_t transmitPin, uint32_t irMode, uint32_t freq);
Parameters
irPin
: define pin for IR receiver and transmitter if irMode == IR_MODE_TX or IR_MODE_RX.
receivePin
: Hardware IR receiving pin that connected with the IR Receiver.
transmitPin
: Hardware IR transmitting pin that connected with the IR Transmistter.
irMode
: set IR transmit or receive mode. (Valid values: IR_MODE_TX and IR_MODE_RX)
freq
: modulation frequency for IR signal (in Hz).
Returns
NA
Example Code
NA
Note
IR device can only operate in either transmit or receive mode. “IRDevice.h” must be included to use the class function.
IRDevice::end
Description
Stop the IR device operations and free up resources allocated to the IR transmitting and receiving pins.
Syntax
void end(void);
Parameters
NA
Returns
NA
Example Code
Example: IRSendRaw
Note
“IRDevice.h” must be included to use the class function.
IRDevice::send
Description
Send data by entering customized IR raw data and data length in IR transmission buffer.
Syntax
void send(const unsigned int buf[ ] , uint16_t len);
Parameters
buf[ ]
: IR raw signals (in us) in an array form.
len
: total length of the IR raw signal array.
Returns
NA
Example Code
Example: IRSendRaw
Note
“IRDevice.h” must be included to use the class function. IR Raw Data array contains information in the form of consecutive microseconds (us). For more details, please refer to: http://www.righto.com/2009/08/multi-protocol-infrared-remote-library.html.
IRDevice::beginNEC
Description
Allocate resources and start the IR device with a frequency suitable for the NEC protocol.
Syntax
void beginNEC(uint8_t receivePin, uint8_t transmitPin, uint32_t irMode);
Parameters
receivePin
: Hardware IR receiving pin that connected with the IR Receiver.
transmitPin
: Hardware IR transmitting pin that connected with the IR Transmistter.
irMode
: transmit or receive mode. (Valid values: IR_MODE_TX and IR_MODE_RX).
Returns
NA
Example Code
Example: IRRecvNEC
Note
“IRDevice.h” must be included to use the class function. IR device can only operate in either transmit or receive mode. Refer to https://techdocs.altium.com/display/FPGA/NEC+Infrared+Transmission+Protocol for the NEC protocol.
IRDevice::sendNEC
Description
Send data using the NEC protocol.
Syntax
void sendNEC(uint8_t adr, uint8_t cmd);
Parameters
adr
: 8-bit NEC address data to be transmit
cmd
: 8-bit NEC command data to be transmit
Returns
NA
Example Code
Example: IRSendNEC
Note
IR device can only operate in either transmit or receive mode. Refer to https://techdocs.altium.com/display/FPGA/NEC+Infrared+Transmission+Protocol for the NEC protocol. “IRDevice.h” must be included to use the class function.
IRDevice::recvNEC
Description
Receive data using the NEC protocol.
Syntax
void recvNEC(uint8_t& adr, uint8_t& cmd uint32_t timeout);
Parameters
adr
: 8-bit NEC address data to be transmit
cmd
: 8-bit NEC command data to be transmit
timeout
: time duration (in ms) to wait for an incoming transmission
Returns
This function returns “1” if data has been received or returns “0” if no data has been received within the timeout period.
Example Code
Example: IRRecvNEC
Note
“IRDevice.h” must be included to use the class function. IR device can only operate in either transmit or receive mode. Refer to https://techdocs.altium.com/display/FPGA/NEC+Infrared+Transmission+Protocol for the NEC protocol.