From 4c8412b06d32c46263e1520b5c6f330835f1274a Mon Sep 17 00:00:00 2001 From: 535tobor <92122791+535tobor@users.noreply.github.com> Date: Thu, 5 Oct 2023 18:06:24 -0400 Subject: [PATCH] Add files via upload --- teamcode/BlueBoardSide.java | 85 +++++++++++++++ teamcode/BlueFarSide.java | 45 ++++++++ teamcode/Main.java | 97 +++++++++++++++++ teamcode/RedBoardSide.java | 45 ++++++++ teamcode/RedFarSide.java | 46 ++++++++ teamcode/operations/TargetOperations.java | 10 ++ teamcode/operations/TargetSetup.java | 15 +++ teamcode/operations/inOut/Gamepad2.java | 24 +++++ teamcode/operations/inputs/AprilTag.java | 81 ++++++++++++++ teamcode/operations/inputs/Imu.java | 82 ++++++++++++++ .../operations/outputs/DriverStation.java | 11 ++ .../motors/barMotor/BarMotorMovements.java | 20 ++++ .../motors/barMotor/ConfigureMotorBar.java | 14 +++ .../motors/drive/HardcoreMovements.java | 102 ++++++++++++++++++ .../outputs/motors/drive/Mecanum.java | 39 +++++++ .../outputs/motors/drive/configureMotors.java | 77 +++++++++++++ .../pixelMotor/ConfigureMotorPixel.java | 15 +++ .../pixelMotor/PixelMotorMovements.java | 21 ++++ 18 files changed, 829 insertions(+) create mode 100644 teamcode/BlueBoardSide.java create mode 100644 teamcode/BlueFarSide.java create mode 100644 teamcode/Main.java create mode 100644 teamcode/RedBoardSide.java create mode 100644 teamcode/RedFarSide.java create mode 100644 teamcode/operations/TargetOperations.java create mode 100644 teamcode/operations/TargetSetup.java create mode 100644 teamcode/operations/inOut/Gamepad2.java create mode 100644 teamcode/operations/inputs/AprilTag.java create mode 100644 teamcode/operations/inputs/Imu.java create mode 100644 teamcode/operations/outputs/DriverStation.java create mode 100644 teamcode/operations/outputs/motors/barMotor/BarMotorMovements.java create mode 100644 teamcode/operations/outputs/motors/barMotor/ConfigureMotorBar.java create mode 100644 teamcode/operations/outputs/motors/drive/HardcoreMovements.java create mode 100644 teamcode/operations/outputs/motors/drive/Mecanum.java create mode 100644 teamcode/operations/outputs/motors/drive/configureMotors.java create mode 100644 teamcode/operations/outputs/motors/pixelMotor/ConfigureMotorPixel.java create mode 100644 teamcode/operations/outputs/motors/pixelMotor/PixelMotorMovements.java diff --git a/teamcode/BlueBoardSide.java b/teamcode/BlueBoardSide.java new file mode 100644 index 0000000..2a779ef --- /dev/null +++ b/teamcode/BlueBoardSide.java @@ -0,0 +1,85 @@ +package org.firstinspires.ftc.teamcode; + +import static org.firstinspires.ftc.teamcode.operations.inputs.AprilTag.*; +import static org.firstinspires.ftc.teamcode.operations.outputs.DriverStation.output; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.HardcoreMovements.*; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.*; + +import com.qualcomm.robotcore.eventloop.opmode.Autonomous; + +import org.firstinspires.ftc.teamcode.operations.TargetOperations; + +@Autonomous(name="Blue, Board Side") +public class BlueBoardSide extends TargetOperations { + + @Override + public void runOpMode() throws InterruptedException { + // LinearOpMode that calls a different form of OpMode: + runInit(); + while(opModeInInit()){runInitLoop();} + waitForStart(); + runStart(); + if (isStopRequested()){runStop();} // stop OpMode if the button is pressed + while (opModeIsActive()) {runLoop();} + visionPortal.close(); // close view for camera + } + + @Override + public void runInit() { + mapMotors("fr","fl","br","bl"); + forwardMotors(false,true,false,true); + // ^ set motor directions + initAprilTag("Camera 1"); + } + + @Override + public void runInitLoop(){} + + @Override + public void runStart() {} + @Override + public void runStop() { + stopAll(); + } + @Override + public void runLoop() { + + setAprilTagVariables(); + // ^ this line puts the april tag number into a variable, along with other april tag infromation + if (gamepad1.a) { + drive(0.5,0.5, 0.25,0.25); + } + else { + driveStop(); + } + + if (gamepad1.x) { + drive(0.5,-0.5, 0.25,-0.25); + } + else { + driveStop(); + } + + if (gamepad1.b) { + drive(-0.5,0.5, -0.25,0.25); + } + else { + driveStop(); + } + output(tagId); + if (tagId == 1){ + output("The First Tag!"); + runStop(); + } + else if (tagId == 2){ + output("The Second Tag!"); + runStop(); + } + else if (tagId == 3){ + output("The Third Tag!"); + runStop(); + } + + } +} + diff --git a/teamcode/BlueFarSide.java b/teamcode/BlueFarSide.java new file mode 100644 index 0000000..d372a7e --- /dev/null +++ b/teamcode/BlueFarSide.java @@ -0,0 +1,45 @@ +package org.firstinspires.ftc.teamcode; + +import com.qualcomm.robotcore.eventloop.opmode.Autonomous; + +import org.firstinspires.ftc.teamcode.operations.TargetOperations; + +@Autonomous(name="Blue, Far Side") +public class BlueFarSide extends TargetOperations { + + @Override + public void runOpMode() { + + runInit(); + while(opModeInInit()){runInitLoop();} + waitForStart(); + runStart(); + if (isStopRequested()){runStop();} + while (opModeIsActive()) {runLoop();} + } + + @Override + public void runInit() { + + } + + @Override + public void runInitLoop() { + + } + + @Override + public void runStart() { + + } + + @Override + public void runLoop() { + + } + + @Override + public void runStop() { + + } +} \ No newline at end of file diff --git a/teamcode/Main.java b/teamcode/Main.java new file mode 100644 index 0000000..31d03ed --- /dev/null +++ b/teamcode/Main.java @@ -0,0 +1,97 @@ +package org.firstinspires.ftc.teamcode; + +import static org.firstinspires.ftc.teamcode.operations.inOut.Gamepad2.*; +import static org.firstinspires.ftc.teamcode.operations.inputs.AprilTag.tagId; +import static org.firstinspires.ftc.teamcode.operations.inputs.Imu.imuGet; +import static org.firstinspires.ftc.teamcode.operations.outputs.DriverStation.output; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.HardcoreMovements.*; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.Mecanum.*; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.*; + +import com.qualcomm.robotcore.eventloop.opmode.TeleOp; + +import org.firstinspires.ftc.teamcode.operations.TargetOperations; + +@TeleOp +public class Main extends TargetOperations { + + double speed = 0.5; // speed used when using hardcore mode + + @Override + public void runOpMode() { + runInit(); + while(opModeInInit()){runInitLoop();} + waitForStart(); + runStart(); + if (isStopRequested()){runStop();} + while (opModeIsActive()) {runLoop();} + } + + @Override + public void runInit() { + mapMotors("fr","fl","br","bl"); + forwardMotors(false,true,false,true); + //ConfigureMotorBar.mapMotor("bar"); + //ConfigureMotorPixel.mapMotor("pixel"); + imuGet("imu", "LEFT", "UP"); + } + + @Override + public void runInitLoop() { + + } + + @Override + public void runStart() { + } + + @Override + public void runLoop() { + waypoints(-gamepad1.left_stick_y, gamepad1.left_stick_x, gamepad1.right_stick_x); // Remember, Y stick value is reversed + imuReset(gamepad1.options); // resets imu case of accidents or incidences + fieldCentricMath(); // does the required math for Mecanum drive as well as getting imu for field centric + runPixelMotor(gamepad2.a); + runBarMotor(gamepad2.y); + drive(frontLeftPower,backLeftPower,frontRightPower,backRightPower); + + /// Hardcore movements for Mecanum, but no turn: + + if (gamepad1.dpad_left) { + left(speed); + } + + else if (gamepad1.dpad_right) { + right(speed); + } + + else if (gamepad1.dpad_up) { + forward(speed); + } + + else if (gamepad1.dpad_down) { + backward(speed); + } + + else { + driveStop(); + } + + /// + + if (gamepad1.x) { + // go to april tag 1 + if (tagId != 1) { + left(speed); + } + else if (tagId == 1) { + output("tag 1"); + } + } + + } + + @Override + public void runStop() { + + } +} \ No newline at end of file diff --git a/teamcode/RedBoardSide.java b/teamcode/RedBoardSide.java new file mode 100644 index 0000000..31f56bc --- /dev/null +++ b/teamcode/RedBoardSide.java @@ -0,0 +1,45 @@ +package org.firstinspires.ftc.teamcode; + +import com.qualcomm.robotcore.eventloop.opmode.Autonomous; + +import org.firstinspires.ftc.teamcode.operations.TargetOperations; + +@Autonomous(name="Red, Board Side") +public class RedBoardSide extends TargetOperations { + @Override + public void runOpMode() { + + runInit(); + while(opModeInInit()){runInitLoop();} + waitForStart(); + runStart(); + if (isStopRequested()){runStop();} + while (opModeIsActive()) {runLoop();} + } + + @Override + public void runInit() { + + } + + @Override + public void runInitLoop() { + + } + + @Override + public void runStart() { + + } + + @Override + public void runLoop() { + + } + + @Override + public void runStop() { + + } + +} \ No newline at end of file diff --git a/teamcode/RedFarSide.java b/teamcode/RedFarSide.java new file mode 100644 index 0000000..59aeb68 --- /dev/null +++ b/teamcode/RedFarSide.java @@ -0,0 +1,46 @@ +package org.firstinspires.ftc.teamcode; + +import com.qualcomm.robotcore.eventloop.opmode.Autonomous; + +import org.firstinspires.ftc.teamcode.operations.TargetOperations; + +@Autonomous(name="Red, Far Side") +public class RedFarSide extends TargetOperations { + + @Override + public void runOpMode() { + + runInit(); + while(opModeInInit()){runInitLoop();} + waitForStart(); + runStart(); + if (isStopRequested()){runStop();} + while (opModeIsActive()) {runLoop();} + } + + @Override + public void runInit() { + + } + + @Override + public void runInitLoop() { + + } + + @Override + public void runStart() { + + } + + @Override + public void runLoop() { + + } + + @Override + public void runStop() { + + } + +} \ No newline at end of file diff --git a/teamcode/operations/TargetOperations.java b/teamcode/operations/TargetOperations.java new file mode 100644 index 0000000..db89256 --- /dev/null +++ b/teamcode/operations/TargetOperations.java @@ -0,0 +1,10 @@ +package org.firstinspires.ftc.teamcode.operations; + +import com.qualcomm.robotcore.eventloop.opmode.LinearOpMode; +public abstract class TargetOperations extends LinearOpMode implements TargetSetup { + + public void stopAll() { + requestOpModeStop(); + } + +} \ No newline at end of file diff --git a/teamcode/operations/TargetSetup.java b/teamcode/operations/TargetSetup.java new file mode 100644 index 0000000..4ac5484 --- /dev/null +++ b/teamcode/operations/TargetSetup.java @@ -0,0 +1,15 @@ +// public is not needed, because Interface has public by default +package org.firstinspires.ftc.teamcode.operations; + + interface TargetSetup { + /* + this interface was made so that + both LinearOpMode and OpMode can be + ran within the same class + */ + void runInit(); + void runInitLoop(); + void runStart(); + void runLoop(); + void runStop(); +} diff --git a/teamcode/operations/inOut/Gamepad2.java b/teamcode/operations/inOut/Gamepad2.java new file mode 100644 index 0000000..53bb91c --- /dev/null +++ b/teamcode/operations/inOut/Gamepad2.java @@ -0,0 +1,24 @@ +package org.firstinspires.ftc.teamcode.operations.inOut; + +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.pixelMotor.ConfigureMotorPixel.pixelMotor; + +import org.firstinspires.ftc.teamcode.operations.outputs.motors.barMotor.BarMotorMovements; + +public class Gamepad2 { + + public static void runPixelMotor(boolean button) { + if (button) { + pixelMotor.setPower(1); + } + else { + pixelMotor.setPower(0); + } + } + + + public static void runBarMotor(boolean button) { + if (button) { + BarMotorMovements.rotate(50,1); + } + } +} \ No newline at end of file diff --git a/teamcode/operations/inputs/AprilTag.java b/teamcode/operations/inputs/AprilTag.java new file mode 100644 index 0000000..a1fa369 --- /dev/null +++ b/teamcode/operations/inputs/AprilTag.java @@ -0,0 +1,81 @@ +package org.firstinspires.ftc.teamcode.operations.inputs; + +import static org.firstinspires.ftc.robotcore.external.BlocksOpModeCompanion.hardwareMap; + +import org.firstinspires.ftc.robotcore.external.hardware.camera.WebcamName; +import org.firstinspires.ftc.vision.VisionPortal; +import org.firstinspires.ftc.vision.apriltag.AprilTagDetection; +import org.firstinspires.ftc.vision.apriltag.AprilTagProcessor; + +import java.util.ArrayList; +import java.util.List; + +public class AprilTag { + + public static final boolean USE_WEBCAM = true; // true for webcam, false for phone camera + + public static VisionPortal visionPortal; + + public static double firstTagId, tagId; + public static AprilTagDetection firstTagFound; + public static double tagsFound; + public static String tagName; + + public static List tagCenter, tagPosition; + + public static AprilTagProcessor aprilTag; + + + public static void initAprilTag(String CameraName) { + + // Create the AprilTag processor + aprilTag = AprilTagProcessor.easyCreateWithDefaults(); + + visionPortal = VisionPortal.easyCreateWithDefaults( + hardwareMap.get(WebcamName.class, CameraName), aprilTag); + } + + public static void initAprilTag() { + // default hardware map name for the camera + initAprilTag("Camera 1"); // sets the name to the default name + } + + public static void setAprilTagVariables() { + // add AprilTag found information to set variables + + List currentDetections = aprilTag.getDetections(); + firstTagFound = currentDetections.get(0); + firstTagId = firstTagFound.id; + tagsFound = currentDetections.size(); + + // Step through the list of detections and display info for each one. + for (AprilTagDetection detection : currentDetections) { + if (detection.metadata != null) { + + tagName = detection.metadata.name; + tagPosition = new ArrayList(); + tagPosition.add(detection.ftcPose.x); + tagPosition.add(detection.ftcPose.y); + tagPosition.add(detection.ftcPose.z); + tagPosition.add(detection.ftcPose.pitch); + tagPosition.add(detection.ftcPose.roll); + tagPosition.add(detection.ftcPose.yaw); + tagPosition.add(detection.ftcPose.range); + tagPosition.add(detection.ftcPose.bearing); + tagPosition.add(detection.ftcPose.elevation); + + } + else { + + tagName = "unknown"; + } + + tagId = detection.id; + + tagCenter = new ArrayList(); + tagCenter.add(detection.center.x); + tagCenter.add(detection.center.y); + } + } + +} diff --git a/teamcode/operations/inputs/Imu.java b/teamcode/operations/inputs/Imu.java new file mode 100644 index 0000000..eaa7585 --- /dev/null +++ b/teamcode/operations/inputs/Imu.java @@ -0,0 +1,82 @@ +package org.firstinspires.ftc.teamcode.operations.inputs; + +import static com.qualcomm.hardware.rev.RevHubOrientationOnRobot.LogoFacingDirection.BACKWARD; +import static com.qualcomm.hardware.rev.RevHubOrientationOnRobot.LogoFacingDirection.DOWN; +import static com.qualcomm.hardware.rev.RevHubOrientationOnRobot.LogoFacingDirection.FORWARD; +import static com.qualcomm.hardware.rev.RevHubOrientationOnRobot.LogoFacingDirection.LEFT; +import static com.qualcomm.hardware.rev.RevHubOrientationOnRobot.LogoFacingDirection.RIGHT; +import static com.qualcomm.hardware.rev.RevHubOrientationOnRobot.LogoFacingDirection.UP; + +import com.qualcomm.hardware.rev.RevHubOrientationOnRobot; +import com.qualcomm.robotcore.hardware.HardwareMap; +import com.qualcomm.robotcore.hardware.IMU; + + +public class Imu { + + public static IMU imu; + + static HardwareMap hardwareMap = null; + + public static void imuGet (String hardwareMapImuName, String logoFacing, String usbFacing) { + // get imu from hardware map and set the directions to the directions of the robot's brain + imu = hardwareMap.get(IMU .class, hardwareMapImuName); + // Retrieve the IMU from the hardware map + IMU.Parameters parameters = null; + // Adjust the orientation parameters to match your robot + if (logoFacing == UP.name() && usbFacing == FORWARD.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + UP, + RevHubOrientationOnRobot.UsbFacingDirection.FORWARD)); + } + + else if (logoFacing == LEFT.name() && usbFacing == UP.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.LEFT, + RevHubOrientationOnRobot.UsbFacingDirection.UP)); + } + + else if (logoFacing == RIGHT.name() && usbFacing == UP.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.RIGHT, + RevHubOrientationOnRobot.UsbFacingDirection.UP)); + } + + else if (logoFacing == FORWARD.name() && usbFacing == UP.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.FORWARD, + RevHubOrientationOnRobot.UsbFacingDirection.UP)); + } + + else if (logoFacing == BACKWARD.name() && usbFacing == UP.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.BACKWARD, + RevHubOrientationOnRobot.UsbFacingDirection.UP)); + } + + else if (logoFacing == FORWARD.name() && usbFacing == RIGHT.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.FORWARD, + RevHubOrientationOnRobot.UsbFacingDirection.RIGHT)); + } + + else if (logoFacing == UP.name() && usbFacing == BACKWARD.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + UP, + RevHubOrientationOnRobot.UsbFacingDirection.BACKWARD)); + } + + else if (logoFacing == DOWN.name() && usbFacing == FORWARD.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.DOWN, + RevHubOrientationOnRobot.UsbFacingDirection.FORWARD)); + } + + else if (logoFacing == FORWARD.name() && usbFacing == LEFT.name()) { + parameters = new IMU.Parameters(new RevHubOrientationOnRobot( + RevHubOrientationOnRobot.LogoFacingDirection.FORWARD, + RevHubOrientationOnRobot.UsbFacingDirection.LEFT)); + } + imu.initialize(parameters); + } +} diff --git a/teamcode/operations/outputs/DriverStation.java b/teamcode/operations/outputs/DriverStation.java new file mode 100644 index 0000000..404373f --- /dev/null +++ b/teamcode/operations/outputs/DriverStation.java @@ -0,0 +1,11 @@ +package org.firstinspires.ftc.teamcode.operations.outputs; + +import static org.firstinspires.ftc.robotcore.external.BlocksOpModeCompanion.telemetry; + +public class DriverStation { + public static void output(Object output) { + // display to telemetry without a caption + telemetry.addData("", output); + telemetry.update(); + } +} diff --git a/teamcode/operations/outputs/motors/barMotor/BarMotorMovements.java b/teamcode/operations/outputs/motors/barMotor/BarMotorMovements.java new file mode 100644 index 0000000..709d381 --- /dev/null +++ b/teamcode/operations/outputs/motors/barMotor/BarMotorMovements.java @@ -0,0 +1,20 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.barMotor; + +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.barMotor.ConfigureMotorBar.barMotor; + +import com.qualcomm.robotcore.hardware.DcMotor; + +public class BarMotorMovements { + + public void motorEncoder () { + barMotor.setMode(DcMotor.RunMode.RUN_USING_ENCODER); + barMotor.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER); + barMotor.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); + } + + public static void rotate(int rotations, int speed) { + barMotor.setTargetPosition(rotations); + barMotor.setMode(DcMotor.RunMode.RUN_TO_POSITION); + barMotor.setPower(speed); + } +} diff --git a/teamcode/operations/outputs/motors/barMotor/ConfigureMotorBar.java b/teamcode/operations/outputs/motors/barMotor/ConfigureMotorBar.java new file mode 100644 index 0000000..a243496 --- /dev/null +++ b/teamcode/operations/outputs/motors/barMotor/ConfigureMotorBar.java @@ -0,0 +1,14 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.barMotor; + +import static org.firstinspires.ftc.robotcore.external.BlocksOpModeCompanion.hardwareMap; + +import com.qualcomm.robotcore.hardware.DcMotor; + +public class ConfigureMotorBar { + + public static DcMotor barMotor; + public static void mapMotor (String motorName) { + barMotor = hardwareMap.dcMotor.get(motorName); + } + +} diff --git a/teamcode/operations/outputs/motors/drive/HardcoreMovements.java b/teamcode/operations/outputs/motors/drive/HardcoreMovements.java new file mode 100644 index 0000000..006ddda --- /dev/null +++ b/teamcode/operations/outputs/motors/drive/HardcoreMovements.java @@ -0,0 +1,102 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.drive; + +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.bl; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.br; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.fl; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.fr; + +import com.qualcomm.robotcore.hardware.DcMotor; + +public class HardcoreMovements { + + public static void forward(double speed) { + fr.setPower(speed); + fl.setPower(speed); + br.setPower(speed); + bl.setPower(speed); + + } + + public static void backward(double speed) { + fr.setPower(speed); + fl.setPower(speed); + br.setPower(speed); + bl.setPower(speed); + + } + + public static void left(double speed) { + fr.setPower(speed); + fl.setPower(-speed); + br.setPower(-speed); + bl.setPower(speed); + + } + + public static void right(double speed) { + fr.setPower(-speed); + fl.setPower(speed); + br.setPower(speed); + bl.setPower(-speed); + + } + + public static void forwardLeft(double speed) { + fr.setPower(speed); + bl.setPower(speed); + + } + + public static void forwardRight(double speed) { + fl.setPower(speed); + br.setPower(speed); + + } + + public static void backwardLeft(double speed) {; + fl.setPower(-speed); + br.setPower(-speed); + + } + + public static void backwardRight(double speed) { + fr.setPower(-speed); + bl.setPower(-speed); + + } + + public static void turnRight(double speed) { + fr.setPower(-speed); + fl.setPower(speed); + br.setPower(-speed); + bl.setPower(speed); + + } + + public static void turnLeft(double speed) { + fr.setPower(speed); + fl.setPower(-speed); + br.setPower(speed); + bl.setPower(-speed); + + } + + public static void drive(double frontLeftSpeed, double frontRightSpeed, double backLeftSpeed, double backRightSpeed) { + fr.setPower(frontLeftSpeed); + fl.setPower(frontRightSpeed); + br.setPower(backLeftSpeed); + bl.setPower(backRightSpeed); + + } + + public static void driveStop() { + + drive(0,0,0,0); + fl.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); + fr.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); + bl.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); + br.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); + } + // ^ set all motors to 0, this stops all movements + +} diff --git a/teamcode/operations/outputs/motors/drive/Mecanum.java b/teamcode/operations/outputs/motors/drive/Mecanum.java new file mode 100644 index 0000000..6ae453c --- /dev/null +++ b/teamcode/operations/outputs/motors/drive/Mecanum.java @@ -0,0 +1,39 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.drive; + +import static org.firstinspires.ftc.teamcode.operations.inputs.Imu.imu; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.rx; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.x; +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.drive.configureMotors.y; + +import org.firstinspires.ftc.robotcore.external.navigation.AngleUnit; + +public class Mecanum { + + static double botHeading; + static double rotX; + static double rotY; + static double denominator; + public static double frontLeftPower; + public static double frontRightPower; + public static double backLeftPower; + public static double backRightPower; + + public static void fieldCentricMath() { + double botHeading = imu.getRobotYawPitchRollAngles().getYaw(AngleUnit.RADIANS); + + // Rotate the movement direction counter to the robot's rotation + double rotX = x * Math.cos(-botHeading) - y * Math.sin(-botHeading); + double rotY = x * Math.sin(-botHeading) + y * Math.cos(-botHeading); + + rotX = rotX * 1.1; // Counteract imperfect strafing + + // Denominator is the largest motor power (absolute value) or 1 + // This ensures all the powers maintain the same ratio, + // but only if at least one is out of the range [-1, 1] + double denominator = Math.max(Math.abs(rotY) + Math.abs(rotX) + Math.abs(rx), 1); + double frontLeftPower = (rotY + rotX + rx) / denominator; + double backLeftPower = (rotY - rotX + rx) / denominator; + double frontRightPower = (rotY - rotX - rx) / denominator; + double backRightPower = (rotY + rotX - rx) / denominator; + } +} diff --git a/teamcode/operations/outputs/motors/drive/configureMotors.java b/teamcode/operations/outputs/motors/drive/configureMotors.java new file mode 100644 index 0000000..b32e972 --- /dev/null +++ b/teamcode/operations/outputs/motors/drive/configureMotors.java @@ -0,0 +1,77 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.drive; + +import static org.firstinspires.ftc.teamcode.operations.inputs.Imu.imu; + +import com.qualcomm.robotcore.hardware.DcMotor; +import com.qualcomm.robotcore.hardware.DcMotorSimple; +import com.qualcomm.robotcore.hardware.HardwareMap; + +public class configureMotors { + + public static DcMotor fr; + public static DcMotor fl; + public static DcMotor br; + public static DcMotor bl; + + public static double y; + public static double x; + public static double rx; + + static HardwareMap hardwareMap = null; + + public static void mapMotors (String frontLeftMotor, String frontRightMotor, String backLeftMotor, String backRightMotor) { + fr = hardwareMap.dcMotor.get(frontRightMotor); + fl = hardwareMap.dcMotor.get(frontLeftMotor); + br = hardwareMap.dcMotor.get(backRightMotor); + bl = hardwareMap.dcMotor.get(backLeftMotor); + } + + + public static void forwardMotors (boolean frontLeftMotor, boolean frontRightMotor, boolean backLeftMotor, boolean backRightMotor) { + + if (frontRightMotor) { + fr.setDirection(DcMotorSimple.Direction.FORWARD); + } + + else { + fr.setDirection(DcMotorSimple.Direction.REVERSE); + } + + if (frontLeftMotor) { + fl.setDirection(DcMotorSimple.Direction.FORWARD); + } + + else { + fl.setDirection(DcMotorSimple.Direction.REVERSE); + } + + if (backRightMotor) { + br.setDirection(DcMotorSimple.Direction.FORWARD); + } + + else { + br.setDirection(DcMotorSimple.Direction.REVERSE); + } + + if (backLeftMotor) { + bl.setDirection(DcMotorSimple.Direction.FORWARD); + } + + else { + bl.setDirection(DcMotorSimple.Direction.REVERSE); + } + } + + public static void waypoints(double Y, double X, double RX) { + y = Y; + x = X; + rx = RX; + } + + public static void imuReset(boolean button) { + if (button) { + imu.resetYaw(); + } + } + +} diff --git a/teamcode/operations/outputs/motors/pixelMotor/ConfigureMotorPixel.java b/teamcode/operations/outputs/motors/pixelMotor/ConfigureMotorPixel.java new file mode 100644 index 0000000..91e7288 --- /dev/null +++ b/teamcode/operations/outputs/motors/pixelMotor/ConfigureMotorPixel.java @@ -0,0 +1,15 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.pixelMotor; + +import static org.firstinspires.ftc.robotcore.external.BlocksOpModeCompanion.hardwareMap; + +import com.qualcomm.robotcore.hardware.DcMotor; + +public class ConfigureMotorPixel { + + public static DcMotor pixelMotor; + + public static void mapMotor (String motorName) { + pixelMotor = hardwareMap.dcMotor.get(motorName); + } + +} diff --git a/teamcode/operations/outputs/motors/pixelMotor/PixelMotorMovements.java b/teamcode/operations/outputs/motors/pixelMotor/PixelMotorMovements.java new file mode 100644 index 0000000..d1704f7 --- /dev/null +++ b/teamcode/operations/outputs/motors/pixelMotor/PixelMotorMovements.java @@ -0,0 +1,21 @@ +package org.firstinspires.ftc.teamcode.operations.outputs.motors.pixelMotor; + +import static org.firstinspires.ftc.teamcode.operations.outputs.motors.pixelMotor.ConfigureMotorPixel.pixelMotor; + +import com.qualcomm.robotcore.hardware.DcMotor; + +public class PixelMotorMovements { + + public static void motorEncoder () { + pixelMotor.setMode(DcMotor.RunMode.RUN_USING_ENCODER); + pixelMotor.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER); + pixelMotor.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); + } + + public static void rotate (int rotations, int speed) { + pixelMotor.setTargetPosition(rotations); + pixelMotor.setMode(DcMotor.RunMode.RUN_TO_POSITION); + pixelMotor.setPower(speed); + } + +}