Version 2 (modified by 5 years ago) (diff) | ,
---|
Often it's desirable to have more than one camera on a robot, for example to provide front and back views. As always, camera code should always run in its own thread to prevent camera errors from taking down the main robot thread. The example below shows how to create a new thread class called Cameras that creates two cameras and lets you switch between them using an Xbox controller.
WPILib provides a great helper class called CameraServer that does most of the heavy lifting. You can read about it here and here
For more info see
Robot.java
package frc.robot; import edu.wpi.first.wpilibj.TimedRobot; public class Robot extends TimedRobot { Cameras cameras; @Override public void robotInit() { cameras = new Cameras(); // create the Cameras thread cameras.start(); // start thread and launch its run() method } }
Cameras.java
Create a new file named Cameras.java under src/main/java/frc/robot (same folder as Robot.java):
package frc.robot; import edu.wpi.first.cameraserver.CameraServer; import edu.wpi.cscore.UsbCamera; import edu.wpi.first.wpilibj.XboxController; class Cameras extends Thread { CameraServer camServer; UsbCamera frontCam, rearCam; XboxController xbox; public Cameras() { // Camera server manages all cameras and streams camServer = CameraServer.getInstance(); // Create and start front and rear cameras frontCam = camServer.startAutomaticCapture("front", 0); rearCam = camServer.startAutomaticCapture("rear", 1); // Use Xbox controller to select camera stream xbox = new XboxController(0); } public void run() { while (true) { if (xbox.getAButton()) { // A button selects front camera camServer.getServer().setSource(frontCam); } if (xbox.getBButton()) { // B button selects rear camera camServer.getServer().setSource(rearCam); } } } }