gyro#
Initializing the gyro Class#
A Gyro Sensor is created by using the following constructor:
The gyro
constructor creates a gyro object in the specified Three Wire Port:
Parameter |
Description |
---|---|
|
A valid Smart Port that the Gyro Sensor is connected to. |
// Create the Brain.
brain Brain;
// Construct a Gyro Sensor "Gyro" with the
// gyro class.
gyro Gyro = gyro(PORT1);
This Gyro
object will be used in all subsequent examples throughout this API documentation when referring to gyro class methods.
Class Methods#
calibrate()#
This method is called in the following ways:
The calibrate()
method calibrates the Gyro Sensor. Calibration should be done when the Gyro Sensor is not moving.
Returns: None.
// Start calibration.
Gyro.calibrate();
The calibrate(value)
method calibrates the Gyro Sensor. Calibration should be done when the Gyro Sensor is not moving.
Parameters |
Description |
---|---|
value |
Sets the amount of calibration time. The default is 0. |
Returns: None.
// Start calibration with the calibration time set to 3 seconds.
Gyro.calibrate(3);
isCalibrating()#
The isCalibrating()
method checks if the Gyro Sensor is currently calibrating.
Returns: true
if the Gyro is calibrating. false
if it is not.
// Start calibration.
Gyro.calibrate();
// Print that the Gyro is calibrating while waiting for it to
// finish calibrating.
while(Gyro.isCalibrating()){
Brain.Screen.clear();
Brain.Screen.print("Gyro Calibrating");
wait(50, msec);
}
resetHeading()#
The resetHeading()
method resets the heading of the Gyro Sensor to 0.
Returns: None.
resetRotation()#
The resetRotation()
method resets the rotation of the Gyro Sensor to 0.
Returns: None.
setHeading()#
The setHeading(value, units)
method sets the heading of the Gyro Sensor to a specific value.
Parameters |
Description |
---|---|
value |
The value to use for the new heading. |
units |
A valid RotationUnit. |
Returns: None.
angle()#
The angle(units)
method returns the current angle of the Gyro Sensor.
Parameters |
Description |
---|---|
units |
A valid RotationUnit. The default is |
Returns: A double representing current angle of the Gyro Sensor in the specified units.
// Get the current angle for the Gyro.
double value = Gyro.angle()
heading()#
The heading(units)
method returns the current heading of the Gyro Sensor.
Parameters |
Description |
---|---|
units |
A valid RotationUnit. The default is |
Returns: A double representing current heading of the Gyro Sensor in the specified units.
// Get the current heading for the Gyro.
double value = Gyro.heading()
setRotation()#
The setRotation(value, units)
method sets the rotation of the Gyro Sensor to a specific value.
Parameters |
Description |
---|---|
value |
The value to use for the new rotation. |
units |
A valid RotationUnit. |
Returns: None.
rotation()#
The rotation(units)
method returns the current rotation of the Gyro Sensor.
Parameters |
Description |
---|---|
units |
A valid RotationUnit. The default is |
Returns: A double representing current rotation of the Gyro Sensor in the specified units.
// Get the current rotation for the Gyro.
double value = Gyro.rotation()
setTurnType()#
The setTurnType(dir)
command sets the direction which returns positive heading.
Parameters |
Description |
---|---|
dir |
A valid TurnType. |
Returns: None.
// Set the direction for positive angles to right.
Gyro.setTurnType(right);
getTurnType()#
The getTurnType()
method returns the direction that returns positive heading values with the Gyro Sensor.
Returns: The turn type of the Gyro Sensor in the specified units.
changed()#
The changed(callback)
method registers a callback function for when the Gyro Sensor’s heading changes.
Parameters |
Description |
---|---|
callback |
The callback function to be called when the Gyro Sensor’s heading changes. |
Returns: None.
// Define the GyroChanged function with a void return type,
// showing it doesn't return a value.
void GyroChanged() {
// The Brain will print that the Gyro Sensor changed on the
// Brain's screen.
Brain.Screen.print("Gyro changed");
}
int main() {
// Initializing Robot Configuration. DO NOT REMOVE!
vexcodeInit();
// Turn the robot right.
Drivetrain.turn(right);
// Run GyroChanged when the value of the
// Gyro Sensor changes.
Gyro.changed(GyroChanged);
}