2023-12-17 18:10:23 +01:00
|
|
|
package org.firstinspires.ftc.teamcode;
|
|
|
|
|
|
|
|
import com.qualcomm.robotcore.eventloop.opmode.LinearOpMode;
|
2024-02-11 15:10:49 +01:00
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.YawPitchRollAngles;
|
2023-12-17 18:10:23 +01:00
|
|
|
import com.qualcomm.robotcore.robot.Robot;
|
|
|
|
import org.firstinspires.ftc.robotcore.external.Telemetry;
|
|
|
|
import com.qualcomm.robotcore.hardware.Gamepad;
|
|
|
|
import com.qualcomm.robotcore.hardware.DcMotorEx;
|
|
|
|
import com.qualcomm.robotcore.robot.Robot;
|
|
|
|
import com.qualcomm.robotcore.eventloop.opmode.TeleOp;
|
|
|
|
import com.qualcomm.robotcore.hardware.DcMotor;
|
|
|
|
import com.qualcomm.robotcore.hardware.DcMotorSimple;
|
|
|
|
import com.qualcomm.robotcore.hardware.Servo;
|
2024-01-07 15:55:38 +01:00
|
|
|
|
2024-01-07 16:20:57 +01:00
|
|
|
import com.qualcomm.robotcore.hardware.IMU;
|
2024-01-07 16:25:41 +01:00
|
|
|
import com.qualcomm.robotcore.hardware.ImuOrientationOnRobot;
|
2024-01-07 16:28:37 +01:00
|
|
|
import com.qualcomm.hardware.rev.RevHubOrientationOnRobot;
|
2024-01-07 15:55:38 +01:00
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.AngleUnit;
|
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.AxesOrder;
|
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.AxesReference;
|
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.Orientation;
|
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.Position;
|
|
|
|
import org.firstinspires.ftc.robotcore.external.navigation.Velocity;
|
2023-12-17 18:10:23 +01:00
|
|
|
|
2024-01-28 15:50:55 +01:00
|
|
|
//test
|
2024-03-17 15:42:51 +01:00
|
|
|
@TeleOp(name = "WeRobot: FTC2024 Carlike", group = "WeRobot")
|
2023-12-17 18:10:23 +01:00
|
|
|
public class Werobot_FTC2024_carlike extends LinearOpMode {
|
2024-03-17 15:42:51 +01:00
|
|
|
|
|
|
|
// Le moteur de droite
|
|
|
|
private DcMotor rm;
|
|
|
|
|
|
|
|
// Le moteur de gauche
|
|
|
|
private DcMotor lm;
|
|
|
|
|
|
|
|
private DcMotor moissoneuse;
|
|
|
|
|
|
|
|
private DcMotor lmelevator;
|
|
|
|
|
|
|
|
private DcMotor rmelevator;
|
|
|
|
|
|
|
|
private DcMotor box;
|
|
|
|
|
|
|
|
private DcMotor rotation;
|
|
|
|
|
|
|
|
private IMU imu;
|
2024-01-07 16:24:24 +01:00
|
|
|
|
2024-02-11 16:15:23 +01:00
|
|
|
/*
|
2024-03-17 15:42:51 +01:00
|
|
|
* La fonction pour faire des exponentielles spécifiques
|
|
|
|
*
|
|
|
|
* @param double t => le nombre dont on veut faire l'exponentielle
|
|
|
|
*
|
|
|
|
* @return double une_exponentielle_très_spéciale_de_t
|
2024-02-11 16:15:23 +01:00
|
|
|
*/
|
2024-03-17 15:42:51 +01:00
|
|
|
private double helloexp(double t) {
|
|
|
|
return (Math.exp(5 * t) - 1) / (Math.exp(5) - 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
private void tele(string name, string data) {
|
|
|
|
telemetry.addData(name, data);
|
|
|
|
telemetry.update();
|
|
|
|
}
|
|
|
|
|
2024-02-11 16:15:23 +01:00
|
|
|
/*
|
2024-03-17 15:42:51 +01:00
|
|
|
* La fonction du thread principal
|
2024-02-11 16:15:23 +01:00
|
|
|
*/
|
2024-03-17 15:42:51 +01:00
|
|
|
@Override
|
|
|
|
public void runOpMode() throws InterruptedException {
|
|
|
|
// l'axe x du joystick gauche de la manette
|
|
|
|
float x;
|
|
|
|
|
|
|
|
// l'axe y du joystick gauche de la manette
|
|
|
|
|
|
|
|
double y;
|
|
|
|
|
|
|
|
// variation 1 du left trigger
|
|
|
|
|
|
|
|
double t;
|
|
|
|
|
|
|
|
// variation 2 du left trigger
|
|
|
|
|
|
|
|
double t2;
|
|
|
|
|
|
|
|
// variation 3 du left trigger
|
|
|
|
|
|
|
|
double t3;
|
|
|
|
|
|
|
|
// le mode du robot
|
|
|
|
|
|
|
|
String mode = "normal";
|
|
|
|
|
|
|
|
// b est il déjà préssé?
|
|
|
|
|
|
|
|
boolean already_b = false;
|
|
|
|
|
|
|
|
// a est il déjà préssé?
|
|
|
|
|
|
|
|
boolean already_a = false;
|
|
|
|
|
|
|
|
// x est il déjà préssé?
|
|
|
|
|
|
|
|
boolean already_x = false;
|
|
|
|
|
|
|
|
telemetry.addData("Status", "Initialized");
|
|
|
|
|
|
|
|
telemetry.update();
|
|
|
|
|
|
|
|
lm = hardwareMap.get(DcMotor.class, "blm");
|
|
|
|
|
|
|
|
rm = hardwareMap.get(DcMotor.class, "brm");
|
|
|
|
|
|
|
|
moissoneuse = hardwareMap.get(DcMotor.class, "moissonneuse");
|
|
|
|
|
|
|
|
lmelevator = hardwareMap.get(DcMotor.class, "ltrselv");
|
|
|
|
lmelevator.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
|
|
|
|
lmelevator.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE);
|
|
|
|
|
|
|
|
rmelevator = hardwareMap.get(DcMotor.class, "rtrselv");
|
|
|
|
rmelevator.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
|
|
|
|
rmelevator.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE);
|
|
|
|
|
|
|
|
rotation = hardwareMap.get(DcMotor.class, "elvRot");
|
|
|
|
rotation.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
|
|
|
|
rotation.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE);
|
|
|
|
|
|
|
|
box = hardwareMap.get(DcMotor.class, "boxRot");
|
|
|
|
box.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
|
|
|
|
box.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE);
|
|
|
|
|
|
|
|
imu = hardwareMap.get(IMU.class, "imu");
|
|
|
|
|
|
|
|
imu.initialize(
|
|
|
|
|
|
|
|
// paramètres de l'imu
|
|
|
|
new IMU.Parameters(
|
|
|
|
// orientation initiale du robot
|
|
|
|
new RevHubOrientationOnRobot(
|
|
|
|
//logo vers le haut
|
|
|
|
RevHubOrientationOnRobot.LogoFacingDirection.UP,
|
|
|
|
//usb vers l'avant
|
|
|
|
RevHubOrientationOnRobot.UsbFacingDirection.FORWARD)));
|
|
|
|
// réinitialisation du yaw de l'imu
|
|
|
|
imu.resetYaw();
|
|
|
|
// telemetry.addData("Mode", "calibrating...");
|
|
|
|
// telemetry.update();
|
|
|
|
|
|
|
|
// make sure the imu gyro is calibrated before continuing.
|
|
|
|
// while (!isStopRequested() && !imu.isGyroCalibrated())
|
|
|
|
// {
|
|
|
|
// sleep(50);
|
|
|
|
// idle();
|
|
|
|
// }
|
|
|
|
|
|
|
|
/*
|
|
|
|
* ajout de la donnée en "mode": "en attente de démarrage" sur telemetry
|
|
|
|
*/
|
|
|
|
telemetry.addData("Mode", "waiting for start");
|
|
|
|
// telemetry.addData("imu calib status", imu.getCalibrationStatus().toString());
|
|
|
|
/*
|
|
|
|
* mise à jour de la telemetry
|
|
|
|
*/
|
|
|
|
telemetry.update();
|
|
|
|
/*
|
|
|
|
* en attente du démarrage
|
|
|
|
*/
|
|
|
|
waitForStart();
|
|
|
|
|
2024-02-11 16:15:23 +01:00
|
|
|
/*
|
2024-03-17 15:42:51 +01:00
|
|
|
* le robot a démarré, le tant que le robot est activé et donc qu'il n'a pas été
|
|
|
|
* stoppé:
|
2024-02-11 16:15:23 +01:00
|
|
|
*/
|
2024-03-17 15:42:51 +01:00
|
|
|
while (opModeIsActive()) {
|
2024-02-11 16:15:23 +01:00
|
|
|
/*
|
2024-03-17 15:42:51 +01:00
|
|
|
* définition de {@link x} sur la valeur de x du joystick gauche du gamepad 1
|
2024-02-11 16:15:23 +01:00
|
|
|
*/
|
2024-03-17 15:42:51 +01:00
|
|
|
x = gamepad1.left_stick_x;
|
2024-02-11 16:15:23 +01:00
|
|
|
/*
|
2024-03-17 15:42:51 +01:00
|
|
|
* définition de {@link y} sur la valeur de y du joystick gauche du gamepad 1
|
2024-02-11 16:15:23 +01:00
|
|
|
*/
|
2024-03-17 15:42:51 +01:00
|
|
|
y = gamepad1.left_stick_y;
|
|
|
|
/*
|
|
|
|
* définition de {@link t} sur la valeur du trigger droit du gamepad 1
|
|
|
|
*/
|
|
|
|
t = gamepad1.right_trigger;
|
|
|
|
/*
|
|
|
|
* définition de {@link t2} par utilisation de la fonction {@link helloexp} sur
|
|
|
|
* {@link t}
|
|
|
|
*/
|
|
|
|
t2 = helloexp(t);
|
|
|
|
/*
|
|
|
|
* définition de {@link t3} par utilisation de la fonction {@link helloexp} sur
|
|
|
|
* la norme du vecteur du joystick gauche du gamepad 1 (racine carrée de {@link
|
|
|
|
* x} au carré plus {@link y} au carré
|
|
|
|
*/
|
|
|
|
t3 = helloexp(Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2)));
|
|
|
|
/*
|
|
|
|
* ajout de la donnée "statut":"entrain de courrir" sur telemetry
|
|
|
|
*/
|
|
|
|
telemetry.addData("Status", "Running");
|
|
|
|
/*
|
|
|
|
* si le bouton a du gamepad 1 est appuyé et {already_a} est faux
|
|
|
|
*/
|
|
|
|
if (gamepad1.a && !already_a) {
|
|
|
|
if (mode == "normal") {
|
|
|
|
mode = "tank";
|
|
|
|
} else if (mode == "tank") {
|
|
|
|
mode = "essaifranck";
|
|
|
|
} else if (mode == "essaifranck") {
|
|
|
|
mode = "elina";
|
|
|
|
} else {
|
|
|
|
mode = "normal";
|
|
|
|
}
|
|
|
|
already_a = true;
|
|
|
|
}
|
|
|
|
if (!gamepad1.a && already_a) {
|
|
|
|
already_a = false;
|
|
|
|
}
|
|
|
|
double lpower = 0.0;
|
|
|
|
double rpower = 0.0;
|
|
|
|
if (mode == "normal") {
|
|
|
|
double ysign = y > 0 ? 1.0 : (y < 0 ? -1.0 : 0.0);
|
|
|
|
double xsign = x > 0 ? 1.0 : (x < 0 ? -1.0 : 0.0);
|
|
|
|
lpower = -ysign * t + (xsign - 2 * x) * t;
|
|
|
|
rpower = ysign * t + (xsign - 2 * x) * t;
|
|
|
|
tele("mode", "normal");
|
|
|
|
} else if (mode == "tank") {
|
|
|
|
lpower = -y;
|
|
|
|
rpower = gamepad1.right_stick_y;
|
|
|
|
tele("mode", "tank");
|
|
|
|
} else if (mode == "essaifranck") {
|
|
|
|
double a = (-y + x) / Math.pow(2, 1 / 2);
|
|
|
|
double b = (-y - x) / Math.pow(2, 1 / 2);
|
|
|
|
double vmean = (Math.abs(a) + Math.abs(b)) / 2;
|
|
|
|
lpower = (a / vmean) * t2;
|
|
|
|
rpower = (b / vmean) * t2;
|
|
|
|
tele("mode", "essai Franck");
|
|
|
|
} else if (mode == "elina") {
|
|
|
|
double a = (-y + x) / Math.pow(2, 1 / 2);
|
|
|
|
double b = (-y - x) / Math.pow(2, 1 / 2);
|
|
|
|
double vmean = (Math.abs(a) + Math.abs(b)) / 2;
|
|
|
|
lpower = (a / vmean) * t3;
|
|
|
|
rpower = (b / vmean) * t3;
|
|
|
|
tele("mode", "Elina");
|
|
|
|
}
|
|
|
|
if (!(gamepad1.left_bumper)) {
|
|
|
|
lpower /= 3;
|
|
|
|
rpower /= 3;
|
|
|
|
}
|
|
|
|
lm.setPower(lpower);
|
|
|
|
rm.setPower(rpower);
|
2024-01-07 15:55:38 +01:00
|
|
|
|
2024-03-17 15:42:51 +01:00
|
|
|
if (gamepad1.b && !already_b) {
|
2024-03-17 15:56:00 +01:00
|
|
|
double moissoneuseSpeed = 1.0;
|
|
|
|
if (gamepad1.right_bumper){
|
|
|
|
moissoneuseSpeed = -1.0;
|
|
|
|
}
|
2024-03-17 15:42:51 +01:00
|
|
|
already_b = !already_b;
|
2024-03-17 15:56:00 +01:00
|
|
|
if (moissoneuse.getPower() == moissoneuseSpeed) {
|
2024-03-17 15:42:51 +01:00
|
|
|
moissoneuse.setPower(0);
|
|
|
|
} else {
|
2024-03-17 15:56:00 +01:00
|
|
|
moissoneuse.setPower(moissoneuseSpeed);
|
2024-03-17 15:42:51 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!gamepad1.b && already_b) {
|
|
|
|
already_b = !already_b;
|
|
|
|
}
|
2024-03-17 15:56:00 +01:00
|
|
|
|
2024-01-07 16:01:20 +01:00
|
|
|
|
2024-03-17 15:42:51 +01:00
|
|
|
telemetry.addData("x", x);
|
|
|
|
telemetry.addData("y", y);
|
|
|
|
telemetry.addData("lpow", lpower);
|
|
|
|
telemetry.addData("rpow", rpower);
|
|
|
|
telemetry.addData("ltrigg", t);
|
|
|
|
telemetry.addData("t2", t2);
|
|
|
|
telemetry.addData("mode", mode);
|
|
|
|
// Create an object to receive the IMU angles
|
|
|
|
YawPitchRollAngles robotOrientation;
|
|
|
|
robotOrientation = imu.getRobotYawPitchRollAngles();
|
2024-01-07 16:01:20 +01:00
|
|
|
|
2024-03-17 15:42:51 +01:00
|
|
|
// Now use these simple methods to extract each angle
|
|
|
|
// (Java type double) from the object you just created:
|
|
|
|
double Yaw = robotOrientation.getYaw(AngleUnit.DEGREES);
|
|
|
|
double Pitch = robotOrientation.getPitch(AngleUnit.DEGREES);
|
|
|
|
double Roll = robotOrientation.getRoll(AngleUnit.DEGREES);
|
|
|
|
telemetry.addData("yaw", Yaw);
|
|
|
|
|
|
|
|
telemetry.update();
|
2024-02-11 16:15:23 +01:00
|
|
|
}
|
|
|
|
}
|
2024-01-07 15:29:01 +01:00
|
|
|
}
|