USB Host Shield 2.0
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
PS3USB.h
Go to the documentation of this file.
1 /* Copyright (C) 2012 Kristian Lauszus, TKJ Electronics. All rights reserved.
2 
3  This software may be distributed and modified under the terms of the GNU
4  General Public License version 2 (GPL2) as published by the Free Software
5  Foundation and appearing in the file GPL2.TXT included in the packaging of
6  this file. Please note that GPL2 Section 2[b] requires that all works based
7  on this software must also be made publicly available under the terms of
8  the GPL2 ("Copyleft").
9 
10  Contact information
11  -------------------
12 
13  Kristian Lauszus, TKJ Electronics
14  Web : http://www.tkjelectronics.com
15  e-mail : kristianl@tkjelectronics.com
16  */
17 
18 #ifndef _ps3usb_h_
19 #define _ps3usb_h_
20 
21 #if defined(ARDUINO) && ARDUINO >= 100
22 #include "Arduino.h"
23 #else
24 #include "WProgram.h"
25 #endif
26 
27 #include "Usb.h"
28 #include "PS3Enums.h"
29 
30 /* PS3 data taken from descriptors */
31 #define EP_MAXPKTSIZE 64 // max size for data via USB
32 
33 /* Endpoint types */
34 #define EP_INTERRUPT 0x03
35 
36 /* Names we give to the 3 ps3 pipes - this is only used for setting the bluetooth address into the ps3 controllers */
37 #define PS3_CONTROL_PIPE 0
38 #define PS3_OUTPUT_PIPE 1
39 #define PS3_INPUT_PIPE 2
40 
41 //PID and VID of the different devices
42 #define PS3_VID 0x054C // Sony Corporation
43 #define PS3_PID 0x0268 // PS3 Controller DualShock 3
44 #define PS3NAVIGATION_PID 0x042F // Navigation controller
45 #define PS3MOVE_PID 0x03D5 // Motion controller
46 
47 // used in control endpoint header for HID Commands
48 #define bmREQ_HID_OUT USB_SETUP_HOST_TO_DEVICE|USB_SETUP_TYPE_CLASS|USB_SETUP_RECIPIENT_INTERFACE
49 #define HID_REQUEST_SET_REPORT 0x09
50 
51 #define PS3_MAX_ENDPOINTS 3
52 
61 class PS3USB : public USBDeviceConfig {
62 public:
70  PS3USB(USB *pUsb, uint8_t btadr5 = 0, uint8_t btadr4 = 0, uint8_t btadr3 = 0, uint8_t btadr2 = 0, uint8_t btadr1 = 0, uint8_t btadr0 = 0);
71 
80  virtual uint8_t Init(uint8_t parent, uint8_t port, bool lowspeed);
85  virtual uint8_t Release();
90  virtual uint8_t Poll();
91 
96  virtual uint8_t GetAddress() {
97  return bAddress;
98  };
99 
104  virtual bool isReady() {
105  return bPollEnable;
106  };
107 
114  virtual boolean VIDPIDOK(uint16_t vid, uint16_t pid) {
115  return (vid == PS3_VID && (pid == PS3_PID || pid == PS3NAVIGATION_PID || pid == PS3MOVE_PID));
116  };
123  void setBdaddr(uint8_t* BDADDR);
128  void setMoveBdaddr(uint8_t* BDADDR);
129 
139  bool getButtonPress(Button b);
140  bool getButtonClick(Button b);
151  uint8_t getAnalogButton(Button a);
157  uint8_t getAnalogHat(AnalogHat a);
164  uint16_t getSensor(Sensor a);
170  double getAngle(Angle a);
176  bool getStatus(Status c);
181  String getStatusString();
182 
184  void setAllOff();
186  void setRumbleOff();
191  void setRumbleOn(Rumble mode);
199  void setRumbleOn(uint8_t rightDuration, uint8_t rightPower, uint8_t leftDuration, uint8_t leftPower);
200 
205  void setLedRaw(uint8_t value);
210  void setLedOff(LED a);
215  void setLedOn(LED a);
220  void setLedToggle(LED a);
221 
226  void moveSetBulb(uint8_t r, uint8_t g, uint8_t b);
231  void moveSetBulb(Colors color);
236  void moveSetRumble(uint8_t rumble);
237 
242  void attachOnInit(void (*funcOnInit)(void)) {
243  pFuncOnInit = funcOnInit;
244  };
248  bool PS3Connected;
253 
254 protected:
258  uint8_t bAddress;
261 
262 private:
268  void onInit();
269  void (*pFuncOnInit)(void); // Pointer to function called in onInit()
270 
271  bool bPollEnable;
272 
273  uint32_t timer; // used to continuously set PS3 Move controller Bulb and rumble values
274 
275  uint32_t ButtonState;
276  uint32_t OldButtonState;
277  uint32_t ButtonClickState;
278 
279  uint8_t my_bdaddr[6]; // Change to your dongles Bluetooth address in the constructor
280  uint8_t readBuf[EP_MAXPKTSIZE]; // General purpose buffer for input data
281  uint8_t writeBuf[EP_MAXPKTSIZE]; // General purpose buffer for output data
282 
283  void readReport(); // read incoming data
284  void printReport(); // print incoming date - Uncomment for debugging
285 
286  /* Private commands */
287  void PS3_Command(uint8_t* data, uint16_t nbytes);
288  void enable_sixaxis(); // Command used to enable the Dualshock 3 and Navigation controller to send data via USB
289  void Move_Command(uint8_t* data, uint16_t nbytes);
290 };
291 #endif