forked from FIRST-Tech-Challenge/FtcRobotController
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFreightTeleOp2.java
162 lines (136 loc) · 6.86 KB
/
FreightTeleOp2.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
package org.firstinspires.ftc.teamcode;
// A two-player teleop.
// Player 1 controls only driving,
// while player 2 controls the arm, claw, wrist and carousel spinner.
import com.qualcomm.hardware.bosch.BNO055IMU;
import com.qualcomm.hardware.bosch.JustLoggingAccelerationIntegrator;
import com.qualcomm.robotcore.eventloop.opmode.OpMode;
import com.qualcomm.robotcore.eventloop.opmode.TeleOp;
import com.qualcomm.robotcore.hardware.CRServo;
import com.qualcomm.robotcore.hardware.DcMotor;
import com.qualcomm.robotcore.hardware.Servo;
import org.firstinspires.ftc.teamcode.dependencies.Arm.ArmPosition;
import org.firstinspires.ftc.teamcode.dependencies.ClawWithWristArm;
import org.firstinspires.ftc.teamcode.dependencies.ClawWithWristArmStickyPositions;
@TeleOp(name="Freight TeleOps 2 Player", group="TeleOp")
public class FreightTeleOp2 extends OpMode {
DcMotor left;
DcMotor right;
DcMotor spinny;
ClawWithWristArm arm;
BNO055IMU imu;
public void init() {
left = hardwareMap.dcMotor.get("left");
right = hardwareMap.dcMotor.get("right");
spinny = hardwareMap.dcMotor.get("spinny");
imu = hardwareMap.get(BNO055IMU.class, "imu");
arm = new ClawWithWristArm(
hardwareMap.get(DcMotor.class, "arm"),
hardwareMap.get(CRServo.class, "scoop"),
hardwareMap.get(Servo.class, "wrist"));
// IMU, used for orientation
BNO055IMU.Parameters parameters = new BNO055IMU.Parameters();
parameters.angleUnit = BNO055IMU.AngleUnit.DEGREES;
parameters.accelUnit = BNO055IMU.AccelUnit.METERS_PERSEC_PERSEC;
parameters.loggingEnabled = true;
parameters.loggingTag = "IMU";
parameters.accelerationIntegrationAlgorithm = new JustLoggingAccelerationIntegrator();
imu.initialize(parameters);
currentArmPosition = ArmPosition.NEUTRAL;
}
long timeSinceCycleStart;
double maxSpeed = 1.0;
ArmPosition currentArmPosition;
public void loop() {
telemetry.clearAll();
// ==== GAMEPAD 1 - Driving (Alex)
// Store power from joystick values
double leftInput = gamepad1.right_stick_x;
double rightInput = gamepad1.left_stick_y;
double leftSpd = leftInput + rightInput;
double rightSpd = leftInput - rightInput;
// Use bumpers and/or triggers to decrease movement speed
// Left bumper/trigger decrease speed to 50%
// Right bumper/trigger decrease speed to 25%
// WHen both are held at once, decrease speed to 12.5%
boolean slowLeft = gamepad1.left_bumper || gamepad1.left_trigger>0;
boolean slowRight = gamepad1.right_bumper || gamepad1.right_trigger>0;
if(slowRight && slowLeft){
maxSpeed = 0.125; // L+R = 12.5% speed
} else if (slowRight) {
maxSpeed = 0.25; // R = 25% speed
} else if (slowLeft) {
maxSpeed = 0.5; // L = 50% speed
} else {
maxSpeed = 1.0; // None = 100% speed
}
// Set drive power quadratically and scale with maxSpeed
left.setPower(leftSpd * Math.abs(leftSpd) * maxSpeed);
right.setPower(rightSpd * Math.abs(rightSpd) * maxSpeed);
// ==== GAMEPAD 2 - Arm (Jack)
// DPAD UP/DOWN - Spin Carousel
// LEFT STICK UP/DOWN - Wrist Up/Down
// LEFT STICK LEFT/RIGHT - Wrist Cap Position
// A/B/C/D - Neutral -> Three Arm Levels
// ANY BUMPER - Hold to Enable Back arm levels.
// LEFT STICK UP/DOWN - Tune arm Up/Down.
// LEFT STICK LEFT/RIGHT - Tunes Arm Power.
// If a bumper or back button is held while a button is pressed, the arm is moved to its backwards variant
boolean backArm = gamepad2.left_bumper || gamepad2.right_bumper || gamepad2.back;
// Move to appropriate location based on button pressed and left bumper state
if(gamepad2.a){
currentArmPosition = backArm ? ArmPosition.BACK_NEUTRAL : ArmPosition.NEUTRAL;
}else if(gamepad2.x){
currentArmPosition = backArm ? ArmPosition.BACK_ONE : ArmPosition.ONE;
}else if(gamepad2.y){
currentArmPosition = backArm ? ArmPosition.BACK_TWO : ArmPosition.TWO;
}else if(gamepad2.b){
currentArmPosition = backArm ? ArmPosition.BACK_THREE : ArmPosition.THREE;
}else if (gamepad2.left_stick_button || gamepad2.right_stick_button || gamepad2.start){
currentArmPosition = ArmPosition.CAP;
}
// Left stick's X can tune the arm slightly up and down from its desired tick location.
// Left stick's Y decreases the power of the arm, to prevent it from overshooting.
arm.moveToPosition(currentArmPosition.ticks + (int)(gamepad2.left_stick_y * 50),
0.7 * (1 - Math.abs(gamepad2.left_stick_x)));
// Claw - Right trigger to close hand, left trigger to open hand. Works analogously
arm.setHandPower(gamepad2.right_trigger - gamepad2.left_trigger);
// Wrist - Move with right joystick. Up Up to flip wrist up, down to flip wrist down, side to go to cap position
if (gamepad2.right_stick_y < -0.6){
arm.wristUp();
} else if (gamepad2.right_stick_y > 0.6) {
arm.wristDown();
} else if (Math.abs(gamepad2.right_stick_x) > 0.6){
arm.wristCap();
}
// ( Only run when using ClawWithWristArmStickyPositions, comment out if not )
// Spinny - When not being held, time start is set to current time millis.
// When the button is held, the timer is not reset and allowed to run.
// Whenever the current time exceeds the timer start value plus a certain amount,
// the wheel will spin fast to boost the duck off the carousel against the metal bar.
// Blue side
if(gamepad2.dpad_up || gamepad1.dpad_up){
spinny.setPower(isFastSpeed() ? -0.44 : -0.22);
}
// Red side
else if(gamepad2.dpad_down || gamepad1.dpad_down){
spinny.setPower(isFastSpeed() ? 0.44 : 0.22);
} else {
timeSinceCycleStart = System.currentTimeMillis();
spinny.setPower(0);
}
// == Telemetry
telemetry.addLine(String.format("A: %s, B: %s, X: %s, Y: %s",
gamepad2.a, gamepad2.b, gamepad2.x, gamepad2.y));
telemetry.addData("left_trigger: ", gamepad2.left_trigger);
telemetry.addData("right_trigger: ", gamepad2.right_trigger);
telemetry.addData("arm position: ", arm.getArmMotor().getCurrentPosition());
telemetry.addData("hand power: ", arm.getClaw().getPower());
telemetry.addData("wrist position: ", arm.getWrist().getPosition());
telemetry.update();
}
private boolean isFastSpeed(){
return false;
// return System.currentTimeMillis() > timeSinceCycleStart+1250 || gamepad1.left_bumper;
}
}