Package com.revrobotics
Class CANSparkMaxLowLevel
- java.lang.Object
- 
- com.revrobotics.CANSparkMaxLowLevel
 
- 
- All Implemented Interfaces:
- edu.wpi.first.wpilibj.PIDOutput,- edu.wpi.first.wpilibj.SpeedController
 - Direct Known Subclasses:
- CANSparkMax
 
 public abstract class CANSparkMaxLowLevel extends java.lang.Object implements edu.wpi.first.wpilibj.SpeedController
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected static classCANSparkMaxLowLevel.FollowConfigstatic classCANSparkMaxLowLevel.MotorTypestatic classCANSparkMaxLowLevel.PeriodicFrameclassCANSparkMaxLowLevel.PeriodicStatus0classCANSparkMaxLowLevel.PeriodicStatus1classCANSparkMaxLowLevel.PeriodicStatus2
 - 
Field SummaryFields Modifier and Type Field Description static intkAPIBuildVersionstatic intkAPIMajorVersionstatic intkAPIMinorVersionstatic intkAPIVersionprotected CANSparkMaxLowLevel.MotorTypem_motorTypeprotected longm_sparkMax
 - 
Constructor SummaryConstructors Constructor Description CANSparkMaxLowLevel(int deviceID, CANSparkMaxLowLevel.MotorType type)Create a new SPARK MAX Controller
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static voidenableExternalUSBControl(boolean enable)Allow external controllers to recieve control commands over USB.intgetDeviceId()Get the configured Device ID of the SPARK MAX.java.lang.StringgetFirmwareString()Get the firmware version of the SPARK MAX as a string.intgetFirmwareVersion()Get the firmware version of the SPARK MAX.CANSparkMaxLowLevel.MotorTypegetInitialMotorType()Get the motor type setting from when the SparkMax was created.CANSparkMaxLowLevel.MotorTypegetMotorType()Get the motor type setting for the SPARK MAX.floatgetSafeFloat(float f)byte[]getSerialNumber()Get the unique serial number of the SPARK MAX.CANErrorrestoreFactoryDefaults()Restore motor controller parameters to factory default until the next controller rebootCANErrorrestoreFactoryDefaults(boolean persist)Restore motor controller parameters to factory defaultprotected CANErrorsetAltEncPosition(double value)voidsetControlFramePeriodMs(int periodMs)Set the control frame send period for the native CAN Send thread.protected CANErrorsetEncPosition(double value)protected CANErrorsetIAccum(double value)CANErrorsetMotorType(CANSparkMaxLowLevel.MotorType type)Set the motor type connected to the SPARK MAX.CANErrorsetPeriodicFramePeriod(CANSparkMaxLowLevel.PeriodicFrame frameID, int periodMs)Set the rate of transmission for periodic frames from the SPARK MAX Each motor controller sends back three status frames with different data at set rates.
 
- 
- 
- 
Field Detail- 
kAPIMajorVersionpublic static final int kAPIMajorVersion 
 - 
kAPIMinorVersionpublic static final int kAPIMinorVersion 
 - 
kAPIBuildVersionpublic static final int kAPIBuildVersion 
 - 
kAPIVersionpublic static final int kAPIVersion 
 - 
m_sparkMaxprotected long m_sparkMax 
 - 
m_motorTypeprotected final CANSparkMaxLowLevel.MotorType m_motorType 
 
- 
 - 
Constructor Detail- 
CANSparkMaxLowLevelpublic CANSparkMaxLowLevel(int deviceID, CANSparkMaxLowLevel.MotorType type)Create a new SPARK MAX Controller- Parameters:
- deviceID- The device ID.
- type- The motor type connected to the controller. Brushless motors must be connected to their matching color and the hall sensor plugged in. Brushed motors must be connected to the Red and Black terminals only.
 
 
- 
 - 
Method Detail- 
getFirmwareVersionpublic int getFirmwareVersion() Get the firmware version of the SPARK MAX.- Returns:
- uint32_t Firmware version integer. Value is represented as 4 bytes, Major.Minor.Build H.Build L
 
 - 
setControlFramePeriodMspublic void setControlFramePeriodMs(int periodMs) Set the control frame send period for the native CAN Send thread.- Parameters:
- periodMs- The send period in milliseconds between 1ms and 100ms or set to 0 to disable periodic sends. Note this is not updated until the next call to Set() or SetReference().
 
 - 
getFirmwareStringpublic java.lang.String getFirmwareString() Get the firmware version of the SPARK MAX as a string.- Returns:
- std::string Human readable firmware version string
 
 - 
getSerialNumberpublic byte[] getSerialNumber() Get the unique serial number of the SPARK MAX. Not currently available.- Returns:
- byte[] Vector of bytes representig the unique serial number
 
 - 
getDeviceIdpublic int getDeviceId() Get the configured Device ID of the SPARK MAX.- Returns:
- int device ID
 
 - 
getInitialMotorTypepublic CANSparkMaxLowLevel.MotorType getInitialMotorType() Get the motor type setting from when the SparkMax was created. This does not use the Get Parameter API which means it does not read what motor type is stored on the SparkMax itself. Instead, it reads the stored motor type from when the SparkMax object was first created.- Returns:
- MotorType Motor type setting
 
 - 
setMotorTypepublic CANError setMotorType(CANSparkMaxLowLevel.MotorType type) Set the motor type connected to the SPARK MAX. This uses the Set Parameter API and should be used infrequently. The parameter does not presist unless burnFlash() is called. The recommended method to configure this parameter is to use the SPARK MAX GUI to tune and save parameters.- Parameters:
- type- The type of motor connected to the controller. Brushless motors must be connected to their matching color and the hall sensor plugged in. Brushed motors must be connected to the Red and Black terminals only.
- Returns:
- CANError Set to CANError::kOk if successful
 
 - 
getMotorTypepublic CANSparkMaxLowLevel.MotorType getMotorType() Get the motor type setting for the SPARK MAX. This uses the Get Parameter API and should be used infrequently. This function uses a non-blocking call and will return a cached value if the parameter is not returned by the timeout. The timeout can be changed by calling SetCANTimeout(int milliseconds)- Returns:
- MotorType Motor type setting
 
 - 
setPeriodicFramePeriodpublic CANError setPeriodicFramePeriod(CANSparkMaxLowLevel.PeriodicFrame frameID, int periodMs) Set the rate of transmission for periodic frames from the SPARK MAX Each motor controller sends back three status frames with different data at set rates. Use this function to change the default rates. Defaults: Status0 - 10ms Status1 - 20ms Status2 - 50ms This value is not stored in the FLASH after calling burnFlash() and is reset on powerup. Refer to the SPARK MAX reference manual on details for how and when to configure this parameter.- Parameters:
- frameID- The frame ID can be one of PeriodicFrame type
- periodMs- The rate the controller sends the frame to the controller.
- Returns:
- CANError Set to CANError.kOK if successful
 
 - 
enableExternalUSBControlpublic static void enableExternalUSBControl(boolean enable) Allow external controllers to recieve control commands over USB. For example, a configuration where the heartbeat (and enable/disable) is sent by the main controller, but control frames are sent by other CAN devices over USB. This is global for all controllers on the same bus. This does not disable sending control frames from this device. To prevent conflicts, do not enable this feature and also send Set() for SetReference() from the controllers you wish to control.- Parameters:
- enable- Enable or disable external control
 
 - 
getSafeFloatpublic float getSafeFloat(float f) 
 - 
setEncPositionprotected CANError setEncPosition(double value) 
 - 
setAltEncPositionprotected CANError setAltEncPosition(double value) 
 - 
setIAccumprotected CANError setIAccum(double value) 
 - 
restoreFactoryDefaultspublic CANError restoreFactoryDefaults() Restore motor controller parameters to factory default until the next controller reboot- Returns:
- CANError Set to CANError::kOk if successful
 
 - 
restoreFactoryDefaultspublic CANError restoreFactoryDefaults(boolean persist) Restore motor controller parameters to factory default- Parameters:
- persist- If true, burn the flash with the factory default parameters
- Returns:
- CANError Set to CANError::kOk if successful
 
 
- 
 
-