Files
2023WayOfTheRobot/src/main/java/frc4388/robot/subsystems/Limelight.java
T

132 lines
3.3 KiB
Java
Raw Normal View History

2023-03-15 13:50:35 -06:00
// Copyright (c) FIRST and other WPILib contributors.
// Open Source Software; you can modify and/or share it under the terms of
// the WPILib BSD license file in the root directory of this project.
package frc4388.robot.subsystems;
import java.util.ArrayList;
import java.util.List;
import org.opencv.core.Point;
import org.photonvision.PhotonCamera;
import org.photonvision.common.hardware.VisionLEDMode;
import org.photonvision.targeting.PhotonPipelineResult;
2023-03-15 14:50:30 -06:00
import org.photonvision.targeting.PhotonTrackedTarget;
2023-03-15 13:50:35 -06:00
import org.photonvision.targeting.TargetCorner;
2023-03-15 16:46:06 -06:00
import edu.wpi.first.wpilibj.smartdashboard.SmartDashboard;
2023-03-15 13:50:35 -06:00
import edu.wpi.first.wpilibj2.command.SubsystemBase;
import frc4388.robot.Constants.VisionConstants;
import frc4388.utility.AbhiIsADumbass;
public class Limelight extends SubsystemBase {
private PhotonCamera cam;
2023-03-15 15:25:06 -06:00
2023-03-15 16:46:06 -06:00
private boolean lightOn;
2023-03-15 15:25:06 -06:00
/** Creates a new Limelight. */
2023-03-15 13:50:35 -06:00
public Limelight() {
cam = new PhotonCamera(VisionConstants.NAME);
2023-03-15 16:46:06 -06:00
cam.setDriverMode(false);
2023-03-15 13:50:35 -06:00
}
public void setLEDs(boolean on) {
2023-03-15 16:46:06 -06:00
lightOn = on;
cam.setLED(lightOn ? VisionLEDMode.kOn : VisionLEDMode.kOff);
}
public void toggleLEDs() {
lightOn = !lightOn;
cam.setLED(lightOn ? VisionLEDMode.kOn : VisionLEDMode.kOff);
2023-03-15 13:50:35 -06:00
}
public void setDriverMode(boolean driverMode) {
cam.setDriverMode(driverMode);
}
2023-03-16 16:25:26 -06:00
public void setToLimePipeline() {
cam.setPipelineIndex(1);
}
public void setToAprilPipeline() {
cam.setPipelineIndex(0);
}
2023-03-16 23:08:08 -06:00
public PhotonTrackedTarget getAprilPoint() {
setToAprilPipeline();
2023-03-15 16:46:06 -06:00
if (!cam.isConnected()) return null;
2023-03-15 13:50:35 -06:00
PhotonPipelineResult result = cam.getLatestResult();
2023-03-16 16:25:26 -06:00
if (!result.hasTargets()) return null;
2023-03-15 13:50:35 -06:00
2023-03-16 23:08:08 -06:00
return result.getBestTarget();
2023-03-15 14:50:30 -06:00
}
2023-03-16 23:08:08 -06:00
public double getDistanceToApril() {
PhotonTrackedTarget aprilPoint = getAprilPoint();
if (aprilPoint == null) return -1;
2023-03-16 16:25:26 -06:00
2023-03-16 23:08:08 -06:00
double aprilHeight = VisionConstants.APRIL_HEIGHT - VisionConstants.LIME_HEIGHT;
double theta = 35.0 + aprilPoint.getPitch();
2023-03-16 16:25:26 -06:00
2023-03-16 23:08:08 -06:00
double distanceToApril = aprilHeight / Math.tan(Math.toRadians(theta));
return distanceToApril;
2023-03-16 16:25:26 -06:00
}
2023-03-16 23:08:08 -06:00
public PhotonTrackedTarget getLowestTape() {
setToLimePipeline();
2023-03-16 19:10:26 -06:00
if (!cam.isConnected()) return null;
PhotonPipelineResult result = cam.getLatestResult();
if (!result.hasTargets()) return null;
ArrayList<PhotonTrackedTarget> points = (ArrayList<PhotonTrackedTarget>) result.getTargets();
PhotonTrackedTarget lowest = points.get(0);
for (PhotonTrackedTarget point : points) {
if (point.getPitch() < lowest.getPitch()) {
lowest = point;
}
}
return lowest;
}
2023-03-16 23:08:08 -06:00
public int getNumTapes() {
setToLimePipeline();
2023-03-16 19:10:26 -06:00
PhotonPipelineResult result = cam.getLatestResult();
return result.getTargets().size();
2023-03-15 14:50:30 -06:00
}
2023-03-16 23:08:08 -06:00
public double getDistanceToTape() {
PhotonTrackedTarget tapePoint = getLowestTape();
if (tapePoint == null) return -1;
2023-03-15 14:50:30 -06:00
2023-03-16 23:08:08 -06:00
double tapeHeight = VisionConstants.MID_TAPE_HEIGHT - VisionConstants.LIME_HEIGHT;
2023-03-16 16:25:26 -06:00
double theta = 35.0 + tapePoint.getPitch();
2023-03-15 14:50:30 -06:00
2023-03-16 23:08:08 -06:00
double distanceToTape = tapeHeight / Math.tan(Math.toRadians(theta));
return distanceToTape;
2023-03-15 13:50:35 -06:00
}
2023-03-16 16:25:26 -06:00
int ctr = 0;
2023-03-15 13:50:35 -06:00
@Override
public void periodic() {
// This method will be called once per scheduler run
2023-03-16 16:25:26 -06:00
if (ctr % 50 == 0) {
2023-03-16 23:08:08 -06:00
SmartDashboard.putNumber("Horizontal Distance", getDistanceToTape());
2023-03-16 16:25:26 -06:00
}
ctr++;
2023-03-15 13:50:35 -06:00
}
}