2014-01-02 06:50:57 +05:30
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"log"
|
2014-01-07 22:11:41 +05:30
|
|
|
"os"
|
|
|
|
"os/signal"
|
2014-01-09 05:26:21 +05:30
|
|
|
"time"
|
2014-01-02 06:50:57 +05:30
|
|
|
|
2014-02-10 05:05:41 +05:30
|
|
|
"github.com/kidoman/embd/i2c"
|
|
|
|
"github.com/kidoman/embd/sensor/l3gd20"
|
2014-01-02 06:50:57 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
func main() {
|
2014-02-08 03:52:06 +05:30
|
|
|
bus := i2c.NewBus(1)
|
|
|
|
|
2014-01-02 06:50:57 +05:30
|
|
|
gyro := l3gd20.New(bus, l3gd20.R250DPS)
|
2014-01-09 05:26:21 +05:30
|
|
|
gyro.Debug = true
|
2014-01-02 06:50:57 +05:30
|
|
|
defer gyro.Close()
|
|
|
|
|
2014-01-07 22:11:41 +05:30
|
|
|
gyro.Start()
|
2014-01-02 06:50:57 +05:30
|
|
|
|
2014-01-07 22:11:41 +05:30
|
|
|
quit := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(quit, os.Interrupt, os.Kill)
|
2014-01-02 06:50:57 +05:30
|
|
|
|
2014-01-07 22:11:41 +05:30
|
|
|
orientations, err := gyro.Orientations()
|
|
|
|
if err != nil {
|
|
|
|
log.Panic(err)
|
|
|
|
}
|
2014-01-02 06:50:57 +05:30
|
|
|
|
2014-01-09 05:26:21 +05:30
|
|
|
timer := time.Tick(250 * time.Millisecond)
|
|
|
|
|
2014-01-07 22:11:41 +05:30
|
|
|
for {
|
|
|
|
select {
|
2014-01-09 05:26:21 +05:30
|
|
|
case <-timer:
|
|
|
|
orientation := <-orientations
|
2014-01-07 22:11:41 +05:30
|
|
|
log.Printf("x: %v, y: %v, z: %v", orientation.X, orientation.Y, orientation.Z)
|
|
|
|
case <-quit:
|
|
|
|
return
|
|
|
|
}
|
2014-01-02 06:50:57 +05:30
|
|
|
}
|
|
|
|
}
|