欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136
標題:
19電賽精心編制程模塊程序 MMA7455例程
[打印本頁]
作者:
zhangjing128
時間:
2019-7-30 15:59
標題:
19電賽精心編制程模塊程序 MMA7455例程
QQ圖片20190730155146.png
(6.08 KB, 下載次數: 41)
下載附件
2019-7-30 15:56 上傳
單片機源程序如下:
#include "MMA7455.H"
//sbit sda=P2^3; //I2C 數據傳送位
//sbit scl=P2^4; //I2C 時鐘傳送位
unsigned char sign_flag; //輸出數據正負標記位
void IIC_MMA7455_init()
{
IIC_start();
IIC_writebyte(MMA7455_ADDER_WRITE); //1. 在IIC總線上尋址MMA7455
while(IIC_respons());
IIC_writebyte(MMA7455_Mode_Control_Register); //2. 模式設置寄存器尋址
while(IIC_respons());
IIC_writebyte(MMA7455_2G_Measurement_Mode); //3. 模式寄存器數據寫入
while(IIC_respons());
IIC_stop();
IIC_start();
IIC_writebyte(MMA7455_ADDER_WRITE); //1. 在IIC總線上尋址MMA7455
while(IIC_respons());
IIC_writebyte(MMA7455_Mode_Control_Register); //2. 模式設置寄存器尋址
while(IIC_respons());
IIC_writebyte(MMA7455_2G_Measurement_Mode); //3. 模式寄存器數據寫入
while(IIC_respons());
IIC_stop();
}
void IIC_MMA7455_writedata(uchar byte_add,uchar wdata)//函數功能:按地址寫入一字節數據
{
unsigned char temp;
temp=(IIC_WRITE<<1);
IIC_start();
IIC_writebyte(temp);
while(IIC_respons());
IIC_writebyte(byte_add);
while(IIC_respons());
IIC_writebyte(wdata);
while(IIC_respons());
IIC_stop();
}
unsigned char IIC_MMA7455_readdata(uchar byte_add) //函數功能:按地址讀出一字節數據
{
unsigned char temp;
char x_y_z ;
temp=(IIC_WRITE<<1);
IIC_start();
IIC_writebyte(0x3A);
while(IIC_respons());
IIC_writebyte(byte_add);
while(IIC_respons());
temp=((IIC_READ<<1)|0x01);
IIC_start();
IIC_writebyte(0x3B);
while(IIC_respons());
x_y_z=IIC_readbyte();
while(IIC_respons());
IIC_stop();
return x_y_z;
}
unsigned char IIC_MMA7455_test()
{
unsigned char temp;
for(temp=255;temp<=1;temp--);
IIC_MMA7455_writedata(0x16,0x05);
for(temp=255;temp<=1;temp--);
temp=IIC_MMA7455_readdata(0x16);
if(temp==0x05) {return 1;}
else{return 0;}
}
unsigned char IIC_MMA7455_checkbusy()
{
unsigned char temp;
temp=IIC_MMA7455_readdata(MMA7455_READ_STATUS);
if((temp&0x01)==1)
{
return 1;
}
else
{
return 0;
}
}
unsigned char IIC_MMA7455_getvalue(unsigned char address_byte)
{
unsigned char temp;
while(!IIC_MMA7455_checkbusy());
temp=IIC_MMA7455_readdata(address_byte);
if((temp&0x80)==0x00)
{
sign_flag=0;
return temp;
}
else
{
sign_flag=1;
temp=temp-0x01;
temp=~temp;
return temp;
}
}
unsigned char IIC_MMA7455_getaverage(unsigned char address_byte)
{
unsigned char num,temp;
unsigned int temps=0x00;
for(num=50;num>0;num--)
{
temp=IIC_MMA7455_getvalue(address_byte);
temps=temps+temp;
}
temp=temps/50;
return temp;
}
unsigned char IIC_MMA7455_getacceleration(unsigned char address_byte)
{
unsigned int temp;
temp=IIC_MMA7455_getaverage(address_byte);
temp=temp*200;
temp=temp>>7;
return temp;
}
unsigned char IIC_MMA7455_calibrate_X()
{
unsigned char tempX,time;
while(!IIC_MMA7455_checkbusy());
tempX=IIC_MMA7455_readdata(MMA7455_READ_X);
for(time=100;time>0;time--)
{
if((tempX&0x80)==0x00)
{
tempX=tempX+tempX;
tempX=~tempX+1;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempX);
}
else
{
tempX=tempX-1;
tempX=~tempX;
tempX=tempX+tempX;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempX);
}
tempX=IIC_MMA7455_readdata(MMA7455_READ_X);
if((tempX<=10)&&(tempX>=-10)){break;}
}
return 1;
}
unsigned char IIC_MMA7455_calibrate_Y()
{
unsigned char tempY,time;
while(!IIC_MMA7455_checkbusy());
tempY=IIC_MMA7455_readdata(MMA7455_READ_Y);
for(time=100;time>0;time--)
{
if((tempY&0x80)==0x00)
{
tempY=tempY+tempY;
tempY=~tempY+1;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempY);
}
else
{
tempY=tempY-1;
tempY=~tempY;
tempY=tempY+tempY;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempY);
}
tempY=IIC_MMA7455_readdata(MMA7455_READ_Y);
if((tempY<=10)&&(tempY>=-10)){break;}
}
return 1;
}
unsigned char IIC_MMA7455_calibrate_Z()
{
unsigned char tempZ,time;
while(!IIC_MMA7455_checkbusy());
tempZ=IIC_MMA7455_readdata(MMA7455_READ_Z);
for(time=100;time>0;time--)
{
if((tempZ&0x80)==0x00)
{
tempZ=64-tempZ;
if(tempZ==0){break;}
if(tempZ>0)
{
tempZ=tempZ+tempZ;
tempZ=~tempZ+1;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempZ);
}
if(tempZ<0)
{
tempZ=tempZ+tempZ;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempZ);
}
}
else
{
tempZ=tempZ-1;
tempZ=~tempZ;
tempZ=64+tempZ;
tempZ=tempZ+tempZ;
IIC_MMA7455_writedata(MMA7455_RW_XOFFL,tempZ);
}
tempZ=IIC_MMA7455_readdata(MMA7455_READ_Z);
if((tempZ<=70)&&(tempZ>=50)){break;}
}
return 1;
}
復制代碼
所有資料51hei提供下載:
精心編寫程序模塊.rar
(20.7 KB, 下載次數: 16)
2019-7-30 15:59 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
歡迎光臨 (http://www.raoushi.com/bbs/)
Powered by Discuz! X3.1