久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 29478|回復: 68
打印 上一主題 下一主題
收起左側

ADXL345單片機計步器程序

  [復制鏈接]
跳轉到指定樓層
樓主
ID:115111 發表于 2016-5-11 00:00 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式

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.zg4o1577.cn/bbs/dpj-50084-1.html


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏13 分享淘帖 頂1 踩
回復

使用道具 舉報

沙發
ID:119999 發表于 2016-5-11 11:08 | 只看該作者
我也想做,希望得到幫助
回復

使用道具 舉報

板凳
ID:120268 發表于 2016-5-12 12:51 | 只看該作者
感謝樓主分享!
回復

使用道具 舉報

地板
ID:68727 發表于 2016-5-12 21:21 來自手機 | 只看該作者
下來學習adxl345那里可以買到
回復

使用道具 舉報

5#
ID:120928 發表于 2016-5-15 13:13 | 只看該作者
感謝分享
回復

使用道具 舉報

6#
ID:119279 發表于 2016-5-20 14:31 | 只看該作者
感謝分享
回復

使用道具 舉報

7#
ID:119279 發表于 2016-5-20 14:31 | 只看該作者
正是急需的時候 謝謝大神分享
回復

使用道具 舉報

8#
ID:134612 發表于 2016-7-22 13:51 | 只看該作者
感謝分享!!
回復

使用道具 舉報

9#
ID:137625 發表于 2016-8-26 00:56 | 只看該作者
感謝分享!找了好久,還是論壇有貨
回復

使用道具 舉報

10#
ID:99036 發表于 2016-8-30 20:23 | 只看該作者
好東西!!!!謝謝
回復

使用道具 舉報

11#
ID:141382 發表于 2016-10-5 17:15 | 只看該作者
謝謝樓主
回復

使用道具 舉報

12#
ID:143128 發表于 2016-10-17 21:57 | 只看該作者
這個壓縮包有仿真圖嗎
回復

使用道具 舉報

13#
ID:143128 發表于 2016-10-19 18:53 | 只看該作者
可以給個仿真圖嗎
回復

使用道具 舉報

14#
ID:143128 發表于 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
回復

使用道具 舉報

15#
ID:55331 發表于 2016-11-24 23:49 | 只看該作者
正需要呢  謝謝分享
回復

使用道具 舉報

16#
ID:151000 發表于 2016-11-29 22:07 | 只看該作者
大神,能給個原圖嗎?
回復

使用道具 舉報

17#
ID:151000 發表于 2016-11-29 22:09 | 只看該作者
大神能給個元器件清單嗎?
回復

使用道具 舉報

18#
ID:151852 發表于 2016-12-3 12:13 | 只看該作者
求全部程序
回復

使用道具 舉報

19#
ID:153114 發表于 2016-12-12 17:54 | 只看該作者
感謝分享
回復

使用道具 舉報

20#
ID:154881 發表于 2016-12-15 00:02 | 只看該作者
不錯不錯 正想做這個呢
回復

使用道具 舉報

21#
ID:154881 發表于 2016-12-15 00:13 | 只看該作者
Tbucuo 不錯  可是 我燒錄不行學習學習吧
回復

使用道具 舉報

22#
ID:167226 發表于 2017-2-28 19:50 | 只看該作者
正需要
回復

使用道具 舉報

23#
ID:167265 發表于 2017-2-28 22:09 | 只看該作者
請問記步數原理是什么,要怎么做才能記一步
回復

使用道具 舉報

24#
ID:51533 發表于 2017-3-2 09:32 | 只看該作者
感謝分享
回復

使用道具 舉報

25#
ID:169448 發表于 2017-3-10 10:35 | 只看該作者

 感謝樓主分享!
回復

使用道具 舉報

26#
ID:169448 發表于 2017-3-11 15:23 | 只看該作者
謝謝大神的分享
回復

使用道具 舉報

27#
ID:186896 發表于 2017-4-6 21:44 | 只看該作者
謝謝大神
回復

使用道具 舉報

28#
ID:156639 發表于 2017-4-9 20:33 | 只看該作者
準備學習學習
回復

使用道具 舉報

29#
ID:188124 發表于 2017-4-11 20:19 | 只看該作者
fresh 發表于 2016-10-19 22:32
void conversion(uint temp_data)  
{  
    wan=temp_data/10000+0x30 ;

0x30的ASCII碼是0
回復

使用道具 舉報

30#
ID:188124 發表于 2017-4-11 20:23 | 只看該作者
非常感謝分享!
回復

使用道具 舉報

31#
ID:189075 發表于 2017-4-13 15:44 | 只看該作者

感謝分享
回復

使用道具 舉報

32#
ID:189826 發表于 2017-4-15 14:14 | 只看該作者
感謝分享
回復

使用道具 舉報

33#
ID:192342 發表于 2017-4-22 15:24 | 只看該作者
非常感謝分享!
回復

使用道具 舉報

34#
ID:196655 發表于 2017-5-5 10:11 | 只看該作者
請問樓主ADXL345有沒仿真?是用什么代替的?
回復

使用道具 舉報

35#
ID:197695 發表于 2017-5-8 21:36 | 只看該作者
zhahl 發表于 2016-11-29 22:07
大神,能給個原圖嗎?

你用哪種軟件進行仿真?
回復

使用道具 舉報

36#
ID:199657 發表于 2017-5-12 14:28 | 只看該作者
請問stc板子 怎么修改管腳
回復

使用道具 舉報

37#
ID:192323 發表于 2017-5-12 19:08 | 只看該作者
正是急需的時候 謝謝大神分享!!!!
回復

使用道具 舉報

38#
ID:206744 發表于 2017-6-1 16:03 來自手機 | 只看該作者
大神  怎么獲得黑幣
回復

使用道具 舉報

39#
ID:206744 發表于 2017-6-1 16:04 來自手機 | 只看該作者
小時候可花 發表于 2016-12-15 00:13
Tbucuo 不錯  可是 我燒錄不行學習學習吧

加油加油加油加油
回復

使用道具 舉報

40#
ID:206744 發表于 2017-6-1 16:05 來自手機 | 只看該作者
lobagoo 發表于 2016-12-3 12:13
**** 作者被禁止或刪除 內容自動屏蔽 ****

我也想要知道全部的  你有嗎
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 一级片免费观看 | 亚洲 欧美 在线 一区 | av永久 | 国产一区二区三区色淫影院 | 亚洲国产精品久久久 | 91免费高清 | 精品国产18久久久久久二百 | 日本a在线| 天天色图 | 中文字幕在线三区 | 亚洲一区久久久 | 国产成人av在线 | 国产精品美女久久久久aⅴ国产馆 | 91偷拍精品一区二区三区 | www.国产.com| 日韩免费中文字幕 | 日韩成人影院在线观看 | 亚洲欧美中文字幕在线观看 | 亚洲视频在线看 | 成人毛片视频免费 | 久久精品亚洲欧美日韩久久 | 亚洲一区综合 | 亚洲精品2| 国产高清精品在线 | 国产 日韩 欧美 在线 | 日韩a级片 | 欧美国产精品 | 久久久久久成人网 | 伊人色综合久久久天天蜜桃 | 欧美在线视频二区 | 狠狠色狠狠色综合系列 | 亚洲网视频 | 精品一二区 | 色综合一区| 91啪亚洲精品 | 99亚洲| 蜜桃视频在线观看www社区 | 久国产视频 | 免费一级黄色录像 | 亚洲国产一区二区三区 | 视频一区二区国产 |