直接輸出角度單片機源程序如下:
- //****************************************
- // Update to MPU6050 by shinetop
- // MCU: STC89C52
- // 功能: 顯示加速度計和陀螺儀的10位原始數(shù)據(jù)
- //****************************************
- // GY-52 MPU3050 IIC測試程序
- // 使用單片機STC89C51
- // 晶振:11.0592M
- // 顯示:LCD1602
- // 編譯環(huán)境 Keil uVision2
- // 參考宏晶網(wǎng)站24c04通信程序
- //****************************************
- #include <REG52.H>
- #include <math.h> //Keil library
- #include <stdio.h> //Keil library
- #include <INTRINS.H>
- typedef unsigned char uchar;
- typedef unsigned short ushort;
- typedef unsigned int uint;
- //****************************************
- // 定義51單片機端口
- //****************************************
- sbit SCL=P1^0; //IIC時鐘引腳定義
- sbit SDA=P1^1; //IIC數(shù)據(jù)引腳定義
- sbit led1=P2^7;
- sbit led2=P2^6;
- //****************************************
- // 定義MPU6050內(nèi)部地址
- //****************************************
- #define SMPLRT_DIV 0x19 //陀螺儀采樣率,典型值:0x07(125Hz)
- #define CONFIG 0x1A //低通濾波頻率,典型值:0x06(5Hz)
- #define GYRO_CONFIG 0x1B //陀螺儀自檢及測量范圍,典型值:0x18(不自檢,2000deg/s)
- #define ACCEL_CONFIG 0x1C //加速計自檢、測量范圍及高通濾波頻率,典型值:0x01(不自檢,2G,5Hz)
- #define ACCEL_XOUT_H 0x3B
- #define ACCEL_XOUT_L 0x3C
- #define ACCEL_YOUT_H 0x3D
- #define ACCEL_YOUT_L 0x3E
- #define ACCEL_ZOUT_H 0x3F
- #define ACCEL_ZOUT_L 0x40
- #define TEMP_OUT_H 0x41
- #define TEMP_OUT_L 0x42
- #define GYRO_XOUT_H 0x43
- #define GYRO_XOUT_L 0x44
- #define GYRO_YOUT_H 0x45
- #define GYRO_YOUT_L 0x46
- #define GYRO_ZOUT_H 0x47
- #define GYRO_ZOUT_L 0x48
- #define PWR_MGMT_1 0x6B //電源管理,典型值:0x00(正常啟用)
- #define WHO_AM_I 0x75 //IIC地址寄存器(默認數(shù)值0x68,只讀)
- #define SlaveAddress 0xD0 //IIC寫入時的地址字節(jié)數(shù)據(jù),+1為讀取
- //****************************************
- //定義類型及變量
- //****************************************
- uchar dis[4]; //顯示數(shù)字(-511至512)的字符數(shù)組
- int dis_data; //變量
- int Acc_X; //顯示X軸角度
- int Acc_Y;
- int Acc_Z;
- int Gyr_X; //顯示X軸角速度
- int Gyr_Y;
- int Gyr_Z;
- //int Temperature,Temp_h,Temp_l; //溫度及高低位數(shù)據(jù)
- //****************************************
- //函數(shù)聲明
- //****************************************
- void delay(unsigned int k); //延時
- //MPU6050操作函數(shù)
- void InitMPU6050(); //初始化MPU6050
- void Delay5us();
- void I2C_Start();
- void I2C_Stop();
- void I2C_SendACK(bit ack);
- bit I2C_RecvACK();
- void I2C_SendByte(uchar dat);
- uchar I2C_RecvByte();
- void I2C_ReadPage();
- void I2C_WritePage();
- void display_ACCEL_x();
- void display_ACCEL_y();
- void display_ACCEL_z();
- uchar Single_ReadI2C(uchar REG_Address); //讀取I2C數(shù)據(jù)
- void Single_WriteI2C(uchar REG_Address,uchar REG_data); //向I2C寫入數(shù)據(jù)
- //****************************************
- //整數(shù)轉(zhuǎn)字符串
- //****************************************
- void lcd_printf(uchar *s,int temp_data)
- {
- if(temp_data<0)
- {
- temp_data=-temp_data;
- *s='-';
- }
- else *s=' ';
- *++s =temp_data/100+0x30;
- temp_data=temp_data%100; //取余運算
- *++s =temp_data/10+0x30;
- temp_data=temp_data%10; //取余運算
- *++s =temp_data+0x30;
- }
- //****************************************
- //延時
- //****************************************
- void delay(unsigned int k)
- {
- unsigned int i,j;
- for(i=0;i<k;i++)
- {
- for(j=0;j<121;j++);
- }
- }
- //**************************************
- //延時5微秒(STC90C52RC@12M)
- //不同的工作環(huán)境,需要調(diào)整此函數(shù)
- //當改用1T的MCU時,請調(diào)整此延時函數(shù)
- //**************************************
- void Delay5us()
- {
- _nop_();_nop_();_nop_();_nop_();
- _nop_();_nop_();_nop_();_nop_();
- _nop_();_nop_();_nop_();_nop_();
- _nop_();_nop_();_nop_();_nop_();
- _nop_();_nop_();_nop_();_nop_();
- _nop_();_nop_();_nop_();_nop_();
- }
- //**************************************
- //I2C起始信號
- //**************************************
- void I2C_Start()
- {
- SDA = 1; //拉高數(shù)據(jù)線
- SCL = 1; //拉高時鐘線
- Delay5us(); //延時
- SDA = 0; //產(chǎn)生下降沿
- Delay5us(); //延時
- SCL = 0; //拉低時鐘線
- }
- //**************************************
- //I2C停止信號
- //**************************************
- void I2C_Stop()
- {
- SDA = 0; //拉低數(shù)據(jù)線
- SCL = 1; //拉高時鐘線
- Delay5us(); //延時
- SDA = 1; //產(chǎn)生上升沿
- Delay5us(); //延時
- }
- //**************************************
- //I2C發(fā)送應答信號
- //入口參數(shù):ack (0:ACK 1:NAK)
- //**************************************
- void I2C_SendACK(bit ack)
- {
- SDA = ack; //寫應答信號
- SCL = 1; //拉高時鐘線
- Delay5us(); //延時
- SCL = 0; //拉低時鐘線
- Delay5us(); //延時
- }
- //**************************************
- //I2C接收應答信號
- //**************************************
- bit I2C_RecvACK()
- {
- SCL = 1; //拉高時鐘線
- Delay5us(); //延時
- CY = SDA; //讀應答信號
- SCL = 0; //拉低時鐘線
- Delay5us(); //延時
- return CY;
- }
- //**************************************
- //向I2C總線發(fā)送一個字節(jié)數(shù)據(jù)
- //**************************************
- void I2C_SendByte(uchar dat)
- {
- uchar i;
- for (i=0; i<8; i++) //8位計數(shù)器
- {
- dat <<= 1; //移出數(shù)據(jù)的最高位
- SDA = CY; //送數(shù)據(jù)口
- SCL = 1; //拉高時鐘線
- Delay5us(); //延時
- SCL = 0; //拉低時鐘線
- Delay5us(); //延時
- }
- I2C_RecvACK();
- }
- //**************************************
- //從I2C總線接收一個字節(jié)數(shù)據(jù)
- //**************************************
- uchar I2C_RecvByte()
- {
- uchar i;
- uchar dat = 0;
- SDA = 1; //使能內(nèi)部上拉,準備讀取數(shù)據(jù),
- for (i=0; i<8; i++) //8位計數(shù)器
- {
- dat <<= 1;
- SCL = 1; //拉高時鐘線
- Delay5us(); //延時
- dat |= SDA; //讀數(shù)據(jù)
- SCL = 0; //拉低時鐘線
- Delay5us(); //延時
- }
- return dat;
- }
- //**************************************
- //向I2C設(shè)備寫入一個字節(jié)數(shù)據(jù)
- //**************************************
- void Single_WriteI2C(uchar REG_Address,uchar REG_data)
- {
- I2C_Start(); //起始信號
- I2C_SendByte(SlaveAddress); //發(fā)送設(shè)備地址+寫信號
- I2C_SendByte(REG_Address); //內(nèi)部寄存器地址,
- I2C_SendByte(REG_data); //內(nèi)部寄存器數(shù)據(jù),
- I2C_Stop(); //發(fā)送停止信號
- }
- //**************************************
- //從I2C設(shè)備讀取一個字節(jié)數(shù)據(jù)
- //**************************************
- uchar Single_ReadI2C(uchar REG_Address)
- {
- uchar REG_data;
- I2C_Start(); //起始信號
- I2C_SendByte(SlaveAddress); //發(fā)送設(shè)備地址+寫信號
- I2C_SendByte(REG_Address); //發(fā)送存儲單元地址,從0開始
- I2C_Start(); //起始信號
- I2C_SendByte(SlaveAddress+1); //發(fā)送設(shè)備地址+讀信號
- REG_data=I2C_RecvByte(); //讀出寄存器數(shù)據(jù)
- I2C_SendACK(1); //接收應答信號
- I2C_Stop(); //停止信號
- return REG_data;
- }
- //**************************************
- //初始化MPU6050
- //**************************************
- void InitMPU6050()
- {
- Single_WriteI2C(PWR_MGMT_1, 0x00); //解除休眠狀態(tài)
- Single_WriteI2C(SMPLRT_DIV, 0x07);
- Single_WriteI2C(CONFIG, 0x06);
- Single_WriteI2C(GYRO_CONFIG, 0x18);
- Single_WriteI2C(ACCEL_CONFIG, 0x01);
- }
- //**************************************
- //合成數(shù)據(jù)
- //**************************************
- int GetData(uchar REG_Address)
- {
- char H,L;
- H=Single_ReadI2C(REG_Address);
- L=Single_ReadI2C(REG_Address+1);
- return (H<<8)+L; //合成數(shù)據(jù)
- }
- void shuju()
- {
- Acc_X=GetData(ACCEL_XOUT_H); //X軸加速度
- Acc_Y=GetData(ACCEL_YOUT_H); //Y軸加速度
- Acc_Z=GetData(ACCEL_ZOUT_H); //Z軸加速度
- Gyr_X=GetData(GYRO_XOUT_H); //X軸角速度
- Gyr_Y=GetData(GYRO_YOUT_H); //Y軸角速度
- Gyr_Z=GetData(GYRO_ZOUT_H); //Z軸角速度
- }
- //得到角度
- //x,y,z:x,y,z方向的重力加速度分量(不需要單位,直接數(shù)值即可)
- //dir:要獲得的角度.0,與Z軸的角度;1,與X軸的角度;2,與Y軸的角度.
- //返回值:角度值.單位0.1°.
- short ADXL345_Get_Angle(float x , float y , float z , uchar dir)
- {
- float temp;
- float res=0;
- switch(dir)
- {
- case 0://與自然Z軸的角度
- temp=sqrt((x*x+y*y))/z;
- res=atan(temp);
- break;
- case 1://與自然X軸的角度
- temp=x/sqrt((y*y+z*z));
- res=atan(temp);
- break;
- case 2://與自然Y軸的角度
- temp=y/sqrt((x*x+z*z));
- ……………………
- …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼
所有資料51hei提供下載:
陀螺儀控制電機.rar
(37.49 KB, 下載次數(shù): 400)
2017-12-5 08:24 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
|