Code to detect hand movement for use in video game

Dependencies:   LSM9DS1_Library_cal XBee mbed

Files at this revision

API Documentation at this revision

Comitter:
jgensel3
Date:
Mon Apr 24 04:14:25 2017 +0000
Commit message:
Code to detect hand movement for game

Changed in this revision

LSM9DS1_Library_cal.lib Show annotated file Show diff for this revision Revisions of this file
Wireless.h Show annotated file Show diff for this revision Revisions of this file
XBee.lib Show annotated file Show diff for this revision Revisions of this file
main.cpp Show annotated file Show diff for this revision Revisions of this file
mbed.bld Show annotated file Show diff for this revision Revisions of this file
diff -r 000000000000 -r fa587f2eec11 LSM9DS1_Library_cal.lib
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/LSM9DS1_Library_cal.lib	Mon Apr 24 04:14:25 2017 +0000
@@ -0,0 +1,1 @@
+https://developer.mbed.org/users/jgensel3/code/LSM9DS1_Library_cal/#2c98369b783c
diff -r 000000000000 -r fa587f2eec11 Wireless.h
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/Wireless.h	Mon Apr 24 04:14:25 2017 +0000
@@ -0,0 +1,81 @@
+#ifndef WProtocol_h
+#define WProtocol_h
+
+#include "XBee/XBee.h"
+#include <mbed.h>
+
+#define HOST_ADDRESS 0x0003
+
+enum Direction {DIR_UP, DIR_DOWN, DIR_LEFT, DIR_RIGHT, DIR_NONE, A_BUTTON, B_BUTTON};
+enum WMessageType {FOOT_STEP, HAND_GESTURE};
+
+typedef struct WMessage {
+    WMessageType type;
+    Direction direction;
+} WMessage_t;
+
+class WirelessModule {
+public:
+    WirelessModule(PinName tx, PinName rx, WMessageType type) :
+        uart(tx, rx), xbee(uart),
+        tx16req(HOST_ADDRESS, (uint8_t *) &message, sizeof(message))
+    {
+        uart.baud(9600);
+        message.type = type;
+    }
+
+    int sendDirection(Direction dir) {
+        message.direction = dir;
+        xbee.send(tx16req);
+        return 0;
+    }
+private:
+    RawSerial uart;
+    XBee xbee;
+    WMessage_t message;
+    Tx16Request tx16req;
+};
+
+class WirelessHost {
+public:
+    WirelessHost(PinName tx, PinName rx) : uart(tx, rx), xbee(uart) {}
+
+    int waitForMessage(WMessage_t *store) {
+        xbee.readPacket(5000);
+
+        if (xbee.getResponse().isError()) {
+            // API error
+            return -99;
+        }
+
+        if (xbee.getResponse().isAvailable()) {
+            if (xbee.getResponse().getApiId() != RX_16_RESPONSE) {
+                // Unexpected API message
+                return -5;
+            }
+
+            // Retrieve response
+            xbee.getResponse().getRx16Response(rx16resp);
+
+            // Validate packet length
+            if (rx16resp.getDataLength() == sizeof(WMessage_t)) {
+                // Store the payload
+                memcpy(store, rx16resp.getData(), sizeof(WMessage_t));
+                return 0;
+            } else {
+                // Unexpected payload format
+                return -10;
+            }
+        } else {
+            // No Response
+            return -1;
+        }
+    }
+
+private:
+    RawSerial uart;
+    XBee xbee;
+    Rx16Response rx16resp;
+};
+
+#endif
\ No newline at end of file
diff -r 000000000000 -r fa587f2eec11 XBee.lib
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/XBee.lib	Mon Apr 24 04:14:25 2017 +0000
@@ -0,0 +1,1 @@
+http://developer.mbed.org/users/lucasec/code/XBee/#350d308e7b77
diff -r 000000000000 -r fa587f2eec11 main.cpp
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/main.cpp	Mon Apr 24 04:14:25 2017 +0000
@@ -0,0 +1,82 @@
+#include "mbed.h"
+#include "LSM9DS1.h"
+#include "Wireless.h"
+#define PI 3.14159
+// Earth's magnetic field varies by location. Add or subtract
+// a declination to get a more accurate heading. Calculate
+// your's here:
+// http://www.ngdc.noaa.gov/geomag-web/#declination
+#define DECLINATION -4.94 // Declination (degrees) in Atlanta,GA.
+
+DigitalOut myled(LED1);
+Serial pc(USBTX, USBRX);
+InterruptIn pb(p21);
+InterruptIn pb2(p5);
+WirelessModule wireless(p28, p27, HAND_GESTURE);
+
+void pb_hit_interruptA() {
+    pc.printf("pressed\n\r");
+    wireless.sendDirection(A_BUTTON);
+}
+void pb_hit_interruptB(){
+    wireless.sendDirection(B_BUTTON);
+    pc.printf("pressedB\n\r");
+}
+int main()
+{
+    
+    LSM9DS1 IMU(p9, p10, 0xD6, 0x3C);
+    IMU.begin();
+    if (!IMU.begin()) {
+        pc.printf("Failed to communicate with LSM9DS1.\n");
+    }
+    IMU.calibrate(1);
+    //IMU.calibrateMag(0);
+    pb.mode(PullUp);
+    pb2.mode(PullUp);
+    wait(.01);
+    pb.fall(&pb_hit_interruptA);
+    pb2.fall(&pb_hit_interruptB);
+    double inX,inY,inZ;
+    int pos=0;
+    while(1) {
+        while(!IMU.accelAvailable()) {pos = 0;}
+        IMU.readAccel();
+                      
+        inX = IMU.calcAccel(IMU.ax);
+        inY = IMU.calcAccel(IMU.ay); 
+        inZ = IMU.calcAccel(IMU.az);
+        if (inY >= .5)
+        {
+            pc.printf("left\n\r");
+            pos = 1;
+            wireless.sendDirection(DIR_LEFT);
+        }
+        else if( inY <= -.5)
+        {
+            pc.printf("right\n\r");
+            pos = 2;
+            wireless.sendDirection(DIR_RIGHT);
+        }
+        else if (inX >= .5)
+        {
+            pc.printf("up\n\r");
+            pos = 3;
+            wireless.sendDirection(DIR_UP);
+        }
+        else if (inX <= -.5)
+        {
+            pc.printf("down\n\r");
+            pos = 4;
+            wireless.sendDirection(DIR_DOWN);
+        }
+        else
+        {
+            //pc.printf("error");
+            pos = 0;
+            wireless.sendDirection(DIR_NONE);
+        }
+        wait(0.5);
+    }
+}
+
diff -r 000000000000 -r fa587f2eec11 mbed.bld
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/mbed.bld	Mon Apr 24 04:14:25 2017 +0000
@@ -0,0 +1,1 @@
+https://mbed.org/users/mbed_official/code/mbed/builds/97feb9bacc10
\ No newline at end of file