# arduino_adxl345 ## ![aa](images/aa.gif) ## 1 使用硬件 ​ ardunio ​ adxl345 ​ 面包板 ​ 杜邦线 ## 2 线路连接 | arduino | adxl345 | | ------- | ------- | | 3v3 | vcc | | GND | GND | | A4 | SDA | | A5 | SCL | ![image-20201106111418638](images/image-20201106111418638.png) ## 3 arduino代码 ~~~c #include #define DEVICE (0x53) //ADXL345 device address #define TO_READ (6) //num of bytes we are going to read each time (two bytes for each axis) byte buff[TO_READ] ; //6 bytes buffer for saving data read from the device char str[512]; //string buffer to transform data before sending it to the serial port int regAddress = 0x32; //first axis-acceleration-data register on the ADXL345 int x, y, z; //three axis acceleration data double roll = 0.00, pitch = 0.00; //Roll & Pitch are the angles which rotate by the axis X and y //in the sequence of R(x-y-z),more info visit // https://www.dfrobot.com/wiki/index.php?title=How_to_Use_a_Three-Axis_Accelerometer_for_Tilt_Sensing#Introduction void setup() { Wire.begin(); // join i2c bus (address optional for master) Serial.begin(9600); // start serial for output //Turning on the ADXL345 writeTo(DEVICE, 0x2D, 0); writeTo(DEVICE, 0x2D, 16); writeTo(DEVICE, 0x2D, 8); } void loop() { readFrom(DEVICE, regAddress, TO_READ, buff); //read the acceleration data from the ADXL345 //each axis reading comes in 10 bit resolution, ie 2 bytes. Least Significat Byte first!! //thus we are converting both bytes in to one int x = (((int)buff[1]) << 8) | buff[0]; y = (((int)buff[3])<< 8) | buff[2]; z = (((int)buff[5]) << 8) | buff[4]; //we send the x y z values as a string to the serial port // Serial.print("The acceleration info of x, y, z are:"); // sprintf(str, "%d %d %d", x, y, z); // Serial.print(str); // Serial.write(10); //Roll & Pitch calculate RP_calculate(); // Serial.print("Roll:"); Serial.println( roll ); // Serial.print("Pitch:"); Serial.println( pitch ); // Serial.println(""); // Serial.print("Roll:"); Serial.println( roll ); // Serial.print("Pitch:"); Serial.println( pitch ); // Serial.println(""); char xyz[30]={0}; char x[6]; dtostrf(roll,1,2,x); char y[6]; dtostrf(pitch,1,2,y); char z[6]; dtostrf(0.0f,1,2,z); strcat(xyz,"P="); strcat(xyz,x); strcat(xyz,",Y="); strcat(xyz,y); strcat(xyz,",R="); strcat(xyz,z); Serial.println(xyz); //It appears that delay is needed in order not to clog the port delay(50); } //---------------- Functions //Writes val to address register on device void writeTo(int device, byte address, byte val) { Wire.beginTransmission(device); //start transmission to device Wire.write(address); // send register address Wire.write(val); // send value to write Wire.endTransmission(); //end transmission } //reads num bytes starting from address register on device in to buff array void readFrom(int device, byte address, int num, byte buff[]) { Wire.beginTransmission(device); //start transmission to device Wire.write(address); //sends address to read from Wire.endTransmission(); //end transmission Wire.beginTransmission(device); //start transmission to device Wire.requestFrom(device, num); // request 6 bytes from device int i = 0; while(Wire.available()) //device may send less than requested (abnormal) { buff[i] = Wire.read(); // receive a byte i++; } Wire.endTransmission(); //end transmission } //calculate the Roll&Pitch void RP_calculate(){ double x_Buff = float(x); double y_Buff = float(y); double z_Buff = float(z); roll = atan2(y_Buff , z_Buff) * 57.3; pitch = atan2((- x_Buff) , sqrt(y_Buff * y_Buff + z_Buff * z_Buff)) * 57.3; } ~~~ ## 4 ue4 plugin ​ https://github.com/RVillani/UE4Duino ​ UE4Duino解压到项目文件夹plugins中 ![image-20201106110648957](images/image-20201106110648957.png) ## 5 蓝图连接 ​ ![image-20201106110858486](images/image-20201106110858486.png) ![image-20201106110944257](images/image-20201106110944257.png) ## 6 验证结果 摄影机跟着adxl345一起运动 ![image-20201106111038088](images/image-20201106111038088.png) ## 7 总结 1 adxl345 传感器数据不稳定,产生抖动 2 缺少一个轴向 3 使用欧拉角产生极向量反转