2015-07-09 01:54:37 +08:00
|
|
|
package i2c
|
|
|
|
|
2016-12-08 20:24:03 +08:00
|
|
|
import "gobot.io/x/gobot"
|
2015-07-09 01:54:37 +08:00
|
|
|
|
|
|
|
var _ gobot.Driver = (*MMA7660Driver)(nil)
|
|
|
|
|
|
|
|
const mma7660Address = 0x4c
|
|
|
|
|
|
|
|
const (
|
|
|
|
MMA7660_X = 0x00
|
|
|
|
MMA7660_Y = 0x01
|
|
|
|
MMA7660_Z = 0x02
|
|
|
|
MMA7660_TILT = 0x03
|
|
|
|
MMA7660_SRST = 0x04
|
|
|
|
MMA7660_SPCNT = 0x05
|
|
|
|
MMA7660_INTSU = 0x06
|
|
|
|
MMA7660_MODE = 0x07
|
|
|
|
MMA7660_STAND_BY = 0x00
|
|
|
|
MMA7660_ACTIVE = 0x01
|
|
|
|
MMA7660_SR = 0x08
|
|
|
|
MMA7660_AUTO_SLEEP_120 = 0x00
|
|
|
|
MMA7660_AUTO_SLEEP_64 = 0x01
|
|
|
|
MMA7660_AUTO_SLEEP_32 = 0x02
|
|
|
|
MMA7660_AUTO_SLEEP_16 = 0x03
|
|
|
|
MMA7660_AUTO_SLEEP_8 = 0x04
|
|
|
|
MMA7660_AUTO_SLEEP_4 = 0x05
|
|
|
|
MMA7660_AUTO_SLEEP_2 = 0x06
|
|
|
|
MMA7660_AUTO_SLEEP_1 = 0x07
|
|
|
|
MMA7660_PDET = 0x09
|
|
|
|
MMA7660_PD = 0x0A
|
|
|
|
)
|
|
|
|
|
|
|
|
type MMA7660Driver struct {
|
|
|
|
name string
|
|
|
|
connection I2c
|
|
|
|
}
|
|
|
|
|
2016-09-25 20:08:18 +08:00
|
|
|
// NewMMA7660Driver creates a new driver with specified i2c interface
|
|
|
|
func NewMMA7660Driver(a I2c) *MMA7660Driver {
|
2015-07-09 01:54:37 +08:00
|
|
|
return &MMA7660Driver{
|
|
|
|
connection: a,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (h *MMA7660Driver) Name() string { return h.name }
|
2016-09-25 20:08:18 +08:00
|
|
|
func (h *MMA7660Driver) SetName(n string) { h.name = n }
|
2015-07-09 01:54:37 +08:00
|
|
|
func (h *MMA7660Driver) Connection() gobot.Connection { return h.connection.(gobot.Connection) }
|
|
|
|
|
|
|
|
// Start initialized the mma7660
|
2016-11-07 21:55:21 +08:00
|
|
|
func (h *MMA7660Driver) Start() (err error) {
|
2015-07-09 01:54:37 +08:00
|
|
|
if err := h.connection.I2cStart(mma7660Address); err != nil {
|
2016-11-07 21:55:21 +08:00
|
|
|
return err
|
2015-07-09 01:54:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := h.connection.I2cWrite(mma7660Address, []byte{MMA7660_MODE, MMA7660_STAND_BY}); err != nil {
|
2016-11-07 21:55:21 +08:00
|
|
|
return err
|
2015-07-09 01:54:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := h.connection.I2cWrite(mma7660Address, []byte{MMA7660_SR, MMA7660_AUTO_SLEEP_32}); err != nil {
|
2016-11-07 21:55:21 +08:00
|
|
|
return err
|
2015-07-09 01:54:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if err := h.connection.I2cWrite(mma7660Address, []byte{MMA7660_MODE, MMA7660_ACTIVE}); err != nil {
|
2016-11-07 21:55:21 +08:00
|
|
|
return err
|
2015-07-09 01:54:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Halt returns true if devices is halted successfully
|
2016-11-07 21:55:21 +08:00
|
|
|
func (h *MMA7660Driver) Halt() (err error) { return }
|
2015-07-09 01:54:37 +08:00
|
|
|
|
|
|
|
// Acceleration returns the acceleration of the provided x, y, z
|
|
|
|
func (h *MMA7660Driver) Acceleration(x, y, z float64) (ax, ay, az float64) {
|
|
|
|
return x / 21.0, y / 21.0, z / 21.0
|
|
|
|
}
|
|
|
|
|
|
|
|
// XYZ returns the raw x,y and z axis from the mma7660
|
|
|
|
func (h *MMA7660Driver) XYZ() (x float64, y float64, z float64, err error) {
|
|
|
|
ret, err := h.connection.I2cRead(mma7660Address, 3)
|
|
|
|
if err != nil {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(ret) != 3 {
|
|
|
|
err = ErrNotEnoughBytes
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, val := range ret {
|
|
|
|
if ((val >> 6) & 0x01) == 1 {
|
|
|
|
err = ErrNotReady
|
|
|
|
return
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
x = float64((int8(ret[0]) << 2)) / 4.0
|
|
|
|
y = float64((int8(ret[1]) << 2)) / 4.0
|
|
|
|
z = float64((int8(ret[2]) << 2)) / 4.0
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|