找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 29671|回復(fù): 68
收起左側(cè)

ADXL345單片機(jī)計(jì)步器程序

  [復(fù)制鏈接]
ID:115111 發(fā)表于 2016-5-11 00:00 | 顯示全部樓層 |閱讀模式
0.png
adxl345芯片實(shí)現(xiàn)的計(jì)步器,顯示用的是1602液晶屏,下面可以下載完整的程序.


完整的源代碼下載: adxl345計(jì)步器程序設(shè)計(jì).rar (39.38 KB, 下載次數(shù): 760)

部分源碼預(yù)覽:
程序1:1602液晶顯示的adxl345加速度 計(jì)步器版本:
  1. #include<reg52.h>
  2. #include<math.h>
  3. #include"1602.h"
  4. #include  <INTRINS.H>

  5. #define        SlaveAddress   0xA6          //1010 0110    定義器件在IIC總線中的從地址,根據(jù)ALT  ADDRESS地址引腳不同修改
  6.                               //ALT  ADDRESS引腳接地時(shí)地址為0xA6,接電源時(shí)地址為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;   //取余運(yùn)算
  17.         qian=temp_data/1000+0x30 ;
  18.     temp_data=temp_data%1000;    //取余運(yùn)算
  19.     bai=temp_data/100+0x30   ;
  20.     temp_data=temp_data%100;     //取余運(yùn)算                                 -e----------------eee-e
  21.     shi=temp_data/10+0x30    ;
  22.     temp_data=temp_data%10;      //取余運(yùn)算
  23.     ge=temp_data+0x30;        
  24. }
  25. void delay6us()                 //6us延時(shí)函數(shù)
  26. {

  27.         _nop_();        _nop_();          



  28. }

  29. void delay_ms(uint n)       //N ms延時(shí)函數(shù)
  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;                    //拉高數(shù)據(jù)線
  39.     sclk = 1;                    //拉高時(shí)鐘線
  40.     delay6us();                 //延時(shí)
  41.     sda = 0;                    //產(chǎn)生下降沿
  42.     delay6us();                 //延時(shí)
  43.     sclk = 0;                    //拉低時(shí)鐘線
  44. }

  45. void ADXL345_Stop()
  46. {
  47.     sda = 0;                    //拉低數(shù)據(jù)線
  48.     sclk = 1;                    //拉高時(shí)鐘線
  49.     delay6us();                 //延時(shí)
  50.     sda = 1;                    //產(chǎn)生上升沿
  51.     delay6us();                 //延時(shí)
  52. }

  53. void ADXL345_SendACK(bit ack)
  54. {
  55.     sda = ack;                  //寫(xiě)應(yīng)答信號(hào)
  56.     sclk = 1;                    //拉高時(shí)鐘線
  57.     delay6us();                 //延時(shí)
  58.     sclk = 0;                    //拉低時(shí)鐘線
  59.     delay6us();                 //延時(shí)
  60. }


  61. bit ADXL345_RecvACK()
  62. {
  63.     sclk = 1;                    //拉高時(shí)鐘線
  64.     delay6us();                 //延時(shí)
  65.     CY = sda;                   //讀應(yīng)答信號(hào)
  66.     sclk = 0;                    //拉低時(shí)鐘線
  67.     delay6us();                 //延時(shí)

  68.     return CY;
  69. }


  70. void ADXL345_SendByte(uchar dat)
  71. {
  72.     uchar i;
  73. //        sclk = 0;                //拉低時(shí)鐘線

  74.     for (i=0; i<8; i++)         //8位計(jì)數(shù)器
  75.     {
  76.         dat <<= 1;              //移出數(shù)據(jù)的最高位
  77.         sda = CY;               //送數(shù)據(jù)口
  78.         sclk = 1;                //拉高時(shí)鐘線
  79.         delay6us();             //延時(shí)
  80.         sclk = 0;                //拉低時(shí)鐘線
  81.         delay6us();             //延時(shí)
  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.                    //使能內(nèi)部上拉,準(zhǔn)備讀取數(shù)據(jù),
  92.     for (i=0; i<8; i++)         //8位計(jì)數(shù)器
  93.     {
  94.         dat <<= 1;
  95.         sclk = 1;                //拉高時(shí)鐘線
  96.         delay6us();             //延時(shí)
  97.         dat |= sda;             //讀數(shù)據(jù)               
  98.         sclk = 0;                //拉低時(shí)鐘線
  99.         delay6us();             //延時(shí)

  100.     }


  101.     return dat;
  102. }

  103. void Single_Write_ADXL345(uchar REG_Address,uchar REG_data)
  104. {
  105.     ADXL345_Start();                  //起始信號(hào)
  106.     ADXL345_SendByte(SlaveAddress);   //發(fā)送設(shè)備地址+寫(xiě)信號(hào)
  107.     ADXL345_SendByte(REG_Address);    //內(nèi)部寄存器地址,請(qǐng)參考中文pdf22頁(yè)
  108.     ADXL345_SendByte(REG_data);       //內(nèi)部寄存器數(shù)據(jù),請(qǐng)參考中文pdf22頁(yè)
  109.     ADXL345_Stop();                   //發(fā)送停止信號(hào)
  110. }

  111. uchar Single_Read_ADXL345(uchar REG_Address)
  112. {
  113.         uchar REG_data;
  114.     ADXL345_Start();            
  115.        
  116.        
  117.        
  118.                       //起始信號(hào)
  119.     ADXL345_SendByte(SlaveAddress);           //發(fā)送設(shè)備地址+寫(xiě)信號(hào)
  120.     ADXL345_SendByte(REG_Address);                   //發(fā)送存儲(chǔ)單元地址,從0開(kāi)始       
  121.     ADXL345_Start();                          //起始信號(hào)
  122.     ADXL345_SendByte(SlaveAddress+1);         //發(fā)送設(shè)備地址+讀信號(hào)
  123.     REG_data=ADXL345_RecvByte();              //讀出寄存器數(shù)據(jù)
  124.         ADXL345_SendACK(1);   
  125.         ADXL345_Stop();                           //停止信號(hào)
  126.     return REG_data;
  127. }

  128. void Multiple_read_ADXL345()
  129. {   
  130.         uchar i;
  131.     ADXL345_Start();                          //起始信號(hào)
  132.     ADXL345_SendByte(SlaveAddress);           //發(fā)送設(shè)備地址+寫(xiě)信號(hào)           1010 0110
  133.     ADXL345_SendByte(0x32);                   //發(fā)送存儲(chǔ)單元地址,從0x32開(kāi)始 0011 0010
  134.     ADXL345_Start();                          //起始信號(hào)
  135.     ADXL345_SendByte(SlaveAddress+1);         //發(fā)送設(shè)備地址+讀信號(hào)           1010 0111
  136.         for (i=0; i<6; i++)                      //連續(xù)讀取6個(gè)地址數(shù)據(jù),存儲(chǔ)中BUF
  137.     {
  138.         BUF[i] = ADXL345_RecvByte();          //BUF[0]存儲(chǔ)0x32地址中的數(shù)據(jù)
  139.         if(i == 5)        ADXL345_SendACK(1);       //最后一個(gè)數(shù)據(jù)需要回NOACK
  140.         else        ADXL345_SendACK(0);           //回應(yīng)ACK
  141.     }
  142.     ADXL345_Stop();                          //停止信號(hào)
  143.     delay_ms(10);
  144. }

  145. void Init_ADXL345()           //初始化ADXL345,根據(jù)需要請(qǐng)參考pdf進(jìn)行修改***********************
  146. {
  147. //        delay(500);                                          //上電延時(shí)
  148.    Single_Write_ADXL345(0x31,0x2B);   //測(cè)量范圍,正負(fù)16g,13位模式
  149.    Single_Write_ADXL345(0x2C,0x06);   //0000 0110速率設(shè)定為6.25 參考pdf13頁(yè)
  150.    Single_Write_ADXL345(0x2D,0x08);   //選擇電源模式   參考pdf24頁(yè)
  151.    Single_Write_ADXL345(0x2E,0x80);   //使能 DATA_READY 中斷
  152.    Single_Write_ADXL345(0x1E,0x00);   //X 偏移量 根據(jù)測(cè)試傳感器的狀態(tài)寫(xiě)入pdf29頁(yè)
  153.    Single_Write_ADXL345(0x1F,0x00);   //Y 偏移量 根據(jù)測(cè)試傳感器的狀態(tài)寫(xiě)入pdf29頁(yè)
  154.    Single_Write_ADXL345(0x20,0x05);   //Z 偏移量 根據(jù)測(cè)試傳感器的狀態(tài)寫(xiě)入pdf29頁(yè)
  155. }


  156. float operation(uchar starti)
  157. {
  158.         float  dis_data        ;
  159.         int temp;
  160.         temp=(BUF[starti+1]<<8)+BUF[starti];  //合成數(shù)據(jù)
  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;  //計(jì)算數(shù)據(jù)和顯示,查考ADXL345快速入門(mén)第4頁(yè)
  169.   return dis_data;
  170. }
  171. void display_x()         //顯示x軸
  172. {   
  173.    conversion(dis_datax);          //轉(zhuǎn)換出顯示需要的數(shù)據(jù)
  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);          //轉(zhuǎn)換出顯示需要的數(shù)據(jù)
  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);           //轉(zhuǎn)換出顯示需要的數(shù)據(jù)
  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()                         //測(cè)量角度值并顯示
  251. {
  252.         Multiple_read_ADXL345();     //連續(xù)讀出數(shù)據(jù),存儲(chǔ)在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. }
復(fù)制代碼

程序2:ds1302+5110液晶顯示的adxl345加速度 計(jì)步器版本:http://www.torrancerestoration.com/bbs/dpj-50084-1.html


相關(guān)帖子

回復(fù)

使用道具 舉報(bào)

ID:119999 發(fā)表于 2016-5-11 11:08 | 顯示全部樓層
我也想做,希望得到幫助
回復(fù)

使用道具 舉報(bào)

ID:120268 發(fā)表于 2016-5-12 12:51 | 顯示全部樓層
感謝樓主分享!
回復(fù)

使用道具 舉報(bào)

ID:68727 發(fā)表于 2016-5-12 21:21 來(lái)自手機(jī) | 顯示全部樓層
下來(lái)學(xué)習(xí)adxl345那里可以買(mǎi)到
回復(fù)

使用道具 舉報(bào)

ID:120928 發(fā)表于 2016-5-15 13:13 | 顯示全部樓層
感謝分享
回復(fù)

使用道具 舉報(bào)

ID:119279 發(fā)表于 2016-5-20 14:31 | 顯示全部樓層
感謝分享
回復(fù)

使用道具 舉報(bào)

ID:119279 發(fā)表于 2016-5-20 14:31 | 顯示全部樓層
正是急需的時(shí)候 謝謝大神分享
回復(fù)

使用道具 舉報(bào)

ID:134612 發(fā)表于 2016-7-22 13:51 | 顯示全部樓層
感謝分享!
回復(fù)

使用道具 舉報(bào)

ID:137625 發(fā)表于 2016-8-26 00:56 | 顯示全部樓層
感謝分享!找了好久,還是論壇有貨
回復(fù)

使用道具 舉報(bào)

ID:99036 發(fā)表于 2016-8-30 20:23 | 顯示全部樓層
好東西。。。≈x謝
回復(fù)

使用道具 舉報(bào)

ID:141382 發(fā)表于 2016-10-5 17:15 | 顯示全部樓層
謝謝樓主
回復(fù)

使用道具 舉報(bào)

ID:143128 發(fā)表于 2016-10-17 21:57 | 顯示全部樓層
這個(gè)壓縮包有仿真圖嗎
回復(fù)

使用道具 舉報(bào)

ID:143128 發(fā)表于 2016-10-19 18:53 | 顯示全部樓層
可以給個(gè)仿真圖嗎
回復(fù)

使用道具 舉報(bào)

ID:143128 發(fā)表于 2016-10-19 22:32 | 顯示全部樓層
void conversion(uint temp_data)  
{  
    wan=temp_data/10000+0x30 ;
    temp_data=temp_data%10000;   //取余運(yùn)算
        qian=temp_data/1000+0x30 ;
    temp_data=temp_data%1000;    //取余運(yùn)算
    bai=temp_data/100+0x30   ;
    temp_data=temp_data%100;     //取余運(yùn)算                                 -e----------------eee-e
    shi=temp_data/10+0x30    ;
    temp_data=temp_data%10;      //取余運(yùn)算
    ge=temp_data+0x30;         
}
為什么加0x30
回復(fù)

使用道具 舉報(bào)

ID:55331 發(fā)表于 2016-11-24 23:49 | 顯示全部樓層
正需要呢  謝謝分享
回復(fù)

使用道具 舉報(bào)

ID:151000 發(fā)表于 2016-11-29 22:07 | 顯示全部樓層
大神,能給個(gè)原圖嗎?
回復(fù)

使用道具 舉報(bào)

ID:151000 發(fā)表于 2016-11-29 22:09 | 顯示全部樓層
大神能給個(gè)元器件清單嗎?
回復(fù)

使用道具 舉報(bào)

ID:151852 發(fā)表于 2016-12-3 12:13 | 顯示全部樓層
求全部程序
回復(fù)

使用道具 舉報(bào)

ID:153114 發(fā)表于 2016-12-12 17:54 | 顯示全部樓層
感謝分享
回復(fù)

使用道具 舉報(bào)

ID:154881 發(fā)表于 2016-12-15 00:02 | 顯示全部樓層
不錯(cuò)不錯(cuò) 正想做這個(gè)呢
回復(fù)

使用道具 舉報(bào)

ID:154881 發(fā)表于 2016-12-15 00:13 | 顯示全部樓層
Tbucuo 不錯(cuò)  可是 我燒錄不行學(xué)習(xí)學(xué)習(xí)吧
回復(fù)

使用道具 舉報(bào)

ID:167226 發(fā)表于 2017-2-28 19:50 | 顯示全部樓層
正需要
回復(fù)

使用道具 舉報(bào)

ID:167265 發(fā)表于 2017-2-28 22:09 | 顯示全部樓層
請(qǐng)問(wèn)記步數(shù)原理是什么,要怎么做才能記一步
回復(fù)

使用道具 舉報(bào)

ID:51533 發(fā)表于 2017-3-2 09:32 | 顯示全部樓層
感謝分享
回復(fù)

使用道具 舉報(bào)

ID:169448 發(fā)表于 2017-3-10 10:35 | 顯示全部樓層

 感謝樓主分享!
回復(fù)

使用道具 舉報(bào)

ID:169448 發(fā)表于 2017-3-11 15:23 | 顯示全部樓層
謝謝大神的分享
回復(fù)

使用道具 舉報(bào)

ID:186896 發(fā)表于 2017-4-6 21:44 | 顯示全部樓層
謝謝大神
回復(fù)

使用道具 舉報(bào)

ID:156639 發(fā)表于 2017-4-9 20:33 | 顯示全部樓層
準(zhǔn)備學(xué)習(xí)學(xué)習(xí)
回復(fù)

使用道具 舉報(bào)

ID:188124 發(fā)表于 2017-4-11 20:19 | 顯示全部樓層
fresh 發(fā)表于 2016-10-19 22:32
void conversion(uint temp_data)  
{  
    wan=temp_data/10000+0x30 ;

0x30的ASCII碼是0
回復(fù)

使用道具 舉報(bào)

ID:188124 發(fā)表于 2017-4-11 20:23 | 顯示全部樓層
非常感謝分享!
回復(fù)

使用道具 舉報(bào)

ID:189075 發(fā)表于 2017-4-13 15:44 | 顯示全部樓層

感謝分享
回復(fù)

使用道具 舉報(bào)

ID:189826 發(fā)表于 2017-4-15 14:14 | 顯示全部樓層
感謝分享
回復(fù)

使用道具 舉報(bào)

ID:192342 發(fā)表于 2017-4-22 15:24 | 顯示全部樓層
非常感謝分享!
回復(fù)

使用道具 舉報(bào)

ID:196655 發(fā)表于 2017-5-5 10:11 | 顯示全部樓層
請(qǐng)問(wèn)樓主ADXL345有沒(méi)仿真?是用什么代替的?
回復(fù)

使用道具 舉報(bào)

ID:197695 發(fā)表于 2017-5-8 21:36 | 顯示全部樓層
zhahl 發(fā)表于 2016-11-29 22:07
大神,能給個(gè)原圖嗎?

你用哪種軟件進(jìn)行仿真?
回復(fù)

使用道具 舉報(bào)

ID:199657 發(fā)表于 2017-5-12 14:28 | 顯示全部樓層
請(qǐng)問(wèn)stc板子 怎么修改管腳
回復(fù)

使用道具 舉報(bào)

ID:192323 發(fā)表于 2017-5-12 19:08 | 顯示全部樓層
正是急需的時(shí)候 謝謝大神分享。。。
回復(fù)

使用道具 舉報(bào)

ID:206744 發(fā)表于 2017-6-1 16:03 來(lái)自手機(jī) | 顯示全部樓層
大神  怎么獲得黑幣
回復(fù)

使用道具 舉報(bào)

ID:206744 發(fā)表于 2017-6-1 16:04 來(lái)自手機(jī) | 顯示全部樓層
小時(shí)候可花 發(fā)表于 2016-12-15 00:13
Tbucuo 不錯(cuò)  可是 我燒錄不行學(xué)習(xí)學(xué)習(xí)吧

加油加油加油加油
回復(fù)

使用道具 舉報(bào)

ID:206744 發(fā)表于 2017-6-1 16:05 來(lái)自手機(jī) | 顯示全部樓層
lobagoo 發(fā)表于 2016-12-3 12:13
**** 作者被禁止或刪除 內(nèi)容自動(dòng)屏蔽 ****

我也想要知道全部的  你有嗎
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表