A library used for interacting with infrared remote controls via Go.
To install the library, issue the following command
go get github.com/smarthome-go/infrared
You can then import the library in your project using following code
import "github.com/smarthome-go/infrared"
Before codes can be scanned, create a new module struct:
ifScanner := infrared.Scanner{}
The ifScanner
struct now allows you to use the library
After you have created a new struct, run the Setup
function to tell the library on which pin in should listen to incoming infrared signals
This can be achieved by using Scanner.Setup(pin)
ifScanner.Setup(4)
Make sure to implement proper error handling. For reference, take a look at the Example.
To scan for codes, use the following function:
receivedCode, err := ifScanner.Scan()
The scan function will wait until a code is received, then return it.
Due to this, it is to be noted that the Scan
function is blocking, which means you probably want to run this in a separate goroutine.
The Scan
method returns the received code as a hex
string.
Make sure to implement proper error handling.
For another reference, take a look at the Example.
package main
import (
"fmt"
"github.com/smarthome-go/infrared"
)
func main() {
ifScanner := infrared.Scanner
if err := ifScanner.Setup(4); err != nil {
panic(err.Error())
}
receivedCode, err := ifScanner.Scan()
if err != nil {
panic(err)
}
fmt.Println(receivedCode)
}