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.
Dependents: 17robo_fuzi 17robo_tokyo_kaede
sbdbt.cpp
- Committer:
- echo_piyo
- Date:
- 2017-09-24
- Revision:
- 0:59256c750167
File content as of revision 0:59256c750167:
#include "sbdbt.h"
#include "mbed.h"
Sbdbt::Sbdbt(PinName mbed_tx, PinName mbed_rx, PinName pin_pairing) : SBDBT(mbed_tx,mbed_rx), pairing(pin_pairing){
}
void Sbdbt::begin(long baudrate){
init();
SBDBT.baud(baudrate);
SBDBT.attach(this, &Sbdbt::data_receive, Serial::RxIrq);
}
int Sbdbt::get_pairingState(){
return pairing;
}
void Sbdbt::init(){
open_data[0] = buffer[0] = data[0] = 128;
open_data[1] = buffer[1] = data[1] = 0;
open_data[2] = buffer[2] = data[2] = 0;
open_data[3] = buffer[3] = data[3] = 64;
open_data[4] = buffer[4] = data[4] = 64;
open_data[5] = buffer[5] = data[5] = 64;
open_data[6] = buffer[6] = data[6] = 64;
open_data[7] = buffer[7] = data[7] = 0;
}
void Sbdbt::check(){
if (bitTest(data[1],Shikaku)) {
shikaku = 1;
} else {
shikaku = 0;
}
if (bitTest(data[1],L1)) {
l1 = 1;
} else {
l1 = 0;
}
if (bitTest(data[1],L2)) {
l2 = 1;
} else {
l2 = 0;
}
if (bitTest(data[1],R1)) {
r1 = 1;
} else {
r1 = 0;
}
if (bitTest(data[1],R2)) {
r2 = 1;
} else {
r2 = 0;
}
if ((data[2] & Start) == Start) {
start = 1;
up = 0;
down = 0;
} else {
start = 0;
if (bitTest(data[2],Up)) {
up = 1;
} else {
up = 0;
}
if (bitTest(data[2],Down)) {
down = 1;
} else {
down = 0;
}
}
if ((data[2] & Select) == Select) {
select = 1;
right = 0;
left = 0;
} else {
select = 0;
if (bitTest(data[2],Right)) {
right = 1;
} else {
right = 0;
}
if (bitTest(data[2],Left)) {
left = 1;
} else {
left = 0;
}
}
if (bitTest(data[2],Sankaku)) {
sankaku = 1;
} else {
sankaku = 0;
}
if (bitTest(data[2],Batu)) {
batu = 1;
} else {
batu = 0;
}
if (bitTest(data[2],Maru)) {
maru = 1;
} else {
maru = 0;
}
Left_X = data[3];
Left_Y = data[4];
Right_X = data[5];
Right_Y = data[6];
if (Left_X <= EvenNeutral) {
left_x = (float) EvenNeutral - Left_X;
} else {
left_x = (float) OddNeutral - Left_X;
}
if (Left_Y <= EvenNeutral) {
left_y = (float) EvenNeutral - Left_Y;
} else {
left_y = (float) OddNeutral - Left_Y;
}
if (Right_X <= EvenNeutral) {
right_x = (float) EvenNeutral - Right_X;
} else {
right_x = (float) OddNeutral - Right_X;
}
if (Right_Y <= EvenNeutral) {
right_y = (float) EvenNeutral - Right_Y;
} else {
right_y = (float) OddNeutral - Right_Y;
}
left_x = -left_x / EvenNeutral;
left_y = left_y / EvenNeutral;
right_x = -right_x / EvenNeutral;
right_y = right_y / EvenNeutral;
if (fabs(left_x) < 0.24f) {
left_x = 0;
}
if (fabs(left_y) < 0.24f) {
left_y = 0;
}
}
void Sbdbt::data_receive (){
read = SBDBT.getc();
if (read == start_byte) {
data_start = 1;
checksum = 0;
byte = 1;
buffer[0] = read;
} else {
if (data_start == 1) {
buffer[byte] = read;
byte++;
}
if (byte > input_byte) {
int i;
for (i = 1 ; i < input_byte; i++) {
checksum = checksum + buffer[i];
}
if ((checksum & 0b01111111) == buffer[7]) {
for (i = 0; i < data_byte; i++) {
data[i] = buffer[i];
open_data[i] = data[i];
}
check();
}
byte = 0;
data_start = 0;
}
}
}