-
Notifications
You must be signed in to change notification settings - Fork 18
/
Copy pathREADME
150 lines (107 loc) · 4.35 KB
/
README
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
What is this?
-------------
This projet is a collection of code showing how to control Parrot's
Jumping Sumo. The maker, Parrot, freely provides an App (Freeflight 3)
for Android and iOS for people to use it with smartphone and
tablets. Parrot promissed a SDK "this year" (2014) to programmatically
control the Sumo from any platform. However, I was not willing to wait.
The Jumping Sumo is a WiFi-controlled kind of two-tyred RC-Car equipped
with a camera for live-streaming (and recording). It does do jumps and
special, preprogrammed moves.
There are two design goals and reasons for this project (and these apply
as well for the to-be-released SDK): one is to used the code to create
user-applications on platforms which are not officially supported by Parrot.
And, secondly, have people automate the control of the Sumo by
programmatically processing the video-frames and thus have the Sumo
orientate itself.
The code which can be found in this repository was completely reverse
engineered. This was done completely independently of Parrot. They
neither provided help nor did I ask for help in any way. In other
words it works, but has a lot of limitations and assumptations in it
and, in the worst case, might harm or even damage the device when
being used with. So:
THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY
APPLICABLE LAW. YOU ARE USING THIS CODE AT YOUR OWN RISK.
The principal of reverse engineering is, that you send data-bytes to
the device you have captured using the official applipcation. Once
analyzed and processed you are able to associate those bytes with a
certain functionality.
What's in the package
---------------------
analyze/
code which is used to analyze captured network packages
lib/
a C++11 library providing a simple class (sumo::Control) to control
the Sumo. It encapsulates the network-protocol and handles all in and
outgoing network traffic
qsumo/
a simple QT-app letting you control the Sumo with arrow keys on your
keyboard
test/
a super simple and small command-line application which does nothing
else than having the Sumo turn circles and thus showing how to use the API.
See README.dev for me information on the code.
Get it working (on Linux)
-------------------------
0) get the dependencies (Ubuntu/Debian)
$ sudo apt-get install libpcap-dev libqt4-dev mplayer
1) get the code
$ git clone https://github.com/iloreen/libsumo.git
2) create a build-dir
$ cd libsumo
$ mkdir build
3) in build-dir run cmake and compile the stuff
$ cd build
$ cmake ..
$ make
4) connect yourself to the WiFi provided by the Sumo
5) run qs (the QtApp)
$ ./qs
6) click "Open" (it should change the caption to Close when successful
and you should see some text being printed in the terminal and you
should see a video-player (mplayer) window open with the current
view of the sumo)
7) Use the arrow keys to accelerate or break and to turn left or right.
Requirements
------------
- a C++11 capable compiler (gcc >=4.8, clang)
- if you want to analyze network code with 'analyze' you need libpcap-dev
- if you want to build the qt-app, libqt4-dev
- mplayer, used by the QtApp to display the video images
What is implemented
-------------------
- Moving (acceleration and turning)
- Videoframes are shown
- Battery-level can be read
- HighJump and LongJump
- FastTurns
- special moves (like Slalom, fast-turns)
What's missing (a.k.a TODO)
---------------------------
- understand usage of timestamps in "realtime part"
- understand all incoming Type-4 Messages (IOCTL)
- implement correct JSON parsing and generation
- handle configuration messages (don't even know which protocol is used)
- change class which handles video frames so that it can be easily overriden for automatic image processing
- implement MDNS discovery - right now the Sumo's IP address is hardcoded to 192.168.2.1
License
-------
LGPL v2.1 - see COPYING-file
Links
-----
Parrot - Company
http://www.parrot.com/
Parrot - Jumping Sumo product page
http://www.parrot.com/usa/products/jumping-sumo/
Qt Forum - Get keypress events
http://qt-project.org/forums/viewthread/28888
Contribution
------------
I'd like to see
- feedback,
- you trying it out and reporting what happens,
- you forking this repo on github
- you sending patches with fixes, improvements, changes or ports to other languages.
Have fun.
--
Ive Loreen <[email protected]>