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.
main.cpp@0:f2035b8df504, 2017-05-01 (annotated)
- Committer:
 - myu429
 - Date:
 - Mon May 01 01:43:02 2017 +0000
 - Revision:
 - 0:f2035b8df504
 
V1.0 Code
Who changed what in which revision?
| User | Revision | Line number | New contents of line | 
|---|---|---|---|
| myu429 | 0:f2035b8df504 | 1 | #include "mbed.h" | 
| myu429 | 0:f2035b8df504 | 2 | #include "USBMouseKeyboard.h" | 
| myu429 | 0:f2035b8df504 | 3 | |
| myu429 | 0:f2035b8df504 | 4 | USBMouseKeyboard key_mouse; | 
| myu429 | 0:f2035b8df504 | 5 | |
| myu429 | 0:f2035b8df504 | 6 | Serial rf_receive(p28, p27); | 
| myu429 | 0:f2035b8df504 | 7 | |
| myu429 | 0:f2035b8df504 | 8 | void processButtons(short b); | 
| myu429 | 0:f2035b8df504 | 9 | |
| myu429 | 0:f2035b8df504 | 10 | /* | 
| myu429 | 0:f2035b8df504 | 11 | * parse incoming message data into X, Y, and buttons | 
| myu429 | 0:f2035b8df504 | 12 | * move cursor by X, Y | 
| myu429 | 0:f2035b8df504 | 13 | * pass buttons along to handler | 
| myu429 | 0:f2035b8df504 | 14 | */ | 
| myu429 | 0:f2035b8df504 | 15 | void processMessage(char* msg) | 
| myu429 | 0:f2035b8df504 | 16 | { | 
| myu429 | 0:f2035b8df504 | 17 | short x = msg[1] | (msg[2] << 8); | 
| myu429 | 0:f2035b8df504 | 18 | short y = msg[3] | (msg[4] << 8); | 
| myu429 | 0:f2035b8df504 | 19 | short button = msg[5] | (msg[6] << 8); | 
| myu429 | 0:f2035b8df504 | 20 | processButtons(button); | 
| myu429 | 0:f2035b8df504 | 21 | if (button != 0x00) { | 
| myu429 | 0:f2035b8df504 | 22 | // pc.printf("rcvd button: %4x \r\n\r\n", button); | 
| myu429 | 0:f2035b8df504 | 23 | } | 
| myu429 | 0:f2035b8df504 | 24 | key_mouse.move(x, y); | 
| myu429 | 0:f2035b8df504 | 25 | } | 
| myu429 | 0:f2035b8df504 | 26 | |
| myu429 | 0:f2035b8df504 | 27 | |
| myu429 | 0:f2035b8df504 | 28 | /* | 
| myu429 | 0:f2035b8df504 | 29 | * process incoming button data, each bit corresponds to a single button | 
| myu429 | 0:f2035b8df504 | 30 | * allows for multiple button presses froma single message | 
| myu429 | 0:f2035b8df504 | 31 | */ | 
| myu429 | 0:f2035b8df504 | 32 | void processButtons(short b) | 
| myu429 | 0:f2035b8df504 | 33 | { | 
| myu429 | 0:f2035b8df504 | 34 | // button 1 | 
| myu429 | 0:f2035b8df504 | 35 | if (((b >> 1) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 36 | // left click | 
| myu429 | 0:f2035b8df504 | 37 | key_mouse.click(MOUSE_LEFT); | 
| myu429 | 0:f2035b8df504 | 38 | } | 
| myu429 | 0:f2035b8df504 | 39 | // button 2 | 
| myu429 | 0:f2035b8df504 | 40 | if (((b >> 2) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 41 | // Middle click | 
| myu429 | 0:f2035b8df504 | 42 | key_mouse.click(MOUSE_MIDDLE); | 
| myu429 | 0:f2035b8df504 | 43 | } | 
| myu429 | 0:f2035b8df504 | 44 | // button 3 | 
| myu429 | 0:f2035b8df504 | 45 | if (((b >> 3) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 46 | // right click | 
| myu429 | 0:f2035b8df504 | 47 | key_mouse.click(MOUSE_RIGHT); | 
| myu429 | 0:f2035b8df504 | 48 | } | 
| myu429 | 0:f2035b8df504 | 49 | // button 5 | 
| myu429 | 0:f2035b8df504 | 50 | if (((b >> 5) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 51 | // volume up | 
| myu429 | 0:f2035b8df504 | 52 | key_mouse.mediaControl(KEY_VOLUME_UP); | 
| myu429 | 0:f2035b8df504 | 53 | } | 
| myu429 | 0:f2035b8df504 | 54 | // button 6 | 
| myu429 | 0:f2035b8df504 | 55 | if (((b >> 6) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 56 | // scroll up | 
| myu429 | 0:f2035b8df504 | 57 | key_mouse.scroll(-1); | 
| myu429 | 0:f2035b8df504 | 58 | } | 
| myu429 | 0:f2035b8df504 | 59 | // button 7 | 
| myu429 | 0:f2035b8df504 | 60 | if (((b >> 7) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 61 | // fwd | 
| myu429 | 0:f2035b8df504 | 62 | key_mouse.keyCode(RIGHT_ARROW, KEY_ALT); | 
| myu429 | 0:f2035b8df504 | 63 | } | 
| myu429 | 0:f2035b8df504 | 64 | // button 9 | 
| myu429 | 0:f2035b8df504 | 65 | if (((b >> 9) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 66 | // volume down | 
| myu429 | 0:f2035b8df504 | 67 | key_mouse.mediaControl(KEY_VOLUME_DOWN); | 
| myu429 | 0:f2035b8df504 | 68 | } | 
| myu429 | 0:f2035b8df504 | 69 | // button 10 | 
| myu429 | 0:f2035b8df504 | 70 | if (((b >> 10) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 71 | // scroll down | 
| myu429 | 0:f2035b8df504 | 72 | key_mouse.scroll(1); | 
| myu429 | 0:f2035b8df504 | 73 | |
| myu429 | 0:f2035b8df504 | 74 | } | 
| myu429 | 0:f2035b8df504 | 75 | // button 11 | 
| myu429 | 0:f2035b8df504 | 76 | if (((b >> 11) & 0x01) != 0) { | 
| myu429 | 0:f2035b8df504 | 77 | // back | 
| myu429 | 0:f2035b8df504 | 78 | key_mouse.keyCode(LEFT_ARROW, KEY_ALT); | 
| myu429 | 0:f2035b8df504 | 79 | } | 
| myu429 | 0:f2035b8df504 | 80 | } | 
| myu429 | 0:f2035b8df504 | 81 | |
| myu429 | 0:f2035b8df504 | 82 | |
| myu429 | 0:f2035b8df504 | 83 | /* | 
| myu429 | 0:f2035b8df504 | 84 | * read in bytes when available from the RF receiver | 
| myu429 | 0:f2035b8df504 | 85 | * read in bytes while looking for start character and validating checksum | 
| myu429 | 0:f2035b8df504 | 86 | */ | 
| myu429 | 0:f2035b8df504 | 87 | int main() | 
| myu429 | 0:f2035b8df504 | 88 | { | 
| myu429 | 0:f2035b8df504 | 89 | |
| myu429 | 0:f2035b8df504 | 90 | rf_receive.baud(4800); | 
| myu429 | 0:f2035b8df504 | 91 | int curByte = 0; | 
| myu429 | 0:f2035b8df504 | 92 | char received[8]; | 
| myu429 | 0:f2035b8df504 | 93 | char checksum= 0; | 
| myu429 | 0:f2035b8df504 | 94 | while(1) { | 
| myu429 | 0:f2035b8df504 | 95 | // check if data available for reading | 
| myu429 | 0:f2035b8df504 | 96 | if (rf_receive.readable()) { | 
| myu429 | 0:f2035b8df504 | 97 | |
| myu429 | 0:f2035b8df504 | 98 | // read in byte into incoming message array | 
| myu429 | 0:f2035b8df504 | 99 | received[curByte] = rf_receive.getc(); | 
| myu429 | 0:f2035b8df504 | 100 | // if this is the first byte in the message | 
| myu429 | 0:f2035b8df504 | 101 | if (curByte == 0) { | 
| myu429 | 0:f2035b8df504 | 102 | // check if it is the start character, if not, keep overwiting 1st byte | 
| myu429 | 0:f2035b8df504 | 103 | if (received[curByte] == 0x55) { | 
| myu429 | 0:f2035b8df504 | 104 | // if so update checksum and increment message data pointer | 
| myu429 | 0:f2035b8df504 | 105 | checksum += received[curByte]; | 
| myu429 | 0:f2035b8df504 | 106 | curByte++; | 
| myu429 | 0:f2035b8df504 | 107 | } | 
| myu429 | 0:f2035b8df504 | 108 | // if received valid start char, read in 6 data bytes, calculating checksum | 
| myu429 | 0:f2035b8df504 | 109 | } else if (curByte <= 6) { | 
| myu429 | 0:f2035b8df504 | 110 | checksum += received[curByte]; | 
| myu429 | 0:f2035b8df504 | 111 | curByte++; | 
| myu429 | 0:f2035b8df504 | 112 | } else { // else check if calculated checksum matches incoming checksum | 
| myu429 | 0:f2035b8df504 | 113 | if (checksum == received[curByte]) { | 
| myu429 | 0:f2035b8df504 | 114 | // if valid message, process data | 
| myu429 | 0:f2035b8df504 | 115 | processMessage(received); | 
| myu429 | 0:f2035b8df504 | 116 | } | 
| myu429 | 0:f2035b8df504 | 117 | // reset for next message regardless | 
| myu429 | 0:f2035b8df504 | 118 | curByte = 0; | 
| myu429 | 0:f2035b8df504 | 119 | checksum = 0; | 
| myu429 | 0:f2035b8df504 | 120 | } | 
| myu429 | 0:f2035b8df504 | 121 | } | 
| myu429 | 0:f2035b8df504 | 122 | } | 
| myu429 | 0:f2035b8df504 | 123 | } |