1
0
mirror of https://github.com/hybridgroup/gobot.git synced 2025-04-29 13:49:14 +08:00
hybridgroup.gobot/platforms/gpio/analog_sensor_driver.go

84 lines
2.2 KiB
Go
Raw Normal View History

2014-04-27 19:34:16 -07:00
package gpio
import (
"time"
"github.com/hybridgroup/gobot"
2014-04-27 19:34:16 -07:00
)
var _ gobot.Driver = (*AnalogSensorDriver)(nil)
2014-09-27 11:34:13 -07:00
// Represents an Analog Sensor
2014-04-27 19:34:16 -07:00
type AnalogSensorDriver struct {
name string
pin string
interval time.Duration
connection gobot.Connection
gobot.Eventer
gobot.Commander
2014-04-27 19:34:16 -07:00
}
2014-09-27 11:34:13 -07:00
// NewAnalogSensorDriver returns a new AnalogSensorDriver given an AnalogReader, name and pin.
//
// Adds the following API Commands:
// "Read" - See AnalogSensor.Read
func NewAnalogSensorDriver(a AnalogReader, name string, pin string, v ...time.Duration) *AnalogSensorDriver {
2014-06-11 17:41:04 -07:00
d := &AnalogSensorDriver{
name: name,
connection: a.(gobot.Connection),
pin: pin,
Eventer: gobot.NewEventer(),
Commander: gobot.NewCommander(),
interval: 10 * time.Millisecond,
2014-04-27 19:34:16 -07:00
}
if len(v) > 0 {
d.interval = v[0]
}
d.AddEvent("data")
d.AddEvent("error")
2014-07-09 18:32:27 -07:00
d.AddCommand("Read", func(params map[string]interface{}) interface{} {
val, err := d.Read()
return map[string]interface{}{"val": val, "err": err}
2014-06-11 17:41:04 -07:00
})
2014-06-11 17:41:04 -07:00
return d
2014-04-27 19:34:16 -07:00
}
func (a *AnalogSensorDriver) conn() AnalogReader {
return a.Connection().(AnalogReader)
}
2014-09-27 11:34:13 -07:00
// Starts the AnalogSensorDriver and reads the Analog Sensor at the given Driver.Interval().
// Returns true on successful start of the driver.
// Emits the Events:
// "data" int - Event is emitted on change and represents the current reading from the sensor.
func (a *AnalogSensorDriver) Start() (errs []error) {
2014-06-28 17:18:16 -07:00
value := 0
go func() {
for {
newValue, err := a.Read()
if err != nil {
gobot.Publish(a.Event("error"), err)
} else if newValue != value && newValue != -1 {
value = newValue
gobot.Publish(a.Event("data"), value)
}
<-time.After(a.interval)
2014-06-28 17:18:16 -07:00
}
}()
return
2014-06-28 17:18:16 -07:00
}
2014-09-27 11:34:13 -07:00
// Halt returns true on a successful halt of the driver
func (a *AnalogSensorDriver) Halt() (errs []error) { return }
func (a *AnalogSensorDriver) Name() string { return a.name }
func (a *AnalogSensorDriver) Pin() string { return a.pin }
func (a *AnalogSensorDriver) Connection() gobot.Connection { return a.connection }
2014-04-27 19:34:16 -07:00
2014-09-27 11:34:13 -07:00
// Read returns the current reading from the Analog Sensor
func (a *AnalogSensorDriver) Read() (val int, err error) {
return a.conn().AnalogRead(a.Pin())
2014-04-27 19:34:16 -07:00
}