loading

Easy Android controllable, PC Interfaceable Relatively Cheap Mini Quadcopter (or Octocopter!) Drone...

Picture of Easy Android controllable, PC Interfaceable Relatively Cheap Mini Quadcopter (or Octocopter!) Drone...
Or how to become a drone developer without mortgaging your house.

Here is how to make a small, indoor/outdoor quadcopter that you can
fly with either:
* an android phone or tablet
* a legitimate remote
* via your own processing (http://processing.org) sketches on a PC
  (or Android device)

There are lots of optional steps in this project - for example, you
can skip building the quadcopter, and buy one instead - you will still
be to use the Arduino based radio to control it from your
phone/laptop/tablet.  However if you go this route you will miss the
satisfaction of combining the ancient chinese arts of bamboo lashing
and cheap mass manufactured electronic toys...

However you go about it, this is a reasonably cheap project, the most
expensive part other than my laptop and tablet is an Arduino DUE and a
cheaper device could be used if desired.

The ability to write your own code to fly the copter make this more of
a drone than many remote control projects, but you will need to
develop your own code to actually decide what throttle, rudder,
aileron and elevator commands to send it when - a work in progress
based upon a 'Ground station' camera tracking the copter from
underneath is included, but it doesn't fly it yet!

As a simpler exercise for the reader, you can also look into adding
forward/backward/left/right FLIP buttons to the android remote.

Taster video 1: Drone controlled by tablet:
https://www.dropbox.com/s/fesrc4n9tjhul1p/2013-06-27%2022.01.41.mp4

Taster video 2: Onboard footage from flipping (and crashing)
octo-droner:
https://www.dropbox.com/s/cy0xmmbytiqymw7/copter-fpv-flip-flipped.mp4

This work was inspired by the 18$ quadcopter thread on rcgroups
(http://www.rcgroups.com/forums/showthread.php?t=1710948) - take a
look at rcgroups for plenty more inspiration.

It also makes use of plenty of other people's work, but most
immediately the processing-serial-android library
(https://github.com/inventit/processing-android-serial/) and the
hubsan X4 and A7105 code from the deviation project
(http://www.deviationtx.com/)
 
1-40 of 93Next »
JoséM342 days ago

I bought all materials to built the quadcopter, and I achieved to join radio with receiver. But, despite that LEDs stop blinking and looks like join is working, when I use App for Android o Processing, nothing happens.

I'm working with 3 SPI pins, and I used these resistors: 2.2 Kh, 3.3 Kh and 4.7 as drdanny had mentioned in comments, only with them, join between radio and receiver success properly.

Also, I had tried with the code shared by drdanny, and still not working.

I suppose that, if LEDs stop blinking, the join is working and the circuit is well built.

What is wrong?

Somebody could give me suggestions?

Or, Is there something special to do to apps work properly?

JoséM341 month ago

I have some questions about this project.

1. Does hubsan receiver have any sensor like gps, radio, acceleration, etc.?

2. Can I control flight with arduino, and If I can, How I can do it? I want to try autonomous flight, programming with c++

Hey I too am using C++ to fly the quadcopter. My transmitter just got here so I still have to put that together. Once I do I will let you know how my C++ program goes!

Really?

How much time did you wait to receive your transmitter? I ordered mine about one month, and I still waiting for it.

I want to simulate autonomous flight with drones. I have all materials except the transmitter.

And I don't have idea how implement my own program. I know programming and a little of Arduino, but I don't know how control the drone.

shinyshez (author)  JoséM341 month ago
Hi,
I'd advise reading the instructable, which will give you a good intro and answer most of these questions, any further questions you have afterwards, ask away!

Cheers
Shez
MichaelD322 months ago
So, I've put a lot of it together, but I'm having an unbelievably hard time soldering the wires onto the radio signal thing. Not the one that goes on the drone, but the one attached to the arduino. Why they didnt just put holes where the wires should go instead of those stupid indents is completely beyond me.

Do you have any advice with this? I've been trying to get it for the past few days but they just aren't staying. Or maybe a different way to attach it to a breadboard.
shinyshez (author)  MichaelD321 month ago
Heya, I think I soldered on little breadboard compatible headers rather than wires, something like these: http://oliversmith.io/wordpress/wp-content/uploads/2011/09/DSC04685.jpg

Whether that's easier or not I don't know!
Cheers
Shez
JamesF331 month ago

Hey so I am working on writing my own code to communicate to the arduino in c++. What kind of commands do I need to send to the arduino?

shinyshez (author)  JamesF331 month ago
Hey,

Can't really say without a lot more info about your set up and what you are trying to achieve - however the processing code should be an easy place for you to get inspiration as if you know c++ reading it should be a doddle.

Cheers
Shez

Okay so I actually looked through the arduino code and it looks like it gets values for rudder, throttle, aileron, and elevator. I guess my questions is what are the physical quantities these values represent?

shinyshez (author)  JamesF331 month ago

Hey,

Most of my answers to this sound a bit smart assed, but fundamentally:

- The same things as they do when flying with the normal controller

- The same as they do for any quadcopter (google those terms you'll get better pictures than I can draw )

- If you really mean 'physical quantities' then they affect the rate at which the propellers are spun - after all a fixed pitch, unarticulated quadcopter doesn't have anything else to vary. The relationship between the commands and the spinning is more complex than we have to worry about thanks to all the gyro's, accelerometers and computing power hidden in the little toys.

Hope that helps somewhat!

Shez

Thanks! No worries about sounding smart assed. I expected as much for asking questions that seemed obvious.

James

MichaelD323 months ago

I have an Arduino Duemilanove. Is this good enough or do I have to also buy the DUE?

shinyshez (author)  MichaelD323 months ago
Hey,

the radio chip operates on 3.3v logic, whereas the Arduino Duemilanove operates on 5v.

If you are comfortable (or don't mind becoming comfortable!) with converting the logic levels, or converting the Arduino Duemilanove to 3.3v I think it should work....

Cheers
Shez

Thank you! Do you know how I would go about doing this? I'm sure it says somewhere online

shinyshez (author)  MichaelD323 months ago

Google 'logic level converter', 'voltage divider' and have a look at NicholasH1's post below. It may also be possible to take your microprocessors life in your hands and rejig it to run at 3.3v - there may be instructions on the arduino.cc site.

I've not done any of the above, so that is about the limit of my helpfulness, sorry!

compufreek4 months ago

Tried with arduino nano and no luck ... i used the pins but they dont connect ... should arduino nano had different codes ?

joln4 months ago

could it work with this a7105 ?

http://www.banggood.com/A7105-XL7105-SY-B-2_4G-Wir...

thanks

joln5 months ago
great project! thanks :)

is there a way to control the hubsan with python language ?

thanks
joln joln4 months ago

yay I have found one ! will try

https://github.com/chpatrick/hubsan

NathanG47 months ago

Is there any way, if possible, to send a gyro reset code via the Arduino. I don't own the remote for the H4, I'm only using a phone. My octocopter is drifting diagonally and I'm pretty sure it's the gyro which is set incorrectly. The copter also spins around and around.

Thanks for this AWESOME tutorial!

-N.G.

I would have to recommend trying to balance it properly first, ie be sure your battery isn't throwing it off, doesn't take much with such little birds. Then bind up and set throttle=0 yaw=0, elevator =7F, aileron=0
delay maybe 20us
aileron=FF
delay
aileron=0
delay

repeat that about 5x in a row, if you don't get the blinky lights, try setting yaw to FF in the first line...

odair.bonin6 months ago

Hi,

If there are two receiver in the same room and only one transmitter, the two receivers will receive a communication ?

How does it work?

Thanks,

odair.bonin6 months ago

Incredible project.

If there are two copters in the same room and only one transmitter, the two copters will be controlled?

How does it work?

Venman_5511 months ago

When buying the motors do they have to be clockwise/counter-clockwise or is there a way to wire it that makes it rotate a certain direction?

ivver Venman_558 months ago

Changing direction on:

DC-motor: switching polarity (+ on - and vice versa)

Three-phaze motor: switch places of two wires

NicholasH1 made it!1 year ago

This is cool! I haven't built a custom quadcopter yet, but I have been using these Arduino instructions to control an Estes Syncro / Proto X.

I went ahead and set this up slightly differently--I got it working using 4-wire SPI, rather than 3-wire. This made it a lot easier to interface with the 5v arduinos, and also removed the guesswork from the resistor values. For a Due (or other 3.3v arduinos), 4-wire SPI doesn't require any resistors at all; for an Uno (or other 5v arduinos), a simple voltage divider (11k from MOSI to SPIO, 22k from SPIO to ground) handles writing, and reading (from GPIO1 on the left side of the radio board) doesn't require any resistors.

Three aspects of this took me a while to work out. First, there's commented-out code in the A7105_Setup function that claims to set it into 4-wire mode, but there's an error in it. It writes the value 0b0110 to register 0x0b. This is the correct register, but the wrong bit pattern--the bit pattern should be 0b011001, where the final two bits are 0 for non-inverted output and 1 for enable output. In hex, this value is 0x19. I probably would have caught this sooner, but the error codes in the Hubsan initialization routine all check for specific error flags set to 1...so if all your "read" calls are returning 0, the system thinks initialization has passed.

I added this routine to read the chip's "ID" register. This value is 32 bits long, so I write it into an array of uint8_t variables:

void A7105_ReadChipID(uint8_t chipID[]) {
CS_LO();
SPI.transfer(0x46); // 0x40 | 0x06
for (int i = 0; i < 4; ++i) {
chipID[i] = SPI.transfer(0);
}
CS_HI();
}

You call it like this:

uint8_t chipID[4];
A7105_ReadChipID(chipID);
If all four blocks of that are zero, there's something definitely wrong with the connection to the chip. I think this is akin to the MAC address for the chip--it should be constant for any specific a7105 chip, but it should be different for any two a7105s.
Third, and perhaps most importantly, you can't rely on Serial.print in this sketch. Other people have pointed this out as well. Any Serial.print instructions in the sketch will make it unstable. You should comment out any Serial.print instructions before testing the sketch. When the sketch was half-working--talking to the radio correctly, but getting interference from the Serial.print commends--the front two lights on the Estes Syncro would blink in sync with each other, rather than the alternating flash they do when the craft can't find any radio. If you get to this point, persist! You've almost got it working.
I'm planning to use this to build a more useful controller for the Syncro. In particular, I'm going to separate the throttle control from the yaw controls, because on the stock controller it's hard to turn without also bumping the throttle; I'm going to make the throttle control relative rather than absolute, but add a "panic" button to set the throttle to zero; and I'm going to add buttons for extra features, like buttons to adjust rate settings, buttons for flips, and so on. The Hubsan controller offers most of these features, but I'm confident I can produce something superior now that I have the freedom to tweak it to my heart's content.
Here's a photo of my setup. (The thing under the radio is just a little board I etched to make the radio breadboard-friendly, as mine's pin connections were spaced wrong for my breadboards, and the thing in the corner is a pot I wired up to act as a throttle input for testing.)
arduino_copter.jpg

so i'm working with the Proto X. i'm able to get the lights to stop blinking, that all,

i am geting a ChipID.

There are a couple of things I forgot to mention in my comment. I thought I'd posted an additional note to cover that stuff, but apparently I forgot. First, there are a lot of calls to A7105_Reset in the code. That in itself isn't a problem, but I think the radio forgets about 4-wire SPI after a reset. I fixed this by adding an A7105_Setup call after each call to A7105_Reset, but it probably makes more sense to chain a call to A7105_Setup at the end of A7105_Reset, which would guarantee it always resets to the known-good state. Otherwise Read calls will go back to getting zero at all times if you're using 4-wire. In particular, there's a call to A7105_Reset in initialize() in hubsan.ino. This could be the problem, because initialize() will still complete if the Reads are all zero--it only looks for zero values as an "okay" state--and will probably finish binding the copter, so the lights will stop blinking. But since the code will never detect error states from the radio, it's unlikely to keep communicating properly with the copter after this. (I'm not certain if hubsan_cb() requires any nonzero values, but if it does, this would also prevent it from communicating with the copter if the wire mode was reset.)

The second thing is that the configuration of the sketch in main.ino seemed weird to me too, so I rearranged that--I moved the setup and initialization to a setup() function, and made the while(1) loop body into the entire loop() function. That made more sense to me.  Finally, I didn't use the Serial.read value settings that the original author did--I was having enough trouble with Serial changing the timing of things that I decided to just hook up a potentiometer to analog zero and use that for the throttle setting as a proof of concept. That's what worked for me. I haven't used the original author's Processing sketches with the code or with the proto-X.

The entirety of my altered "main.ino" code, then:

void setup() {
  Serial.begin(115200);
  A7105_Setup();
  delay(2000);  // gives two seconds to open serial monitor to see chip id
  uint8_t chipID[4];
  A7105_ReadChipID(chipID);
  Serial.print("Chip ID: ");
  for (int i = 0; i < 4; ++i) {
    Serial.print(chipID[i]);
    Serial.print("\t");
  }
  Serial.println();
  initialize();


void loop() {
    int throttlereading = analogRead(0);

    // set global control variables for the quadcopter
    throttle = throttlereading / 4;  // Scale 0-1023 down to 0-255
    rudder = 0x7f;      // Midpoint setting
    aileron = 0x7f;     // Midpoint setting
    elevator = 0x7f;    // Midpoint setting
   
    int hubsanWait = hubsan_cb();
    delayMicroseconds(hubsanWait);
}

Once again, note that I altered "initialize" so that it would call A7105_Setup after A7105_Reset, so that the code would read error states correctly.

Hope this helps.
-Nick

Hey Nick,

Thanks for the help! so for no go :(

One thing I tried printing the id be for and after paring, is this normal?

Id be for paring is all was,

ID: :85:32:16:65

if after paring is,

ID: :0:0:65:167

-tPt

I was ablet to get woking, using a teensy 3.1 https://www.pjrc.com/teensy/teensy31.html

my testing loop

void loop() {

startTime = micros();

boundcnt = Get_state() >= 8 ? boundcnt + 1 : 0;

hubsanWait = hubsan_cb();

Serial.println(boundcnt);

finishTime = micros();

waitTime = hubsanWait - (finishTime - startTime);

delayMicroseconds(waitTime);

startTime = micros();

}

i allso in hubsan_build_packet() i set,

packet[10] = 0x19; vs 0x64

used this to test the lights and throttle

if( cnt < 100 )

{

packet[9] = 0x0e; // LEDs on, flip on for the 100 first frames

cnt++;

}

else{

packet[9] = 0x02; // LEDs off, flips off

packet[2] = 0xaa;

}

and i have lift off,!!

shinyshez (author)  NicholasH11 year ago
Hey that's great work and will really help others who try and reproduce, thanks for contributing!
Cheers
Shez
VladB11 year ago

Thanks for DYI it is great,

i just don't understand why you need the resistor for 20K?

and can you please explain how to connect it to arduino nano/leonardo?

Thanks for the awesome project. I've managed to build it. I am interested in the android processing serial library you've used. I've tweaked your processing code to reverse the controls as they were backwards when using it on a Nook HD. I can't seem to get the app to connect to the Due. Having gone to inventit processing android serial github, i noticed you had had the same issue as well, but have hacked the library to get it working. I was wondered if you might be willing to share your hacked library. Thanks!

allowishus1 year ago

For those interested, i've just flown my Hubsan x4 with my laptop using this tutorial. But instead of the DUE i tried to make it work with the Sparkfun Arduino Micro Pro 3.3v which by comparison to the DUE is amazingly tiny, about the double the size of the A7105 radio,

And it seems to work, further testing is of course requiered and i will return with my finding. Now to wait 'till after exam to dig into the coding :P

Thanks for a great guide!

Isigo made it!1 year ago

Hi everyone !

Thanks to the awesome work of shinyshez, andy_m and drdanny, i've been able to control my hubsan x4 fpv version with my leap motion controller. Here's the link for the github repository : https://github.com/Isigo/LeapCopter

Bug report and pull request are of course welcome. Soft still buggy, and harsh to read ( have to improve this as well ), and remember that it's a work in progress ;)

DSC_0074.JPG
shinyshez (author)  Isigo1 year ago

That's awesome! Do you have any video of it in action?

Cheers

Shez

For sure ! Got this one (throttle control is still buggy ^^) :

https://drive.google.com/file/d/0B4rfrvVIld3WQXI3S01adU50YVk/edit?usp=sharing

vahokif made it!1 year ago

Hi everyone. I've been working with andy_m but I've taken a different approach and used an MPSSE cable to interface directly with the A7105. I've got binding and control working quite reliably. You can find the code here: https://github.com/vahokif/hubsan Also included is an example script that uses an Xbox 360 controller to control the quadcopter. Bug reports/pull requests are welcome.

IMG_20140214_170318.jpg
1-40 of 93Next »