Commit | Line | Data |
---|---|---|
409d6878 ME |
1 | package org.usfirst.frc.team3501.robot; |
2 | ||
2ada01fd RH |
3 | import edu.wpi.cscore.AxisCamera; |
4 | import edu.wpi.cscore.UsbCamera; | |
b7b608d6 | 5 | import edu.wpi.cscore.VideoSource; |
409d6878 ME |
6 | import edu.wpi.first.wpilibj.CameraServer; |
7 | ||
8 | public class CameraFeeds { | |
50a075d8 RH |
9 | // private final int intakeCam; |
10 | // private final int climberCam; | |
4dff9cc3 | 11 | private VideoSource curCam; |
409d6878 | 12 | private CameraServer server; |
50a075d8 RH |
13 | private static UsbCamera intakeCam; |
14 | private static AxisCamera climberCam; | |
4dff9cc3 RH |
15 | private static String usbCamName; |
16 | private static String axisCamName; | |
4bc0cb18 | 17 | private static CameraFeeds cameraFeeds = null; |
409d6878 | 18 | |
fbc1210e | 19 | @SuppressWarnings("deprecation") |
50a075d8 | 20 | public CameraFeeds(/* Joystick Button */) { |
7638f542 RH |
21 | // Get camera id by supplying camera name example 'cam0', found on roborio |
22 | // web | |
409d6878 | 23 | // interface |
50a075d8 RH |
24 | /* |
25 | * intakeCam = | |
26 | * NIVision.IMAQdxOpenCamera(Constants.CameraFeeds.camNameCenter, | |
27 | * NIVision.IMAQdxCameraControlMode.CameraControlModeController); climberCam | |
28 | * = NIVision.IMAQdxOpenCamera(Constants.CameraFeeds.camNameRight, | |
29 | * NIVision.IMAQdxCameraControlMode.CameraControlModeController); curCam = | |
4bc0cb18 | 30 | * intakeCam; // Image that will contain camera image frame = |
50a075d8 | 31 | * NIVision.imaqCreateImage(NIVision.ImageType.IMAGE_RGB, 0); // Server that |
4bc0cb18 | 32 | * we'll give the image to server = CameraServer.getInstance(); |
50a075d8 RH |
33 | * server.setSize(Constants.CameraFeeds.imgQuality); |
34 | */ | |
4dff9cc3 | 35 | |
409d6878 | 36 | server = CameraServer.getInstance(); |
50a075d8 | 37 | climberCam = server.addAxisCamera("axisCamera", "10.35.1.11"); |
4dff9cc3 RH |
38 | intakeCam = server.startAutomaticCapture(); |
39 | curCam = intakeCam; | |
40 | usbCamName = intakeCam.getName(); | |
41 | axisCamName = climberCam.getName(); | |
2ada01fd RH |
42 | |
43 | // server = CameraServer.getInstance(); | |
44 | // axisCamera = cameraServer2.addAxisCamera("axisCamera", "10.35.1.11"); | |
45 | // cameraFeeds = new CameraFeeds(); | |
409d6878 | 46 | } |
7638f542 | 47 | |
4bc0cb18 | 48 | public static CameraFeeds getCameraFeeds() { |
7638f542 RH |
49 | if (cameraFeeds == null) { |
50 | cameraFeeds = new CameraFeeds(); | |
51 | } | |
52 | return cameraFeeds; | |
53 | ||
4bc0cb18 | 54 | } |
409d6878 ME |
55 | |
56 | public void init() { | |
7638f542 | 57 | changeCam(climberCam); |
409d6878 ME |
58 | } |
59 | ||
4dff9cc3 | 60 | public void toggleCamera() { |
5c6d9c86 | 61 | System.out.println("enter toggleCamer"); |
4dff9cc3 | 62 | if (curCam.equals(intakeCam)) { |
409d6878 | 63 | changeCam(climberCam); |
4dff9cc3 | 64 | curCam = climberCam; |
7638f542 RH |
65 | System.out.println("Switching to climber camera."); |
66 | return; | |
4dff9cc3 | 67 | } |
409d6878 | 68 | |
4dff9cc3 RH |
69 | if (curCam.equals(climberCam)) { |
70 | changeCam(intakeCam); | |
71 | curCam = intakeCam; | |
7638f542 RH |
72 | System.out.println("Switching to intake camera."); |
73 | return; | |
4dff9cc3 | 74 | } |
409d6878 ME |
75 | } |
76 | ||
77 | /** | |
50a075d8 | 78 | * |
4bc0cb18 | 79 | * Change the camera to get image from to a different one |
409d6878 | 80 | * |
7638f542 | 81 | * newId for camera |
409d6878 | 82 | */ |
4dff9cc3 | 83 | public void changeCam(VideoSource cam) { |
5c6d9c86 | 84 | System.out.println("change camera"); |
4dff9cc3 RH |
85 | server.removeCamera(axisCamName); |
86 | server.removeCamera(usbCamName); | |
87 | server.addCamera(cam); | |
409d6878 ME |
88 | } |
89 | } |