2014-04-27 19:34:16 -07:00
|
|
|
package gpio
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
import (
|
2023-12-03 18:03:02 +01:00
|
|
|
"fmt"
|
2023-11-15 20:51:52 +01:00
|
|
|
|
|
|
|
"gobot.io/x/gobot/v2"
|
|
|
|
)
|
2014-04-27 19:34:16 -07:00
|
|
|
|
2015-01-02 10:42:53 -08:00
|
|
|
// ServoDriver Represents a Servo
|
2014-04-27 19:34:16 -07:00
|
|
|
type ServoDriver struct {
|
2023-12-03 18:03:02 +01:00
|
|
|
*driver
|
|
|
|
currentAngle byte
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
|
|
|
|
2016-09-25 13:36:18 +02:00
|
|
|
// NewServoDriver returns a new ServoDriver given a ServoWriter and pin.
|
2014-09-27 11:34:13 -07:00
|
|
|
//
|
2023-12-03 18:03:02 +01:00
|
|
|
// Supported options:
|
|
|
|
//
|
|
|
|
// "WithName"
|
|
|
|
//
|
2014-09-27 11:34:13 -07:00
|
|
|
// Adds the following API Commands:
|
2023-05-20 14:25:21 +02:00
|
|
|
//
|
|
|
|
// "Move" - See ServoDriver.Move
|
2023-12-03 18:03:02 +01:00
|
|
|
// "Min" - See ServoDriver.ToMin
|
|
|
|
// "Center" - See ServoDriver.ToCenter
|
|
|
|
// "Max" - See ServoDriver.ToMax
|
|
|
|
func NewServoDriver(a ServoWriter, pin string, opts ...interface{}) *ServoDriver {
|
|
|
|
//nolint:forcetypeassert // no error return value, so there is no better way
|
2023-11-15 20:51:52 +01:00
|
|
|
d := &ServoDriver{
|
2023-12-03 18:03:02 +01:00
|
|
|
driver: newDriver(a.(gobot.Connection), "Servo", append(opts, withPin(pin))...),
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
2014-06-11 17:41:04 -07:00
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
d.AddCommand("Move", func(params map[string]interface{}) interface{} {
|
|
|
|
angle := byte(params["angle"].(float64)) //nolint:forcetypeassert // ok here
|
|
|
|
return d.Move(angle)
|
2014-06-11 17:41:04 -07:00
|
|
|
})
|
2023-12-03 18:03:02 +01:00
|
|
|
d.AddCommand("ToMin", func(params map[string]interface{}) interface{} {
|
|
|
|
return d.ToMin()
|
2014-06-11 17:41:04 -07:00
|
|
|
})
|
2023-12-03 18:03:02 +01:00
|
|
|
d.AddCommand("ToCenter", func(params map[string]interface{}) interface{} {
|
|
|
|
return d.ToCenter()
|
2014-06-11 17:41:04 -07:00
|
|
|
})
|
2023-12-03 18:03:02 +01:00
|
|
|
d.AddCommand("ToMax", func(params map[string]interface{}) interface{} {
|
|
|
|
return d.ToMax()
|
2014-06-11 17:41:04 -07:00
|
|
|
})
|
|
|
|
|
2023-11-15 20:51:52 +01:00
|
|
|
return d
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
|
|
|
|
2015-01-02 10:42:53 -08:00
|
|
|
// Move sets the servo to the specified angle. Acceptable angles are 0-180
|
2023-11-15 20:51:52 +01:00
|
|
|
func (d *ServoDriver) Move(angle uint8) error {
|
2023-05-19 14:16:22 +02:00
|
|
|
if angle > 180 {
|
2023-12-03 18:03:02 +01:00
|
|
|
return fmt.Errorf("servo angle (%d) must be between 0-180", angle)
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
2023-12-03 18:03:02 +01:00
|
|
|
d.currentAngle = angle
|
|
|
|
return d.servoWrite(d.driverCfg.pin, angle)
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
|
|
|
|
2014-09-27 11:34:13 -07:00
|
|
|
// Min sets the servo to it's minimum position
|
2023-12-03 18:03:02 +01:00
|
|
|
func (d *ServoDriver) ToMin() error {
|
2023-11-15 20:51:52 +01:00
|
|
|
return d.Move(0)
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
|
|
|
|
2014-09-27 11:34:13 -07:00
|
|
|
// Center sets the servo to it's center position
|
2023-12-03 18:03:02 +01:00
|
|
|
func (d *ServoDriver) ToCenter() error {
|
2023-11-15 20:51:52 +01:00
|
|
|
return d.Move(90)
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
|
|
|
|
2014-09-27 11:34:13 -07:00
|
|
|
// Max sets the servo to its maximum position
|
2023-12-03 18:03:02 +01:00
|
|
|
func (d *ServoDriver) ToMax() error {
|
2023-11-15 20:51:52 +01:00
|
|
|
return d.Move(180)
|
2014-04-27 19:34:16 -07:00
|
|
|
}
|
2023-12-03 18:03:02 +01:00
|
|
|
|
|
|
|
// Angle returns the current angle
|
|
|
|
func (d *ServoDriver) Angle() uint8 {
|
|
|
|
return d.currentAngle
|
|
|
|
}
|