Which bluetooth receiver? Like @user591124, I recommend you take a look a the Arduino Bluetooth board, which includes a BT receiver. If you wnat an external BT receiver, check out search results at Sparkfun.
What software? To program your Arduino, you only need the Arduino software which you can download from the Arduino site.
I believe the real issue here is actually going to be the electronic door lock. A quick Google search turned up the likes of this site. They offer electromagnetic locks as well as control boards. It would then appear that you can hook up one of the Arduino outputs to a relay or transistor, which provide the control board with the correct voltage to lock/unlock the door.
Probably best to put the Arduino on the other side of the door, considering it would be quite easy to break in if you had access to it. :)
I tried a voltmeter over GND and DI10 and while measuring it showed
0V.
That doesn't sound right.
When a UART is not transmitting any data, it stays in the idle "1" state.
I expected the wires connected to the Arduino to be so-called RS232TTL levels of +5V in the "1" state and close to GND in the "0" state.
(d)
When the UART is transmitting lots of data, a multimeter typically shows some sort of average voltage between the "1" state and the "0" state, bouncing around 2 V to 4 V.
Perhaps a power or data line got disconnected or wired up wrong?
As a side note, if I remove the pinMode(rxPin, INPUT) line then
nothing is ever received (and rf.available() is always 0).
That's very unexpected.
Most Arduino documentation says things like
"Arduino (Atmega) pins default to inputs, so they don't need to be explicitly declared as inputs with pinMode()." (a)
Some tutorials for SoftwareSerial suggest explicitly declaring the TX pins to be output.
(b)
Perhaps whatever is listening to "txPin" is picking up noise, making it do something unexpected?
Most Arduino tutorials seem to use 9600 bps for the hardware Serial uart.
(c)
rf.available() is always > 0 (and also becomes 63)
How could you possibly know that?
I'm beginning to suspect the code in your Arduino is some program other than what you posted.
What happens when you test exactly the same program, but with a known serial source?
For example,
rather than connect Arduino D10 (your SoftwareSerial rxPin) to the radio, instead connect D10 to Arduino D0 (the data you type in your PC's serial monitor), and type a few words.
What happens then?
Maybe the SoftwareSerial works fine with normal UART data,
but it can't handle the high-frequency glitches common in low-cost radio receivers.
In that case, maybe it would work better to
- (a) connect the Arduino hardware UART (D0 Rx and D1 Tx) to the radio, and the SoftwareSerial to your debugging serial monitor. Or
- (b) use more sophisticated hardware that does clock recovery, etc. like the HopeRF RFM12B as used in the JeeNode and the Moteino, or
- (c) use more sophisticated software, such as the protocol Roman Black invented and describes in "RF modules made easy" or the frequency-shift keying system developed by Tom Boyd in "Pulse train detection with an Arduino".
Some test code:
#include <SoftwareSerial.h>
#define rxPin 10
#define txPin 11
SoftwareSerial rf(rxPin, txPin);
void setup() {
pinMode(rxPin, INPUT);
pinMode(txPin, OUTPUT);
Serial.begin(9600);
rf.begin(2400);
Serial.println("Hello, I was compiled " __DATE__ );
}
void loop() {
if( rf.available() ){
int incomingByte = rf.read();
Serial.print(incomingByte, DEC);
Serial.print(" ");
Serial.println( rf.available(), DEC);
}
}
Best Answer
if your problem is only in characters you receive back just use char[] array instead of int e.g.
char bytes[10];
Now you'll receive the same data back.
Hopefully it solve your problem