/elec/quadcopter

To get this branch, use:
bzr branch http://bzr.ed.am/elec/quadcopter

« back to all changes in this revision

Viewing changes to src/rc-interface/main.ino

  • Committer: Tim Marston
  • Date: 2014-02-05 22:16:51 UTC
  • Revision ID: tim@ed.am-20140205221651-kqf7n3wc1ujssxoj
removed limit.h from receiver.cc

Show diffs side-by-side

added added

removed removed

24
24
//            ___    |    |    |    |    |    |    |    |     ___
25
25
//    GND ---|___|---+----+----+----+    +----+----+----+----|___|--- GND
26
26
//             R                    |    |                     R
27
 
//             ____________________ | __ | _____________________
28
 
//                                  |    |
 
27
//         ________________________ | __ | _____________________
 
28
//         ARDUINO                  |    |
29
29
//                           pin 2  o    o  pin 3
30
30
//                    (interrupt 0)        (interrupt 1)
31
31
//
34
34
//
35
35
// Note that your receiver may not send pulses sequentially, in "channel order".
36
36
// If this turns out to be the case, you will need to arrange for the pulses to
37
 
// wire up the channels in an order whereby the pulses alternatively alternately
38
 
// between the two interrupts and adjust the channel order below.
 
37
// wire up the channels in an order whereby the pulses arrive alternately
 
38
// between the two interrupts and adjust the channel order in config.h.
39
39
//
40
40
// Motor control
41
41
// -------------
42
42
//
43
 
// 
44
 
 
 
43
// The four motor control outputs should be fed directly to the ESCs.
 
44
//
 
45
//                            ESC  ESC  ESC  ESC
 
46
//                             o    o    o    o
 
47
//                             |    |    |    |
 
48
//         ___________________ | __ | __ | __ | _____
 
49
//         ARDUINO             |    |    |    |
 
50
//                      pin 4  o    o    o    o  pin 7
 
51
//
 
52
// SERIAL INTERFACE
 
53
// ----------------
 
54
//
 
55
// The serial interface (pins 0 and 1) talk a very simple protocol.  When a
 
56
// complete set of 8 channel values have been read, it writes 0xffff followed by
 
57
// the 8, 16-bit unsigned channel values.  It expects to recieve 0xffff,
 
58
// followed by 4, 16-bit unsigned channel values.  All channel values are in the
 
59
// range specified in config.h.
45
60
 
46
61
#include "config.h"
47
62
#include "receiver.h"
48
63
#include "motors.h"
49
 
#include "testing.h"
 
64
#include "comms.h"
50
65
 
51
66
 
52
67
void setup()
53
68
{
54
69
        Receiver::setup();
55
70
        Motors::setup();
56
 
 
57
 
        Testing::setup();
 
71
        Comms::setup();
 
72
 
 
73
        // led
 
74
        pinMode( LED_PIN, OUTPUT );
 
75
        digitalWrite( LED_PIN, LOW );
 
76
}
 
77
 
 
78
 
 
79
void flash_led()
 
80
{
 
81
        static bool on = false;
 
82
        on = !on;
 
83
        digitalWrite( LED_PIN, on? HIGH : LOW );
58
84
}
59
85
 
60
86
 
61
87
void loop()
62
88
{
63
 
        unsigned long channel_values[ NUM_CHANNELS ];
 
89
        int channel_values[ NUM_CHANNELS ];
64
90
 
65
91
        while( true )
66
92
        {
 
93
                // have we read a whole set of channel values?
67
94
                if( Receiver::read_channels( channel_values ) )
68
95
                {
69
 
                        Testing::draw_receiver_channels( channel_values );
 
96
                        // update motors
 
97
                        Motors::update();
 
98
 
 
99
                        // yes, flash led!
 
100
                        flash_led();
 
101
 
 
102
                        // send channel values to main board
 
103
                        Comms::write_channels( channel_values );
 
104
 
 
105
                        // set motor speeds
 
106
                        Motors::set_values( channel_values );
70
107
                }
71
 
//              Motors::update_channels( channel_values );
 
108
 
 
109
                // update motors
 
110
                Motors::update();
72
111
        }
73
112
}