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.
ui.cpp
- Committer:
- hober
- Date:
- 2017-12-08
- Revision:
- 7:ee0569d49c52
- Parent:
- 6:ce02d396c961
- Child:
- 8:33d34a775873
File content as of revision 7:ee0569d49c52:
#include "motor.h"
#include "xyz_sensor_platform.h"
#include "ParseArray.h"
#define I2C_FREQUENCY 400000
Serial pc(SERIAL_TX, SERIAL_RX, 115200);
DigitalOut led(LED2),led3(LED3);
DigitalOut mag_test(D11);
XYZSensorPlatform platform;
ParseArray *commandParse;
static const int bufferArrayLength = 100;
static int currentBufferIndex;
static byte* bufferArray;
static byte* dataArray;
byte Xor;
byte commandToSend[10]= {'H','O','1','2','3','4','5','6','E',0};
static const int dataLength = 7;
bool isRecording = false;
void echo(char typ, float x, float y, float z);
void echo(char typ, int16_t *p_data);
int main()
{
float x, y, z;
float pos[3];
int n = 0;
led=1;
mag_test=1;
bufferArray = new byte[bufferArrayLength];
dataArray = new byte[dataLength];
currentBufferIndex = 0;
commandParse = new ParseArray;
commandParse->bufferLength = bufferArrayLength;
commandParse->bufferArray = new byte[bufferArrayLength];
commandParse->enableHeader(0,1,"48");// 48 H
commandParse->enableFooter(8,1,"45");// 45 E
commandParse->enableCheckXOR(9);
commandParse->length=10;
pc.format(8,SerialBase::None,1);
platform.set_speed(2.5);
platform.reset(); // need to be modified here
platform.setSensorI2cFrequency(I2C_FREQUENCY);
while(1) {
if(pc.readable()) {
pc.read((uint8_t*)&(commandParse->bufferArray[currentBufferIndex]),1,NULL);
if(commandParse->parse(currentBufferIndex)) {
for(int i = commandParse->currentHeaderIndex + 1, j = 0; i < commandParse->currentFooterIndex; i++, j++)
dataArray[j] = commandParse->bufferArray[i % commandParse->bufferLength];
switch(dataArray[0]) {
case 'I':
break;
case 'O': // echo
platform.position(pos);
echo('O',pos[0],pos[1],pos[2]);
led3 = !led3;
break;
case 'C': // command
x=(float)((dataArray[1]<<8)+dataArray[2])/10.0f;
y=(float)((dataArray[3]<<8)+dataArray[4])/10.0f;
z=(float)((dataArray[5]<<8)+dataArray[6])/10.0f;
platform.to(x,y,z);
platform.position(pos);
echo('O',pos[0],pos[1],pos[2]);
break;
case 'X':
if(dataArray[1]&0x80)platform.go_right();
else platform.go_left();
platform.position(pos);
echo('O',pos[0],pos[1],pos[2]);
break;
case 'Y':
if(dataArray[1]&0x80)platform.go_forward();
else platform.go_backward();
platform.position(pos);
echo('O',pos[0],pos[1],pos[2]);
break;
case 'Z':
if(dataArray[1]&0x80)platform.go_up();
else platform.go_down();
platform.position(pos);
echo('O',pos[0],pos[1],pos[2]);
break;
case 'M': // magnet
int16_t mag[3];
if(platform.get_mag_raw(mag)==0) echo('M',mag);
mag_test=!mag_test;
break;
case 'R': // record
isRecording = true;
break;
case 'S': // stop
isRecording = false;
break;
default:
break;
}
}
currentBufferIndex++;
currentBufferIndex%=bufferArrayLength;
} // end parsing if
if(isRecording && n < 10000) {
int16_t mag[3];
if(platform.get_mag_raw(mag)==0&&pc.writeable()) {
echo('M',mag);
mag_test=!mag_test;
wait(0.0001);
}
n++;
} // end recording if
} // end while
}
void echo(char typ,float x, float y, float z)
{
int16_t p_data[3]= {(int16_t)(x*10), int16_t(y*10), int16_t(z*10)};
echo(typ,p_data);
}
void echo(char typ, int16_t *p_data)
{
byte tmp[10]= {'H', typ, p_data[0]>>8, p_data[0], p_data[1]>>8 ,p_data[1], p_data[2]>>8, p_data[2], 45,'\0' };
tmp[8]='E';
tmp[9]=commandParse->computeXOR(tmp,9);
pc.write(tmp,10,NULL);
}