This commit is contained in:
Zelina974 2024-05-20 17:08:50 +02:00
parent 1eeff6a40c
commit 335f8b3e89
2 changed files with 148 additions and 87 deletions

42
fgc2024Pilotage.java Normal file
View file

@ -0,0 +1,42 @@
package org.firstinspires.ftc.teamcode;
import com.qualcomm.robotcore.eventloop.opmode.LinearOpMode;
import org.firstinspires.ftc.robotcore.external.navigation.YawPitchRollAngles;
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;
import com.qualcomm.robotcore.hardware.IMU;
import com.qualcomm.robotcore.hardware.ImuOrientationOnRobot;
import com.qualcomm.hardware.rev.RevHubOrientationOnRobot;
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;
@TeleOp(name = "WeRobot: FTC2024 NEW! Carlike", group = "WeRobot")
public class WEROBOT_FTC2024_New_carlike extends LinearOpMode {
private DcMotorEx rm;
private DcMotorEx lm;
@Override
public void runOpMode() throws InterruptedException {
float x; // abscisse joystick gauche
double y; // ordonnées joystick gauche
telemetry.addData("Status"," Initialized");
}
}

View file

@ -3,6 +3,7 @@ package org.firstinspires.ftc.teamcode;
//import FTC2024WeRobotControl; //a tester car pas sur que ça fonctionne //import FTC2024WeRobotControl; //a tester car pas sur que ça fonctionne
import com.qualcomm.robotcore.eventloop.opmode.LinearOpMode; import com.qualcomm.robotcore.eventloop.opmode.LinearOpMode;
import com.qualcomm.robotcore.eventloop.opmode.OpMode;
import com.qualcomm.robotcore.hardware.DcMotorEx; import com.qualcomm.robotcore.hardware.DcMotorEx;
import com.qualcomm.robotcore.hardware.IMU; import com.qualcomm.robotcore.hardware.IMU;
@ -22,28 +23,27 @@ import com.qualcomm.robotcore.util.ElapsedTime;
@Autonomous @Autonomous
public class Ftc2024_autonome_last extends LinearOpMode { public class lastmatch extends LinearOpMode {
public enum AutoMode {
B2D, B4D
}
public AutoMode autonomous_mode = B2D; public DcMotorEx lm;
public DcMotor lm; public DcMotorEx rm;
public DcMotor rm;
public DcMotorEx lmelevator; public DcMotorEx lmelevator;
public DcMotorEx rmelevator; public DcMotorEx rmelevator;
public DcMotor harvestmotor; public DcMotor harvestmotor;
public IMU imu; public IMU imu;
public DcMotorEx rotation; public DcMotorEx rotation;
private ElapsedTime timer;
@Override @Override
public void runOpMode() { public void runOpMode() {
timer = new ElapsedTime();
boolean auto = false; boolean auto = false;
lm = hardwareMap.get(DcMotor.class, "blm"); lm = hardwareMap.get(DcMotorEx.class, "blm");
rm = hardwareMap.get(DcMotor.class, "brm"); rm = hardwareMap.get(DcMotorEx.class, "brm");
harvestmotor = hardwareMap.get(DcMotor.class, "moissonneuse"); harvestmotor = hardwareMap.get(DcMotor.class, "moissonneuse");
rotation = hardwareMap.get(DcMotorEx.class, "elvRot"); rotation = hardwareMap.get(DcMotorEx.class, "elvRot");
rotation.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
lmelevator = hardwareMap.get(DcMotorEx.class, "ltrselv"); lmelevator = hardwareMap.get(DcMotorEx.class, "ltrselv");
lmelevator.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER); lmelevator.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
lmelevator.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE); lmelevator.setZeroPowerBehavior(DcMotor.ZeroPowerBehavior.BRAKE);
@ -64,7 +64,6 @@ public class Ftc2024_autonome_last extends LinearOpMode {
imu.resetYaw(); imu.resetYaw();
YawPitchRollAngles robotOrientation; YawPitchRollAngles robotOrientation;
FTC2024WeRobotControl robot = new FTC2024WeRobotControl(this); FTC2024WeRobotControl robot = new FTC2024WeRobotControl(this);
autonomous_mode = AutoMode.B4D;
telemetry.addData("wait for start", ""); telemetry.addData("wait for start", "");
telemetry.update(); telemetry.update();
@ -81,49 +80,69 @@ public class Ftc2024_autonome_last extends LinearOpMode {
} }
} }
if (opModeIsActive()) { if (opModeIsActive()) {
/* double motor_speed = 1.0;
* autonomous_mode differents possibles values respect the next scheme: lmelevator.setVelocity(600);
* team_color_shortcode + start_line_index + direct_or_no rmelevator.setVelocity(600);
* lmelevator.setTargetPosition(200);
* team_color_shortcode = "b" for blue & "r" for red rmelevator.setTargetPosition(200);
* start_line_index = 4 or 2 see competition manual appendix B Tile location rotation.setVelocity(600);
* plan rotation.setTargetPosition(40);
* direct_or_no = "d" to direct go to pixel deliver zone or "n" to harvest lmelevator.setMode(DcMotor.RunMode.RUN_TO_POSITION);
* pixels before to go in deliver zone rmelevator.setMode(DcMotor.RunMode.RUN_TO_POSITION);
* rotation.setMode(DcMotor.RunMode.RUN_TO_POSITION);
* default is "b4d" sleep(2000);
*/
lm.setMode(DcMotor.RunMode.RUN_WITHOUT_ENCODER);
rm.setMode(DcMotor.RunMode.RUN_WITHOUT_ENCODER);
double total_time = robot.time_for_dist(1 * robot.ground_tiles_width, Math.abs(motor_speed));
timer.reset();
while (opModeIsActive() && timer.seconds() < total_time) {
lm.setPower(motor_speed);
rm.setPower(motor_speed);
}
lm.setPower(0);
rm.setPower(0);
harvestmotor.setPower(-0.6);
lm.setMode(DcMotor.RunMode.RUN_WITHOUT_ENCODER);
rm.setMode(DcMotor.RunMode.RUN_WITHOUT_ENCODER);
total_time = robot.time_for_dist(0.7 * robot.ground_tiles_width, Math.abs(motor_speed));
timer.reset();
while (opModeIsActive() && timer.seconds() < total_time) {
lm.setPower(-motor_speed);
rm.setPower(-motor_speed);
}
lm.setPower(0);
rm.setPower(0);
double angle = 90.0;
lm.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
rm.setMode(DcMotor.RunMode.STOP_AND_RESET_ENCODER);
double perimeter = Math.toRadians(angle)* 37.0/2.0;
int targetPos = (int) Math.floor(perimeter/(9e-2*Math.PI));
targetPos = targetPos * 20;
rm.setTargetPosition(targetPos);
lm.setTargetPosition(-targetPos);
lm.setVelocity(600);
rm.setVelocity(600);
lm.setMode(DcMotor.RunMode.RUN_TO_POSITION);
rm.setMode(DcMotor.RunMode.RUN_TO_POSITION);
// while (Math.abs(lm.getCurrentPosition() - targetPos)>=2){}
motor_speed= 1;
lm.setMode(DcMotor.RunMode.RUN_WITHOUT_ENCODER);
rm.setMode(DcMotor.RunMode.RUN_WITHOUT_ENCODER);
total_time = robot.time_for_dist(1.5 * robot.ground_tiles_width, Math.abs(motor_speed));
timer.reset();
while (opModeIsActive() && timer.seconds() < total_time) {
lm.setPower(motor_speed);
rm.setPower(motor_speed);
}
lm.setPower(0);
rm.setPower(0);
switch (autonomous_mode) {
default:
robot.boxElv();
robot.harvest(1);
robot.forward(2);
/*
* robot.harvest(0);
* robot.rotate((-90));
* robot.posBasse();
* robot.forward(3.5);
* robot.harvest(-1);
* robot.backward(0.5);
* robot.harvest(0);
* robot.forward(0.5);
*/
break;
case B2D:
robot.posBasse();
robot.harvest(1);
robot.forward(1);
robot.harvest(0);
/*
* robot.forward(1);
* robot.harvest(-1);
* robot.backward(0.5);
* robot.harvest(0);
* robot.forward(0.5);
*/
break;
}
} }
} }
} }