Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: Motor PID Joystick_OrdoV5 mbed millis
Fork of MainProgram_BaseBaru_13FebV2 by
Diff: PS3Arduino.txt
- Revision:
- 2:ac21a024ac80
- Parent:
- 0:9072e932503c
- Child:
- 12:e07c59c28c29
diff -r 56bd3e8f38c5 -r ac21a024ac80 PS3Arduino.txt
--- a/PS3Arduino.txt Sat Jun 06 06:19:06 2015 +0000
+++ b/PS3Arduino.txt Sat Jun 27 07:37:28 2015 +0000
@@ -7,23 +7,33 @@
/** Fanny Achmad Hindrarta **/
/** EL'12 - 13212076 **/
/** **/
-/** Last Update : 15 Januari 2015, 20.30 **/
+/** Last Update : 01 Februar1 2015, 20.30 **/
/*********************************************************************************************/
#include <PS3BT.h>
#include <usbhub.h>
+//#include <PS3USB.h>
#include "Arduino.h"
// Satisfy IDE, which only needs to see the include statment in the ino.
#ifdef dobogusinclude
#include <spi4teensy3.h>
#endif
+
USB Usb;
-/* You can create the instance of the class in two ways */
+
+// Bluetooth
+// You can create the instance of the class in two ways
BTD Btd(&Usb); // You have to create the Bluetooth Dongle instance like so
-/* You can create the instance of the class in two ways */
+//You can create the instance of the class in two ways
PS3BT PS3(&Btd); // This will just create the instance
//PS3BT PS3(&Btd, 0x00, 0x15, 0x83, 0x3D, 0x0A, 0x57); // This will also store the bluetooth address - this can be obtained from the dongle when running the sketch
+/*
+// USB
+// You can create the instance of the class in two ways
+PS3USB PS3(&Usb); // This will just create the instance
+//PS3USB PS3(&Btd, 0x00, 0x15, 0x83, 0x3D, 0x0A, 0x57); // This will also store the bluetooth address - this can be obtained from the dongle when running the sketch
+*/
boolean printAngle;
uint8_t state = 0;
@@ -45,12 +55,20 @@
void setup_joystik()
{
- while (!Serial); // Wait for serial port to connect - used on Leonardo, Teensy and other boards with built-in USB CDC serial connection
+ while (!Serial) // Wait for serial port to connect - used on Leonardo, Teensy and other boards with built-in USB CDC serial connection
+ {
+ Serial.write(0x88);
+ Serial.write(0x09);
+ }
if (Usb.Init() == -1) {
- Serial.print(F("\r\nOSC did not start"));
- while (1); //halt
+ //Serial.print(F("\r\nOSC did not start"));
+ while (1) //halt
+ {
+ Serial.write(0x88);
+ Serial.write(0x09);
+ }
}
- Serial.print(F("\r\nPS3 USB Library Started"));
+ //Serial.print(F("\r\nPS3 USB Library Started"));
}
/*********************************************************************************************/
@@ -78,6 +96,7 @@
Serial.write(RY);
Serial.write(LX);
Serial.write(LY);
+
// Debug
/*
@@ -153,7 +172,8 @@
void loop() {
button = 0;
RL = 0;
-
+ button_click=0;
+ RL_click=0;
Usb.Task();
// Pembacaan data joystik dilakukan jika PS3 tersambung ke Arduino
@@ -212,58 +232,52 @@
// Pembacaan dan penggabungan data segitiga, lingkaran, silang, kotak, atas, kanan, bawah, kiri
// Data bernilai '1' hanya saat tombol pertama kali ditekan
if(PS3.getButtonClick(TRIANGLE)){
- segitiga_click = !segitiga_click;
+ button_click = button_click + (0x1 << 0);
}
if(PS3.getButtonClick(CIRCLE)){
- lingkaran_click = !lingkaran_click;
+ button_click = button_click + (0x1 << 1);
}
if(PS3.getButtonClick(CROSS)){
- silang_click = !silang_click;
+ button_click = button_click + (0x1 << 2);
}
if(PS3.getButtonClick(SQUARE)){
- kotak_click = !kotak_click;
+ button_click = button_click + (0x1 << 3);
}
if(PS3.getButtonClick(UP)){
- atas_click = !atas_click;
+ button_click = button_click + (0x1 << 4);
}
if(PS3.getButtonClick(RIGHT)){
- kanan_click = !kanan_click;
+ button_click = button_click + (0x1 << 5);
}
if(PS3.getButtonClick(DOWN)){
- bawah_click = !bawah_click;
+ button_click = button_click + (0x1 << 6);
}
if(PS3.getButtonClick(LEFT)){
- kiri_click = !kiri_click;
+ button_click = button_click + (0x1 << 7);
}
- button_click = 0;
- button_click = (segitiga_click << 0) + (lingkaran_click << 1) + (silang_click << 2) + (kotak_click << 3) + (atas_click << 4) + (kanan_click << 5) + (bawah_click << 6) + (kiri_click << 7);
-
if(PS3.getButtonClick(R1)){
- R1_click = !R1_click;
+ RL_click = RL_click + (0x1 << 0);
}
if(PS3.getButtonClick(R3)){
- R3_click = !R3_click;
+ RL_click = RL_click + (0x1 << 1);
}
if(PS3.getButtonClick(L1)){
- L1_click = !L1_click;
+ RL_click = RL_click + (0x1 << 2);
}
if(PS3.getButtonClick(L3)){
- L3_click = !L3_click;
+ RL_click = RL_click + (0x1 << 3);
}
if(PS3.getButtonClick(START)){
- START_click = !START_click;
+ RL_click = RL_click + (0x1 << 4);
}
if(PS3.getButtonClick(SELECT)){
- SELECT_click = !SELECT_click;
+ RL_click = RL_click + (0x1 << 5);
}
if(PS3.getButtonClick(PS)){
- PS_click = !PS_click;
+ RL_click = RL_click + (0x1 << 6);
}
- RL_click = 0;
- RL_click = (R1_click << 0) + (R3_click << 1) + (L1_click << 2) + (L3_click << 3) + (START_click << 4) + (SELECT_click << 5) + (PS_click << 6);
-
// Tombol Analog
LX = PS3.getAnalogHat(LeftHatX);
LY = PS3.getAnalogHat(LeftHatY);
@@ -272,12 +286,12 @@
aL2 = PS3.getAnalogButton(L2);
aR2 = PS3.getAnalogButton(R2);
+
+ kirimdatajoystik();
} else {
// PS3 Disconnected
Serial.write(0x88);
Serial.write(0x09);
}
-
- kirimdatajoystik();
- delay(5);
-}
\ No newline at end of file
+ delay(3);
+}
