001// Copyright (c) FIRST and other WPILib contributors. 002// Open Source Software; you can modify and/or share it under the terms of 003// the WPILib BSD license file in the root directory of this project. 004 005// THIS FILE WAS AUTO-GENERATED BY ./wpilibNewCommands/generate_hids.py. DO NOT MODIFY 006 007package edu.wpi.first.wpilibj2.command.button; 008 009import edu.wpi.first.wpilibj.PS4Controller; 010import edu.wpi.first.wpilibj.event.EventLoop; 011import edu.wpi.first.wpilibj2.command.CommandScheduler; 012 013/** 014 * A version of {@link PS4Controller} with {@link Trigger} factories for command-based. 015 * 016 * @see PS4Controller 017 */ 018@SuppressWarnings("MethodName") 019public class CommandPS4Controller extends CommandGenericHID { 020 private final PS4Controller m_hid; 021 022 /** 023 * Construct an instance of a controller. 024 * 025 * @param port The port index on the Driver Station that the controller is plugged into. 026 */ 027 public CommandPS4Controller(int port) { 028 super(port); 029 m_hid = new PS4Controller(port); 030 } 031 032 /** 033 * Get the underlying GenericHID object. 034 * 035 * @return the wrapped GenericHID object 036 */ 037 @Override 038 public PS4Controller getHID() { 039 return m_hid; 040 } 041 042 /** 043 * Constructs a Trigger instance around the square button's digital signal. 044 * 045 * @return a Trigger instance representing the square button's digital signal attached 046 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 047 * @see #square(EventLoop) 048 */ 049 public Trigger square() { 050 return square(CommandScheduler.getInstance().getDefaultButtonLoop()); 051 } 052 053 /** 054 * Constructs a Trigger instance around the square button's digital signal. 055 * 056 * @param loop the event loop instance to attach the event to. 057 * @return a Trigger instance representing the square button's digital signal attached 058 * to the given loop. 059 */ 060 public Trigger square(EventLoop loop) { 061 return button(PS4Controller.Button.kSquare.value, loop); 062 } 063 064 /** 065 * Constructs a Trigger instance around the cross button's digital signal. 066 * 067 * @return a Trigger instance representing the cross button's digital signal attached 068 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 069 * @see #cross(EventLoop) 070 */ 071 public Trigger cross() { 072 return cross(CommandScheduler.getInstance().getDefaultButtonLoop()); 073 } 074 075 /** 076 * Constructs a Trigger instance around the cross button's digital signal. 077 * 078 * @param loop the event loop instance to attach the event to. 079 * @return a Trigger instance representing the cross button's digital signal attached 080 * to the given loop. 081 */ 082 public Trigger cross(EventLoop loop) { 083 return button(PS4Controller.Button.kCross.value, loop); 084 } 085 086 /** 087 * Constructs a Trigger instance around the circle button's digital signal. 088 * 089 * @return a Trigger instance representing the circle button's digital signal attached 090 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 091 * @see #circle(EventLoop) 092 */ 093 public Trigger circle() { 094 return circle(CommandScheduler.getInstance().getDefaultButtonLoop()); 095 } 096 097 /** 098 * Constructs a Trigger instance around the circle button's digital signal. 099 * 100 * @param loop the event loop instance to attach the event to. 101 * @return a Trigger instance representing the circle button's digital signal attached 102 * to the given loop. 103 */ 104 public Trigger circle(EventLoop loop) { 105 return button(PS4Controller.Button.kCircle.value, loop); 106 } 107 108 /** 109 * Constructs a Trigger instance around the triangle button's digital signal. 110 * 111 * @return a Trigger instance representing the triangle button's digital signal attached 112 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 113 * @see #triangle(EventLoop) 114 */ 115 public Trigger triangle() { 116 return triangle(CommandScheduler.getInstance().getDefaultButtonLoop()); 117 } 118 119 /** 120 * Constructs a Trigger instance around the triangle button's digital signal. 121 * 122 * @param loop the event loop instance to attach the event to. 123 * @return a Trigger instance representing the triangle button's digital signal attached 124 * to the given loop. 125 */ 126 public Trigger triangle(EventLoop loop) { 127 return button(PS4Controller.Button.kTriangle.value, loop); 128 } 129 130 /** 131 * Constructs a Trigger instance around the left trigger 1 button's digital signal. 132 * 133 * @return a Trigger instance representing the left trigger 1 button's digital signal attached 134 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 135 * @see #L1(EventLoop) 136 */ 137 public Trigger L1() { 138 return L1(CommandScheduler.getInstance().getDefaultButtonLoop()); 139 } 140 141 /** 142 * Constructs a Trigger instance around the left trigger 1 button's digital signal. 143 * 144 * @param loop the event loop instance to attach the event to. 145 * @return a Trigger instance representing the left trigger 1 button's digital signal attached 146 * to the given loop. 147 */ 148 public Trigger L1(EventLoop loop) { 149 return button(PS4Controller.Button.kL1.value, loop); 150 } 151 152 /** 153 * Constructs a Trigger instance around the right trigger 1 button's digital signal. 154 * 155 * @return a Trigger instance representing the right trigger 1 button's digital signal attached 156 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 157 * @see #R1(EventLoop) 158 */ 159 public Trigger R1() { 160 return R1(CommandScheduler.getInstance().getDefaultButtonLoop()); 161 } 162 163 /** 164 * Constructs a Trigger instance around the right trigger 1 button's digital signal. 165 * 166 * @param loop the event loop instance to attach the event to. 167 * @return a Trigger instance representing the right trigger 1 button's digital signal attached 168 * to the given loop. 169 */ 170 public Trigger R1(EventLoop loop) { 171 return button(PS4Controller.Button.kR1.value, loop); 172 } 173 174 /** 175 * Constructs a Trigger instance around the left trigger 2 button's digital signal. 176 * 177 * @return a Trigger instance representing the left trigger 2 button's digital signal attached 178 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 179 * @see #L2(EventLoop) 180 */ 181 public Trigger L2() { 182 return L2(CommandScheduler.getInstance().getDefaultButtonLoop()); 183 } 184 185 /** 186 * Constructs a Trigger instance around the left trigger 2 button's digital signal. 187 * 188 * @param loop the event loop instance to attach the event to. 189 * @return a Trigger instance representing the left trigger 2 button's digital signal attached 190 * to the given loop. 191 */ 192 public Trigger L2(EventLoop loop) { 193 return button(PS4Controller.Button.kL2.value, loop); 194 } 195 196 /** 197 * Constructs a Trigger instance around the right trigger 2 button's digital signal. 198 * 199 * @return a Trigger instance representing the right trigger 2 button's digital signal attached 200 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 201 * @see #R2(EventLoop) 202 */ 203 public Trigger R2() { 204 return R2(CommandScheduler.getInstance().getDefaultButtonLoop()); 205 } 206 207 /** 208 * Constructs a Trigger instance around the right trigger 2 button's digital signal. 209 * 210 * @param loop the event loop instance to attach the event to. 211 * @return a Trigger instance representing the right trigger 2 button's digital signal attached 212 * to the given loop. 213 */ 214 public Trigger R2(EventLoop loop) { 215 return button(PS4Controller.Button.kR2.value, loop); 216 } 217 218 /** 219 * Constructs a Trigger instance around the share button's digital signal. 220 * 221 * @return a Trigger instance representing the share button's digital signal attached 222 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 223 * @see #share(EventLoop) 224 */ 225 public Trigger share() { 226 return share(CommandScheduler.getInstance().getDefaultButtonLoop()); 227 } 228 229 /** 230 * Constructs a Trigger instance around the share button's digital signal. 231 * 232 * @param loop the event loop instance to attach the event to. 233 * @return a Trigger instance representing the share button's digital signal attached 234 * to the given loop. 235 */ 236 public Trigger share(EventLoop loop) { 237 return button(PS4Controller.Button.kShare.value, loop); 238 } 239 240 /** 241 * Constructs a Trigger instance around the options button's digital signal. 242 * 243 * @return a Trigger instance representing the options button's digital signal attached 244 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 245 * @see #options(EventLoop) 246 */ 247 public Trigger options() { 248 return options(CommandScheduler.getInstance().getDefaultButtonLoop()); 249 } 250 251 /** 252 * Constructs a Trigger instance around the options button's digital signal. 253 * 254 * @param loop the event loop instance to attach the event to. 255 * @return a Trigger instance representing the options button's digital signal attached 256 * to the given loop. 257 */ 258 public Trigger options(EventLoop loop) { 259 return button(PS4Controller.Button.kOptions.value, loop); 260 } 261 262 /** 263 * Constructs a Trigger instance around the L3 (left stick) button's digital signal. 264 * 265 * @return a Trigger instance representing the L3 (left stick) button's digital signal attached 266 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 267 * @see #L3(EventLoop) 268 */ 269 public Trigger L3() { 270 return L3(CommandScheduler.getInstance().getDefaultButtonLoop()); 271 } 272 273 /** 274 * Constructs a Trigger instance around the L3 (left stick) button's digital signal. 275 * 276 * @param loop the event loop instance to attach the event to. 277 * @return a Trigger instance representing the L3 (left stick) button's digital signal attached 278 * to the given loop. 279 */ 280 public Trigger L3(EventLoop loop) { 281 return button(PS4Controller.Button.kL3.value, loop); 282 } 283 284 /** 285 * Constructs a Trigger instance around the R3 (right stick) button's digital signal. 286 * 287 * @return a Trigger instance representing the R3 (right stick) button's digital signal attached 288 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 289 * @see #R3(EventLoop) 290 */ 291 public Trigger R3() { 292 return R3(CommandScheduler.getInstance().getDefaultButtonLoop()); 293 } 294 295 /** 296 * Constructs a Trigger instance around the R3 (right stick) button's digital signal. 297 * 298 * @param loop the event loop instance to attach the event to. 299 * @return a Trigger instance representing the R3 (right stick) button's digital signal attached 300 * to the given loop. 301 */ 302 public Trigger R3(EventLoop loop) { 303 return button(PS4Controller.Button.kR3.value, loop); 304 } 305 306 /** 307 * Constructs a Trigger instance around the PlayStation button's digital signal. 308 * 309 * @return a Trigger instance representing the PlayStation button's digital signal attached 310 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 311 * @see #PS(EventLoop) 312 */ 313 public Trigger PS() { 314 return PS(CommandScheduler.getInstance().getDefaultButtonLoop()); 315 } 316 317 /** 318 * Constructs a Trigger instance around the PlayStation button's digital signal. 319 * 320 * @param loop the event loop instance to attach the event to. 321 * @return a Trigger instance representing the PlayStation button's digital signal attached 322 * to the given loop. 323 */ 324 public Trigger PS(EventLoop loop) { 325 return button(PS4Controller.Button.kPS.value, loop); 326 } 327 328 /** 329 * Constructs a Trigger instance around the touchpad button's digital signal. 330 * 331 * @return a Trigger instance representing the touchpad button's digital signal attached 332 * to the {@link CommandScheduler#getDefaultButtonLoop() default scheduler button loop}. 333 * @see #touchpad(EventLoop) 334 */ 335 public Trigger touchpad() { 336 return touchpad(CommandScheduler.getInstance().getDefaultButtonLoop()); 337 } 338 339 /** 340 * Constructs a Trigger instance around the touchpad button's digital signal. 341 * 342 * @param loop the event loop instance to attach the event to. 343 * @return a Trigger instance representing the touchpad button's digital signal attached 344 * to the given loop. 345 */ 346 public Trigger touchpad(EventLoop loop) { 347 return button(PS4Controller.Button.kTouchpad.value, loop); 348 } 349 350 /** 351 * Get the X axis value of left side of the controller. 352 * 353 * @return The axis value. 354 */ 355 public double getLeftX() { 356 return m_hid.getLeftX(); 357 } 358 359 /** 360 * Get the Y axis value of left side of the controller. 361 * 362 * @return The axis value. 363 */ 364 public double getLeftY() { 365 return m_hid.getLeftY(); 366 } 367 368 /** 369 * Get the X axis value of right side of the controller. 370 * 371 * @return The axis value. 372 */ 373 public double getRightX() { 374 return m_hid.getRightX(); 375 } 376 377 /** 378 * Get the Y axis value of right side of the controller. 379 * 380 * @return The axis value. 381 */ 382 public double getRightY() { 383 return m_hid.getRightY(); 384 } 385 386 /** 387 * Get the left trigger 2 axis value of the controller. Note that this axis is bound to the 388 * range of [0, 1] as opposed to the usual [-1, 1]. 389 * 390 * @return The axis value. 391 */ 392 public double getL2Axis() { 393 return m_hid.getL2Axis(); 394 } 395 396 /** 397 * Get the right trigger 2 axis value of the controller. Note that this axis is bound to the 398 * range of [0, 1] as opposed to the usual [-1, 1]. 399 * 400 * @return The axis value. 401 */ 402 public double getR2Axis() { 403 return m_hid.getR2Axis(); 404 } 405}