upm
0.2.0
Sensor/Actuator repository for libmraa (v0.6.1)
|
C++ API for the Grove I2C Motor Driver. More...
This class implements support for the Grove I2C Motor Driver. This device can support a single 4-wire stepper motor, OR two 2-wire DC motors. The device contains an Atmel ATmega8L microcontroller that manages an L298N H-bridge driver chip.
This device supports an i2c bus speed of 100Khz only.
The module does not provide any telemetry or status – it only accepts I2C commands for its various operations.
This module was tested with version 1.3 of the Grove I2C Motor Driver
Public Member Functions | |
GroveMD (int bus=GROVEMD_I2C_BUS, uint8_t address=GROVEMD_DEFAULT_I2C_ADDR) | |
~GroveMD () | |
bool | writePacket (REG_T reg, uint8_t data1, uint8_t data2) |
bool | setMotorSpeeds (uint8_t speedA, uint8_t speedB) |
bool | setPWMFrequencyPrescale (uint8_t freq=0x03) |
bool | setMotorDirections (DC_DIRECTION_T dirA, DC_DIRECTION_T dirB) |
bool | enableStepper (STEP_DIRECTION_T dir, uint8_t speed) |
bool | disableStepper () |
bool | setStepperSteps (uint8_t steps) |
GroveMD | ( | int | bus = GROVEMD_I2C_BUS , |
uint8_t | address = GROVEMD_DEFAULT_I2C_ADDR |
||
) |
grovemd constructor
bus | i2c bus to use |
address | i2c address to use |
bool writePacket | ( | REG_T | reg, |
uint8_t | data1, | ||
uint8_t | data2 | ||
) |
Compose and write a 3-byte packet to the controller
reg | register location |
data1 | first byte of data |
data2 | second byte of data |
bool setMotorSpeeds | ( | uint8_t | speedA, |
uint8_t | speedB | ||
) |
For controlling DC motors, set the speeds of motors A & B. Valid values are 0-255.
speedA | speed of motor A |
speedB | speed of motor B |
bool setPWMFrequencyPrescale | ( | uint8_t | freq = 0x03 | ) |
For controlling DC motors, set the PWM frequency prescale factor. Note this register is not ducumented other than to say that the default value is 0x03. Presumably this is the timer pre-scale factor used on the ATMega MCU timer driving the PWM.
freq | PWM prescale frequency, default 0x03 |
bool setMotorDirections | ( | DC_DIRECTION_T | dirA, |
DC_DIRECTION_T | dirB | ||
) |
For controlling DC motors, set the directions of motors A & B
dirA | direction for motor A, DIR_CW or DIR_CCW |
dirB | direction for motor B, DIR_CW or DIR_CCW |
bool enableStepper | ( | STEP_DIRECTION_T | dir, |
uint8_t | speed | ||
) |
For controlling a stepper motor, set a direction, speed and then enable.
dir | direction, STEP_DIR_CW or STEP_DIR_CCW |
speed | motor speed. Valid range is 1-255, higher is slower. |
bool disableStepper | ( | ) |
For controlling a stepper motor, stop the stepper motor.
bool setStepperSteps | ( | uint8_t | steps | ) |
For controlling a stepper motor, specify the number of steps to execute. Valid values are 1-255, 255 means to rotate continuously.
steps | number of steps to execute. 255 means rotate continously. |