标题: ADXL345单片机计步器程序 [打印本页]

作者: 51黑ele    时间: 2016-5-11 00:00
标题: ADXL345单片机计步器程序

adxl345芯片实现的计步器,显示用的是1602液晶屏,下面可以下载完整的程序.


完整的源代码下载: adxl345计步器程序设计.rar (39.38 KB, 下载次数: 760)

部分源码预览:
程序1:1602液晶显示的adxl345加速度 计步器版本:
  1. #include<reg52.h>
  2. #include<math.h>
  3. #include"1602.h"
  4. #include  <INTRINS.H>

  5. #define        SlaveAddress   0xA6          //1010 0110    定义器件在IIC总线中的从地址,根据ALT  ADDRESS地址引脚不同修改
  6.                               //ALT  ADDRESS引脚接地时地址为0xA6,接电源时地址为0x3A 0011 1010
  7. sbit sclk=P0^0;
  8. sbit sda=P0^1;

  9. float  dis_datax,dis_datay,dis_dataz,acc,acc1=1000;
  10. uchar BUF[8];
  11. uchar wan, qian, bai, shi ,ge,flag,miao,miao1,n;
  12. uint count;

  13. void conversion(uint temp_data)  
  14. {  
  15.     wan=temp_data/10000+0x30 ;
  16.     temp_data=temp_data%10000;   //取余运算
  17.         qian=temp_data/1000+0x30 ;
  18.     temp_data=temp_data%1000;    //取余运算
  19.     bai=temp_data/100+0x30   ;
  20.     temp_data=temp_data%100;     //取余运算                                 -e----------------eee-e
  21.     shi=temp_data/10+0x30    ;
  22.     temp_data=temp_data%10;      //取余运算
  23.     ge=temp_data+0x30;        
  24. }
  25. void delay6us()                 //6us延时函数
  26. {

  27.         _nop_();        _nop_();          



  28. }

  29. void delay_ms(uint n)       //N ms延时函数
  30. {
  31.         uint x,y;
  32.         for(x=n;x>0;x--)
  33.                 for(y=110;y>0;y--);       
  34. }

  35.                                                                                                                                                                 /////

  36. void ADXL345_Start()
  37. {
  38.     sda = 1;                    //拉高数据线
  39.     sclk = 1;                    //拉高时钟线
  40.     delay6us();                 //延时
  41.     sda = 0;                    //产生下降沿
  42.     delay6us();                 //延时
  43.     sclk = 0;                    //拉低时钟线
  44. }

  45. void ADXL345_Stop()
  46. {
  47.     sda = 0;                    //拉低数据线
  48.     sclk = 1;                    //拉高时钟线
  49.     delay6us();                 //延时
  50.     sda = 1;                    //产生上升沿
  51.     delay6us();                 //延时
  52. }

  53. void ADXL345_SendACK(bit ack)
  54. {
  55.     sda = ack;                  //写应答信号
  56.     sclk = 1;                    //拉高时钟线
  57.     delay6us();                 //延时
  58.     sclk = 0;                    //拉低时钟线
  59.     delay6us();                 //延时
  60. }


  61. bit ADXL345_RecvACK()
  62. {
  63.     sclk = 1;                    //拉高时钟线
  64.     delay6us();                 //延时
  65.     CY = sda;                   //读应答信号
  66.     sclk = 0;                    //拉低时钟线
  67.     delay6us();                 //延时

  68.     return CY;
  69. }


  70. void ADXL345_SendByte(uchar dat)
  71. {
  72.     uchar i;
  73. //        sclk = 0;                //拉低时钟线

  74.     for (i=0; i<8; i++)         //8位计数器
  75.     {
  76.         dat <<= 1;              //移出数据的最高位
  77.         sda = CY;               //送数据口
  78.         sclk = 1;                //拉高时钟线
  79.         delay6us();             //延时
  80.         sclk = 0;                //拉低时钟线
  81.         delay6us();             //延时
  82.     }
  83.     ADXL345_RecvACK();
  84. }


  85. uchar ADXL345_RecvByte()
  86. {
  87.     uchar i;
  88.     uchar dat = 0;

  89.     sda = 1;
  90.         //        write_com(0x80);
  91.                    //使能内部上拉,准备读取数据,
  92.     for (i=0; i<8; i++)         //8位计数器
  93.     {
  94.         dat <<= 1;
  95.         sclk = 1;                //拉高时钟线
  96.         delay6us();             //延时
  97.         dat |= sda;             //读数据               
  98.         sclk = 0;                //拉低时钟线
  99.         delay6us();             //延时

  100.     }


  101.     return dat;
  102. }

  103. void Single_Write_ADXL345(uchar REG_Address,uchar REG_data)
  104. {
  105.     ADXL345_Start();                  //起始信号
  106.     ADXL345_SendByte(SlaveAddress);   //发送设备地址+写信号
  107.     ADXL345_SendByte(REG_Address);    //内部寄存器地址,请参考中文pdf22页
  108.     ADXL345_SendByte(REG_data);       //内部寄存器数据,请参考中文pdf22页
  109.     ADXL345_Stop();                   //发送停止信号
  110. }

  111. uchar Single_Read_ADXL345(uchar REG_Address)
  112. {
  113.         uchar REG_data;
  114.     ADXL345_Start();            
  115.        
  116.        
  117.        
  118.                       //起始信号
  119.     ADXL345_SendByte(SlaveAddress);           //发送设备地址+写信号
  120.     ADXL345_SendByte(REG_Address);                   //发送存储单元地址,从0开始       
  121.     ADXL345_Start();                          //起始信号
  122.     ADXL345_SendByte(SlaveAddress+1);         //发送设备地址+读信号
  123.     REG_data=ADXL345_RecvByte();              //读出寄存器数据
  124.         ADXL345_SendACK(1);   
  125.         ADXL345_Stop();                           //停止信号
  126.     return REG_data;
  127. }

  128. void Multiple_read_ADXL345()
  129. {   
  130.         uchar i;
  131.     ADXL345_Start();                          //起始信号
  132.     ADXL345_SendByte(SlaveAddress);           //发送设备地址+写信号           1010 0110
  133.     ADXL345_SendByte(0x32);                   //发送存储单元地址,从0x32开始 0011 0010
  134.     ADXL345_Start();                          //起始信号
  135.     ADXL345_SendByte(SlaveAddress+1);         //发送设备地址+读信号           1010 0111
  136.         for (i=0; i<6; i++)                      //连续读取6个地址数据,存储中BUF
  137.     {
  138.         BUF[i] = ADXL345_RecvByte();          //BUF[0]存储0x32地址中的数据
  139.         if(i == 5)        ADXL345_SendACK(1);       //最后一个数据需要回NOACK
  140.         else        ADXL345_SendACK(0);           //回应ACK
  141.     }
  142.     ADXL345_Stop();                          //停止信号
  143.     delay_ms(10);
  144. }

  145. void Init_ADXL345()           //初始化ADXL345,根据需要请参考pdf进行修改***********************
  146. {
  147. //        delay(500);                                          //上电延时
  148.    Single_Write_ADXL345(0x31,0x2B);   //测量范围,正负16g,13位模式
  149.    Single_Write_ADXL345(0x2C,0x06);   //0000 0110速率设定为6.25 参考pdf13页
  150.    Single_Write_ADXL345(0x2D,0x08);   //选择电源模式   参考pdf24页
  151.    Single_Write_ADXL345(0x2E,0x80);   //使能 DATA_READY 中断
  152.    Single_Write_ADXL345(0x1E,0x00);   //X 偏移量 根据测试传感器的状态写入pdf29页
  153.    Single_Write_ADXL345(0x1F,0x00);   //Y 偏移量 根据测试传感器的状态写入pdf29页
  154.    Single_Write_ADXL345(0x20,0x05);   //Z 偏移量 根据测试传感器的状态写入pdf29页
  155. }


  156. float operation(uchar starti)
  157. {
  158.         float  dis_data        ;
  159.         int temp;
  160.         temp=(BUF[starti+1]<<8)+BUF[starti];  //合成数据
  161. //        write_com(0x80);  
  162.         if(temp<0)
  163.         {
  164.                 temp=-temp;
  165.                 flag=1;

  166.         }
  167.         else flag=0; //显示空格

  168.     dis_data=(float)temp*3.9;  //计算数据和显示,查考ADXL345快速入门第4页
  169.   return dis_data;
  170. }
  171. void display_x()         //显示x轴
  172. {   
  173.    conversion(dis_datax);          //转换出显示需要的数据
  174.    
  175.         write_com(0x80);
  176.         if(flag==0)        write_dat(' ');
  177.         else write_dat('-');
  178.         write_dat('X');
  179.         write_dat(':');
  180.         write_dat(qian);

  181.         write_dat('.');
  182.         write_dat(bai);
  183.         write_dat(shi);
  184.         write_dat('g');       
  185. }

  186. void display_y()        //显示y轴
  187. {   
  188.    
  189.   // dis_datay=operation(2);
  190.     conversion(dis_datay);          //转换出显示需要的数据
  191.         write_com(0x80+8);
  192.         if(flag==0)         write_dat(' ');
  193.         else write_dat('-');
  194.         write_dat('Y');
  195.         write_dat(':');
  196.         write_dat(qian);

  197.         write_dat('.');
  198.         write_dat(bai);
  199.         write_dat(shi);
  200.         write_dat('g');

  201. }

  202. void display_z()           //显示z轴
  203. {  

  204. //  dis_dataz=operation(4);
  205.     conversion(dis_dataz);           //转换出显示需要的数据
  206.         write_com(0x80+0x40);
  207.         if(flag==0)                  write_dat(' ');
  208.         else write_dat('-');
  209.         write_dat('Z');
  210.         write_dat(':');
  211.         write_dat(qian);

  212.         write_dat('.');
  213.         write_dat(bai);
  214.         write_dat(shi);
  215.         write_dat('g');
  216. }

  217. void countstep()
  218. {
  219.         dis_datax=operation(0);
  220.         dis_datay=operation(2);
  221.    dis_dataz=operation(4);

  222.         acc1=acc;
  223.         acc=sqrt(dis_dataz*dis_dataz+dis_datax*dis_datax+dis_datay*dis_datay)  ;
  224.         if(acc1<990&&acc>1010)
  225. //        if(fabs(acc-acc1)>140&&miao1!=miao)

  226.         {
  227.         //        miao1=miao;
  228.                 count++;
  229.         }
  230.         write_com(0x80);
  231.         conversion(acc);
  232.         write_dat('A');
  233.         write_dat(':');
  234.         write_dat(qian);

  235.         write_dat('.');
  236.         write_dat(bai);
  237.         write_dat(shi);
  238.         write_dat('g');



  239.         write_com(0x80+0x40);
  240.         write_dat('C');
  241.         write_dat('o');
  242.         write_dat('u');
  243.         write_dat('n');
  244.         write_dat('t');
  245.         write_dat(':');
  246.         write_dat(count/100+0x30);
  247.         write_dat((count%100)/10+0x30);
  248.         write_dat(count%10+0x30);


  249. }
  250. void ADXL345_Measure()                         //测量角度值并显示
  251. {
  252.         Multiple_read_ADXL345();     //连续读出数据,存储在BUF中
  253. //        display_x();                 //---------显示X轴
  254. //        display_y();                 //---------显示Y轴
  255. //        display_z();                 //---------显示Z轴       
  256.         countstep();

  257. }



  258. void main()
  259. {
  260.         init();
  261.         Init_ADXL345();
  262.         while(1)
  263.         {
  264.         ADXL345_Measure();
  265.            }       
  266. }
复制代码

程序2:ds1302+5110液晶显示的adxl345加速度 计步器版本:http://www.51hei.com/bbs/dpj-50084-1.html



作者: 陈念阳    时间: 2016-5-11 11:08
我也想做,希望得到帮助
作者: 克罗弗多    时间: 2016-5-12 12:51
感谢楼主分享!
作者: 爱玩单片机    时间: 2016-5-12 21:21
下来学习adxl345那里可以买到
作者: lewinxu    时间: 2016-5-15 13:13
感谢分享

作者: 无敌的馒头    时间: 2016-5-20 14:31
感谢分享
作者: 无敌的馒头    时间: 2016-5-20 14:31
正是急需的时候 谢谢大神分享
作者: niso    时间: 2016-7-22 13:51
感谢分享!!
作者: wutong    时间: 2016-8-26 00:56
感谢分享!找了好久,还是论坛有货
作者: qq627472819    时间: 2016-8-30 20:23
好东西!!!!谢谢
作者: keepstudying    时间: 2016-10-5 17:15
谢谢楼主
作者: fresh    时间: 2016-10-17 21:57
这个压缩包有仿真图吗

作者: fresh    时间: 2016-10-19 18:53
可以给个仿真图吗
作者: fresh    时间: 2016-10-19 22:32
void conversion(uint temp_data)  
{  
    wan=temp_data/10000+0x30 ;
    temp_data=temp_data%10000;   //取余运算
        qian=temp_data/1000+0x30 ;
    temp_data=temp_data%1000;    //取余运算
    bai=temp_data/100+0x30   ;
    temp_data=temp_data%100;     //取余运算                                 -e----------------eee-e
    shi=temp_data/10+0x30    ;
    temp_data=temp_data%10;      //取余运算
    ge=temp_data+0x30;         
}
为什么加0x30
作者: qq779089973    时间: 2016-11-24 23:49
正需要呢  谢谢分享
作者: zhahl    时间: 2016-11-29 22:07
大神,能给个原图吗?
作者: zhahl    时间: 2016-11-29 22:09
大神能给个元器件清单吗?
作者: lobagoo    时间: 2016-12-3 12:13
求全部程序

作者: 大小管    时间: 2016-12-12 17:54
感谢分享
作者: 小时候可花    时间: 2016-12-15 00:02
不错不错 正想做这个呢
作者: 小时候可花    时间: 2016-12-15 00:13
Tbucuo 不错  可是 我烧录不行学习学习吧
作者: 慢慢2    时间: 2017-2-28 19:50
正需要
作者: zhangtaoopen    时间: 2017-2-28 22:09
请问记步数原理是什么,要怎么做才能记一步
作者: qiang275129042    时间: 2017-3-2 09:32
感谢分享
作者: 您的照片    时间: 2017-3-10 10:35

 感谢楼主分享!

作者: 您的照片    时间: 2017-3-11 15:23
谢谢大神的分享
作者: ygxdh    时间: 2017-4-6 21:44
谢谢大神
作者: 得不到    时间: 2017-4-9 20:33
准备学习学习
作者: xiaocaiyimei    时间: 2017-4-11 20:19
fresh 发表于 2016-10-19 22:32
void conversion(uint temp_data)  
{  
    wan=temp_data/10000+0x30 ;

0x30的ASCII码是0
作者: xiaocaiyimei    时间: 2017-4-11 20:23
非常感谢分享!
作者: zhulu1990    时间: 2017-4-13 15:44

感谢分享
作者: 此生休    时间: 2017-4-15 14:14
感谢分享
作者: lmlssg    时间: 2017-4-22 15:24
非常感谢分享!
作者: 镇魂调    时间: 2017-5-5 10:11
请问楼主ADXL345有没仿真?是用什么代替的?
作者: discover123    时间: 2017-5-8 21:36
zhahl 发表于 2016-11-29 22:07
大神,能给个原图吗?

你用哪种软件进行仿真?
作者: boen    时间: 2017-5-12 14:28
请问stc板子 怎么修改管脚
作者: reboot    时间: 2017-5-12 19:08
正是急需的时候 谢谢大神分享!!!!
作者: wangxia    时间: 2017-6-1 16:03
大神  怎么获得黑币
作者: wangxia    时间: 2017-6-1 16:04
小时候可花 发表于 2016-12-15 00:13
Tbucuo 不错  可是 我烧录不行学习学习吧

加油加油加油加油
作者: wangxia    时间: 2017-6-1 16:05
lobagoo 发表于 2016-12-3 12:13
**** 作者被禁止或删除 内容自动屏蔽 ****

我也想要知道全部的  你有吗
作者: 清风1234    时间: 2017-6-1 16:06
很想下载,但是下载不了
作者: wangxia    时间: 2017-6-1 16:18
用的是lcd1602显示屏吗
作者: huanx    时间: 2017-7-10 18:12
这个可以!是个参考
作者: lilanzl    时间: 2017-12-5 10:43
感谢分享!
作者: 曼殊姓苏    时间: 2017-12-19 14:41
有个小问题,这个程序烧进单片机后液晶屏为什么没亮呢?
作者: 12.22    时间: 2017-12-22 15:34
感谢大神分享
作者: ssk1va    时间: 2018-3-15 09:56
急需,感谢分享
作者: AAA电子    时间: 2018-3-28 07:21
正需要,试试可以不
作者: ccccy007    时间: 2018-4-16 09:33
下载下来是假的 不要被骗了
作者: djgogo    时间: 2018-4-20 16:27
请问一个程序是基于51还是52的呢?
作者: djgogo    时间: 2018-4-24 11:17
敢问大神用的可是SPI通信方式/

作者: 空小白格    时间: 2018-5-7 17:24
boen 发表于 2017-5-12 14:28
**** 作者被禁止或删除 内容自动屏蔽 ****

你的STC板子的管脚怎么修改的

作者: 枫林谷    时间: 2018-7-6 17:10
我这个也是在51上找的,但是只亮屏,不显示

adxl345.rar

133.75 KB, 下载次数: 12, 下载积分: 黑币 -5


作者: hwasun    时间: 2019-2-15 20:31
感谢楼主分享!
作者: 我不知道-    时间: 2019-3-30 21:59
镇魂调 发表于 2017-5-5 10:11
**** 作者被禁止或删除 内容自动屏蔽 ****

同问,现在拟解决了吗
作者: 25Hzzz    时间: 2019-4-3 16:41
很不错,收藏了
作者: 15650170171    时间: 2019-4-12 15:43
fresh 发表于 2016-10-19 22:32
void conversion(uint temp_data)  
{  
    wan=temp_data/10000+0x30 ;

0x30对应字符'0'
作者: 15650170171    时间: 2019-4-12 15:44
感谢大神分享

作者: gyt    时间: 2019-4-15 13:07
感谢分享,已经在测试了
作者: 刘敏夫    时间: 2019-5-8 17:51
fresh 发表于 2016-10-19 18:53
可以给个仿真图吗

adxl345在仿真里库里找不到
作者: DZD    时间: 2019-5-13 10:12
acc=sqrt(dis_dataz*dis_dataz+dis_datax*dis_datax+dis_datay*dis_datay)  ;这是什么意思

作者: DZD    时间: 2019-5-13 10:45
acc1=acc;
        acc=sqrt(dis_dataz*dis_dataz+dis_datax*dis_datax+dis_datay*dis_datay)  ;
        if(acc1<990&&acc>1010)
什么意思

作者: zctwss321    时间: 2019-5-13 14:41
硬件连接图呢?拍几张啊
作者: fy12    时间: 2019-12-3 19:40
想要一个基于mpu6050的计步程序
作者: 王超c    时间: 2020-3-4 16:29
主函数空?

作者: LISIQI    时间: 2021-5-12 14:30
Proteus里面找不到ADXL怎么办
作者: 小草半年    时间: 2022-3-31 12:52
感谢分享!找了好久,还是论坛有货
作者: zw8957    时间: 2022-4-24 14:01
LISIQI 发表于 2021-5-12 14:30
Proteus里面找不到ADXL怎么办

同问,这个仿真怎么解决啊?




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1