func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) baro := bmp085.New(bus) defer baro.Close() for { temp, err := baro.Temperature() if err != nil { panic(err) } fmt.Printf("Temp is %v\n", temp) pressure, err := baro.Pressure() if err != nil { panic(err) } fmt.Printf("Pressure is %v\n", pressure) altitude, err := baro.Altitude() if err != nil { panic(err) } fmt.Printf("Altitude is %v\n", altitude) time.Sleep(500 * time.Millisecond) } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) dac := mcp4725.New(bus, 0x62) defer dac.Close() stop := make(chan os.Signal, 1) signal.Notify(stop, os.Interrupt, os.Kill) for { select { case <-stop: return default: voltage := rand.Intn(4096) if err := dac.SetVoltage(voltage); err != nil { fmt.Printf("mcp4725: %v\n", err) } } } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) gyro := l3gd20.New(bus, l3gd20.R250DPS) defer gyro.Close() gyro.Start() quit := make(chan os.Signal, 1) signal.Notify(quit, os.Interrupt, os.Kill) orientations, err := gyro.Orientations() if err != nil { panic(err) } timer := time.Tick(250 * time.Millisecond) for { select { case <-timer: orientation := <-orientations fmt.Printf("x: %v, y: %v, z: %v\n", orientation.X, orientation.Y, orientation.Z) case <-quit: return } } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) sensor := tmp006.New(bus, 0x40) if status, err := sensor.Present(); err != nil || !status { fmt.Println("tmp006: not found") fmt.Println(err) return } defer sensor.Close() sensor.Start() stop := make(chan os.Signal, 1) signal.Notify(stop, os.Interrupt, os.Kill) for { select { case temp := <-sensor.ObjTemps(): fmt.Printf("tmp006: got obj temp %.2f\n", temp) case temp := <-sensor.RawDieTemps(): fmt.Printf("tmp006: got die temp %.2f\n", temp) case <-stop: return } } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) controller, err := hd44780.NewI2C( bus, 0x20, hd44780.PCF8574PinMap, hd44780.RowAddress20Col, hd44780.TwoLine, hd44780.BlinkOn, ) if err != nil { panic(err) } display := characterdisplay.New(controller, 20, 4) defer display.Close() display.Clear() display.Message("Hello, world!\n@embd | characterdisplay") time.Sleep(10 * time.Second) display.BacklightOff() }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) d := pca9685.New(bus, 0x41) d.Freq = 50 defer d.Close() pwm := d.ServoChannel(0) servo := servo.New(pwm) c := make(chan os.Signal, 1) signal.Notify(c, os.Interrupt, os.Kill) turnTimer := time.Tick(500 * time.Millisecond) left := true servo.SetAngle(90) defer func() { servo.SetAngle(90) }() for { select { case <-turnTimer: left = !left switch left { case true: servo.SetAngle(70) case false: servo.SetAngle(110) } case <-c: return } } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) hd, err := hd44780.NewI2C( bus, 0x20, hd44780.PCF8574PinMap, hd44780.RowAddress20Col, hd44780.TwoLine, hd44780.BlinkOn, ) if err != nil { panic(err) } defer hd.Close() hd.Clear() message := "Hello, world!" bytes := []byte(message) for _, b := range bytes { hd.WriteChar(b) } hd.SetCursor(0, 1) message = "@embd | hd44780" bytes = []byte(message) for _, b := range bytes { hd.WriteChar(b) } time.Sleep(10 * time.Second) hd.BacklightOff() }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) pca9685 := pca9685.New(bus, 0x41) pca9685.Freq = 1000 defer pca9685.Close() if err := pca9685.SetPwm(15, 0, 2000); err != nil { panic(err) } c := make(chan os.Signal, 1) signal.Notify(c, os.Interrupt, os.Kill) timer := time.Tick(2 * time.Second) sleeping := false for { select { case <-timer: sleeping = !sleeping if sleeping { pca9685.Sleep() } else { pca9685.Wake() } case <-c: return } } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) mems := lsm303.New(bus) defer mems.Close() for { heading, err := mems.Heading() if err != nil { panic(err) } fmt.Printf("Heading is %v\n", heading) time.Sleep(500 * time.Millisecond) } }
func main() { flag.Parse() if err := embd.InitI2C(); err != nil { panic(err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) sensor := bh1750fvi.New(bh1750fvi.High, bus) defer sensor.Close() for { lighting, err := sensor.Lighting() if err != nil { panic(err) } fmt.Printf("Lighting is %v lx\n", lighting) time.Sleep(500 * time.Millisecond) } }
func main() { guardianToken := os.Getenv("GUARDIAN_TOKEN") if guardianToken == "" { log.Fatal("GUARDIAN_TOKEN is required") } ctx, cancel := context.WithCancel(context.Background()) sigch := make(chan os.Signal, 2) signal.Notify(sigch, os.Interrupt, syscall.SIGTERM) go handleSignals(sigch, ctx, cancel) if err := embd.InitI2C(); err != nil { log.Fatal("I2C init: ", err) } defer embd.CloseI2C() bus := embd.NewI2CBus(1) dev := pca9685.New(bus, 0x40) dev.Freq = 100 defer dev.Close() // wake the servo controller so we can reset its channels if err := dev.Wake(); err != nil { log.Fatal("waking: ", err) } resetAllChannels(dev) resetTimer := time.After(time.Second) // long enough for servos to reset query := url.Values{} query.Set("vsn", "1.0.0") query.Set("guardian_token", guardianToken) u := url.URL{ Scheme: "wss", Host: "opendoor-pusher.herokuapp.com", Path: "/events/websocket", RawQuery: query.Encode(), } joinPayload, err := json.Marshal(GuardianPayload{GuardianToken: guardianToken}) if err != nil { log.Fatal(err) } client := phoenix.InitClient(u.String(), []string{topicName}, joinPayload) eventch := client.Start() defer client.Close() select { case <-resetTimer: // servos have had enough time to reset if err := dev.Sleep(); err != nil { log.Fatal(err) } case <-ctx.Done(): return } for { select { case evt := <-eventch: switch evt.Event { case "acquisition_contract", "resale_contract": handleRingEvent(dev, evt) case "system_test": handleSystemTest(dev, evt) default: log.Printf("unhandled message received: %#v", evt) } case <-ctx.Done(): return } } }