Robot and CommandOpMode
Organizing your code with the Robot class and CommandOpMode.
Last updated
Was this helpful?
Organizing your code with the Robot class and CommandOpMode.
Last updated
Was this helpful?
NOTE: We recommend using the for your implementation of the command-based paradigm as it is much friendlier for FTC programs.
The class makes using the CommandScheduler so much simpler in the user's code. Similar to WPILib, the Robot class allows for making a Robot paradigm. This allows for the creation of multiple opmodes tied to one object. This is also the basis for disabling the robot, meaning we want to interrupt the commands and not allow for scheduling new ones. This is done with the static disable()
and enable()
methods:
The first step in using the Robot paradigm is to create your own Robot subclass. This will maintain all of the commands and subsystems you want to utilize. Also note that you can schedule and register new commands and subsystems from outside the Robot class using the schedule()
and register()
methods.
A major downside of the Robot class is that it shares the common commands and subsystems for every use in the OpModes. A recommendation is to create an inside of your robot implementation that specifies TeleOp versus Autonomous so that when the object is constructed, it uses the desired CommandScheduler instance.
Below is an example of utilizing this feature.
Running the robot in the opmode is simple and only requires a few lines of code and making a call to the run()
method.
If desired, the user can override the methods from the CommandOpMode. Similarly to the Robot class, you can disable the CommandOpMode with static methods (which actually disable the Robot class, which is what is referenced in the CommandScheduler for runsWhenDisabled()
commands.
CommandOpMode is an abstract class, which means the user must create their own implementation of it. The only method that needs to be implemented is the initialize()
method, which instantiates all of the hardware and commands to be run by the scheduler. The CommandOpMode class already implements the runOpMode()
method and runs the scheduler. After the opmode is no longer active or a stop is requested, it resets the instance of the scheduler so a new opmode can be run with a fresh instance. This is very nonintuitive, but it works as designed (setting the singleton instance to null, where a new instance is then created upon calling getInstance()
.
A downside that cannot be fixed by this is when you want to run several different opmodes of the different types with respect to the same subsystems. This is where the comes in handy and makes the paradigm a lot more FTC-friendly.
The is the center of the FTC-centric command-based paradigm. It makes everything simpler for the user and greatly decreases the amount of code needed to run everything. Unlike the Robot class, it is opmode-specific, so it does not store a common reference to subsystems. If desired, the user can create a map that houses all of the referenced hardware, but this is currently not a feature offered (but totally supported) by FTCLib.
That is functionally all that needs to be done, everything else is done for the user internally. You can find a sample project utilizing CommandOpMode .