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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

請教各位大神為啥我把eeprom程序加進去了就不亮了

[復制鏈接]
跳轉到指定樓層
樓主
ID:332395 發表于 2018-5-18 13:31 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. /**************************************************************************************
  2. *                              溫度傳感器實驗                                                                                                  *
  3. 實現現象:        具體接線操作請看視頻。
  4.                         下載程序后,在溫度傳感器接口處,按照絲印方向插好溫度傳感器,數碼管就會顯示
  5.                         檢測的溫度值,
  6. 注意事項:                                                                                                                                                                  
  7. ***************************************************************************************/

  8. #include <reg52.h>                         //此文件中定義了單片機的一些特殊功能寄存器
  9. #include <stdio.h>         
  10. #include <eeprom.h>  

  11. typedef unsigned int u16;          //對數據類型進行聲明定義
  12. typedef unsigned char u8;
  13. #define WRITE24C02 0xA0   //10100000,器件地址,寫操作   
  14. #define READ24C02 0xA1   //10100001,器件地址,讀操作

  15. sbit LSA=P2^2;
  16. sbit LSB=P2^3;
  17. sbit LSC=P2^4;
  18. sbit key1=P1^0;
  19. sbit key2=P1^1;
  20. sbit zongkong=P2^7;
  21. sbit output=P2^6;
  22. sbit SO=P3^2;   
  23. sbit CS=P3^0;   
  24. sbit SCK=P3^1;

  25. char num=0;
  26. u8 xw[8],sdwd,a=101,sjwd;
  27. u8 code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};  
  28. void display0 (  te );
  29.      void display1(h);
  30. #define uchar unsigned char   
  31. #define uint unsigned int   //--------------熱電偶數字轉換器MAX6675  


  32. /*******************************************************************************
  33. * 函 數 名         : delay_ms(uchar ntimes)
  34. * 函數功能                   :
  35. * 輸    入         : temp
  36. * 輸    出         : 無
  37. *******************************************************************************/  

  38.    void delay(u16 i)
  39. {
  40.         while(i--);        
  41. }

  42. /********************************  
  43. //讀取MAX6675  
  44. *********************************/   
  45. int Read_6675()   
  46. { uchar i;   
  47.   uint dat_temp;   
  48.   uint dat_6675;   
  49.   i=0;   
  50.   dat_temp=0;   
  51.   dat_6675=0;   
  52.   //ready   
  53.   CS=0;   
  54.   //delay_us(10);   
  55.   SCK=0;   
  56.   //delay_us(10);   
  57.   //get D15-D0 from 6675   
  58.   for(i=0;i<16;i++)   
  59.   {      
  60.    SCK=1;     
  61.    dat_temp=dat_temp<<1;   
  62.    if(SO==1)   
  63.     dat_temp=dat_temp|0x01;   
  64.    SCK=0;   
  65.    //delay_us(10);   
  66.   }   
  67.   CS=1;   
  68.   dat_temp=dat_temp<<1;   
  69.   dat_temp=dat_temp>>4;   
  70.   dat_temp=dat_temp/4;   
  71.   dat_6675 =    dat_temp;   
  72.   return dat_6675;   
  73. }


  74. /*******************************************************************************
  75. * 函 數 名         : datapros()
  76. * 函數功能                   : 溫度讀取處理轉換函數
  77. * 輸    入         : temp
  78. * 輸    出         : 無
  79. *******************************************************************************/

  80. void datapros(int temp)         
  81. {
  82.            float tp;  
  83.         if(temp< 0)                                //當溫度值為負數
  84.           {
  85.                 xw[2] = 0x40;           //   -
  86.                 //因為讀取的溫度是實際溫度的補碼,所以減1,再取反求出原碼
  87.                 temp=temp-1;
  88.                 temp=~temp;
  89.                 tp=temp;
  90.                 temp=tp*0.0025*100+0.5;        
  91.                 //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  92.                 //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  93.                 //算加上0.5,還是在小數點后面。

  94.           }
  95.          else
  96.           {                        
  97.                 xw[0] = 0x00;
  98.                 tp=temp;//因為數據處理有小數點所以將溫度賦給一個浮點型變量
  99.                 //如果溫度是正的那么,那么正數的原碼就是補碼它本身
  100.                 temp=tp*0.0025*100+0.5;        
  101.                 //留兩個小數點就*100,+0.5是四舍五入,因為C語言浮點數轉換為整型的時候把小數點
  102.                 //后面的數自動去掉,不管是否大于0.5,而+0.5之后大于0.5的就是進1了,小于0.5的就
  103.                 //算加上0.5,還是在小數點后面。
  104.         }

  105.         xw[4] = smgduan[temp % 10000 / 1000];
  106.         xw[5] = smgduan[temp % 1000 / 100] | 0x80;
  107.         xw[6] = smgduan[temp % 100 / 10];
  108.         xw[7] = smgduan[temp % 10];
  109.         sjwd=temp % 10000 / 1000*10+temp % 1000 / 100;
  110. }


  111. /*******************************************************************************
  112. * 函數名         :DigDisplay()
  113. * 函數功能                 :數碼管顯示函數
  114. * 輸入           : 無
  115. * 輸出                  : 無
  116. *******************************************************************************/
  117. void DDP()
  118. {
  119.         u8 i;
  120.         for(i=0;i<8;i++)
  121.         {
  122.                 switch(i)         //位選,選擇點亮的數碼管,
  123.                 {
  124.                         case(0):
  125.                                 LSA=0;LSB=0;LSC=0; break;//顯示第0位
  126.                         case(1):
  127.                                 LSA=1;LSB=0;LSC=0; break;//顯示第1位
  128.                         case(2):
  129.                                 LSA=0;LSB=1;LSC=0; break;//顯示第2位
  130.                         case(3):
  131.                                 LSA=1;LSB=1;LSC=0; break;//顯示第3位
  132.                         case(4):
  133.                                 LSA=0;LSB=0;LSC=1; break;//顯示第4位
  134.                         case(5):
  135.                                 LSA=1;LSB=0;LSC=1; break;//顯示第5位
  136.                         case(6):
  137.                                 LSA=0;LSB=1;LSC=1; break;//顯示第6位
  138.                         case(7):
  139.                                 LSA=1;LSB=1;LSC=1; break;//顯示第7位        
  140.                 }
  141.                 P0=xw[i];//發送數據        
  142.                 delay(200);
  143.                 P0=0x00;//消隱
  144.         }               
  145. }

  146. /*******************************************************************************
  147. * 函 數 名       : Initialization
  148. * 函數功能                 : 初始化函數
  149. * 輸    入       : 無
  150. * 輸    出             : 無
  151. *******************************************************************************/
  152. void Initialization()
  153. {
  154.         uchar i=0;
  155.         P0=0x00;
  156.         P1=0x00;
  157.         P2=0XFF;
  158.         P3=0XFF;
  159.         sdwd=30;
  160.         for(i=0;i++;i<8)
  161.         {
  162.                 xw[i]=0x08;        
  163.         }
  164.         readeeprom();
  165.         datapros(Read_6675() );

  166. }

  167. /*******************************************************************************
  168. * 函 數 名       : main
  169. * 函數功能                 : 主函數
  170. * 輸    入       : 無
  171. * 輸    出             : 無
  172. *******************************************************************************/
  173. void main()
  174. {        
  175.         Initialization();
  176.         delay(50);
  177.         while(1)
  178.         {
  179.                 if(zongkong==1)
  180.                 {
  181.                         while(a>100)
  182.                         {
  183.                                 a=0;
  184.                                 datapros(Read_6675() );
  185.                
  186.                         }
  187.                         a++;
  188.                         xw[0]=smgduan[sdwd/10%10];
  189.                         xw[1]=smgduan[sdwd%10];
  190.                         xw[2]=0x08;
  191.                         xw[3]=0x08;
  192.                         DDP();
  193.                         if(key1==1)
  194.                         {
  195.                                 while(key1==1)DDP();
  196.                                 sdwd++;
  197.                                 if(sdwd>50)sdwd=50;
  198.                         }
  199.                         if(key2==1)
  200.                         {
  201.                                 while(key2==1)DDP();
  202.                                 sdwd--;
  203.                                 if(sdwd<10)sdwd=10;
  204.                         }
  205.                         if(sdwd>sjwd+2)
  206.                         {
  207.                                 output=0;               
  208.                         }
  209.                         if(sdwd<sjwd+1)
  210.                         {
  211.                                 output=1;               
  212.                         }
  213.                 }
  214.                 if(zongkong==0)
  215.                 {
  216.                         while(a>100)
  217.                         {
  218.                                 a=0;
  219.                                 datapros(Read_6675() );
  220.                         
  221.                         }
  222.                         a++;
  223.                         xw[0]=smgduan[sdwd/10%10];
  224.                         xw[1]=smgduan[sdwd%10];
  225.                         xw[2]=0x08;
  226.                         xw[3]=0x08;
  227.                         DDP();
  228.                         if(key1==1)
  229.                         {
  230.                                 while(key1==1)DDP();
  231.                                 sdwd++;
  232.                                 if(sdwd>50)sdwd=50;
  233.                         }
  234.                         if(key2==1)
  235.                         {
  236.                                 while(key2==1)DDP();
  237.                                 sdwd--;
  238.                                 if(sdwd<10)sdwd=10;
  239.                         }
  240.                         output=0;
  241.                 }                                
  242.         }               
  243. }

  244. #include "reg52.h"      //包含頭文件
  245. #include"intrins.h"     //_nop_();延時函數用
  246. #include<eeprom.h>

  247. #define uchar unsigned char
  248. #define uint  unsigned int

  249. void Delay1ms(uint y)
  250. {
  251.         uint x;
  252.         for( ; y>0; y--)
  253.         {
  254.                 for(x=110; x>0; x--);
  255.         }
  256. }



  257. //**************************************************************************************************
  258. //啟動(SCL為高,SDA由高變為低是一個開始條件)
  259. //**************************************************************************************************
  260. void start()  
  261. {        
  262.         sda=1;    //數據線置高,
  263.         _nop_();  //延時
  264.         scl=1;    //時鐘線置高
  265.         _nop_();  //延時
  266.         sda=0;    //數據線置低,由高變低
  267.         _nop_();  //延時
  268.         scl=0;    //時鐘線置低,準備發送或接收數據,總線進入忙狀態(I2C總線在空閑狀態時,SDA與SCL均被置高)
  269.         _nop_();  //延時
  270. }
  271. //**************************************************************************************************
  272. //停止(SCL為高,SDA由低變為高是一個結束條件)
  273. //**************************************************************************************************
  274. void stop()   
  275. {
  276.         sda=0;                   //數據線置低
  277.         _nop_();                 //延時
  278.         scl=1;                   //時鐘線置高
  279.         _nop_();                 //延時
  280.         sda=1;                   //數據線置高,由低變高
  281.         _nop_();                 //延時
  282. }
  283. //**************************************************************************************************
  284. //檢測應答(所有的地址和數據字都是以8bit,在第9個時鐘周期,從器件發出"0"信號來作為收到一個字的應答信號)
  285. //**************************************************************************************************
  286. void checkACK()                   //主器件檢測從器件是否返回應答
  287. {
  288.         scl=1;                        //時鐘線置高
  289.         _nop_();                      //延時
  290.         while(sda==1);                //等待第9個時鐘周期器件發出的響應信號"0"
  291.         scl=0;                        //時鐘線置低
  292.         _nop_();                      //延時
  293. }
  294. //**************************************************************************************************
  295. //發送應答(發送方為主器件,接收方為從器件,控制器作為從器件接收完1數據時,發送應答信號
  296. //**************************************************************************************************
  297. void sendACK(bit ACK)                  
  298. {
  299.     if(ACK)sda=1;            //如果i位為1則發送1,即發送"非應答信號"
  300.       else sda=0;            //如果i位為0則發送0,即發送"應答信號"        
  301.     scl=1;                   //時鐘線置高,給一個脈沖
  302.         _nop_();                 //延時
  303.         scl=0;                   //時鐘線置低
  304.         _nop_();                 //延時
  305. }
  306. //**************************************************************************************************
  307. //寫一字節
  308. //**************************************************************************************************
  309. void send_byte(uchar date)       //寫一個8位字
  310. {
  311.         uchar i,temp;                //定義局部變量
  312.         temp=date;                   //待發8位數據賦予temp
  313.         for(i=0;i<8;i++)             //循環8次,每次寫入1位,從最高位開始發送
  314.         {
  315.         if(temp&0x80)sda=1;      //如果temp最高位為1則發送1
  316.           else sda=0;            //如果temp最高位為0則發送0
  317.             _nop_();                 //延時
  318.                 scl=1;                   //給一個脈沖,發送sda當前這位數據
  319.                 _nop_();                 //延時,需大于4us(參考數據手冊時序圖)
  320.                 _nop_();              
  321.                 _nop_();                 
  322.                 _nop_();                 
  323.                 _nop_();               
  324.                 scl=0;                   //時鐘線置低,準備下一脈沖
  325.             _nop_();                 //延時,需大于4.7us(參考數據手冊時序圖)
  326.                 _nop_();              
  327.                 _nop_();                 
  328.                 _nop_();                 
  329.                 _nop_();  
  330.                 temp=temp<<1;            //左移1位,準備好下1位待發送的數據
  331.         }
  332.         checkACK();                  //查詢是否返回應答信號
  333. }
  334. //**************************************************************************************************
  335. //讀一字節
  336. //**************************************************************************************************
  337. uchar receive_byte()         //讀一個8位字
  338. {
  339.         uchar i,temp;            //定義局部變量
  340.         sda=1;                   //設置數據線為輸入
  341.         _nop_();                 //延時
  342.         for(i=0;i<8;i++)         //循環8次,每次讀取1位,從最高位開始接收
  343.         {
  344.                 scl=1;               //給一脈沖,準備發送1位數據            
  345.                 _nop_();             //延時,需大于4us(參考數據手冊時序圖)
  346.                 _nop_();              
  347.                 _nop_();                 
  348.                 _nop_();                 
  349.                 _nop_();
  350.                 temp=(temp<<1)|sda;  //讀取1位數據,放在temp最低位
  351.                 scl=0;               //準備給下1個脈沖
  352.             _nop_();             //延時,需大于4.7us(參考數據手冊時序圖)
  353.                 _nop_();              
  354.                 _nop_();                 
  355.                 _nop_();                 
  356.                 _nop_();      
  357.         }
  358.         return temp;             //返回讀取的8位數據
  359. }
  360. //**************************************************************************************************
  361. //向某I2C器件的某字地址寫一字節數據
  362. //**************************************************************************************************
  363. void write_word(uchar device_add,uchar word_add,uchar date)  //寫進去一個存儲數據
  364. {
  365.         start();                  //啟動
  366.         send_byte(device_add);    //選擇從器件地址,RW位為0,即選擇寫命令
  367.         send_byte(word_add);      //寫字地址
  368.         send_byte(date);          //寫數據
  369.         stop();                   //停止        
  370. }
  371.   //**************************************************************************************************
  372. //向某I2C器件的某字地址讀一字節數據
  373. //**************************************************************************************************
  374. uchar read_word(uchar device_add,uchar word_add)   //讀出一個存儲的數據
  375. {
  376.         uchar date;
  377.         start();                 //啟動
  378.         send_byte(device_add);   //選擇從器件地址,RW位為0,即選擇寫命令
  379.         send_byte(word_add);     //寫字地址
  380.         start();                 //啟動
  381.         send_byte(device_add+1); //選擇從器件地址,RW位為1,即選擇讀命令
  382.         date=receive_byte();     //讀數據
  383.     sendACK(1);              //發送非應答信號
  384.         stop();                  //停止
  385.         return date;             //返回讀取結果數據
  386. }
  387. //**************************************************************************************************
  388. //主函數
  389. //**************************************************************************************************
  390. int readeeprom()
  391. {        
  392.    uchar temp;                   //定義中間變量
  393.    temp=read_word(0xa0,0);       //從I2C器件a0的第0個地址讀出數據賦予temp
  394.    write_word(0xa0,0,temp+1);    //向I2C器件a0的第0個地址寫etmp+1
  395.          Delay1ms(50);            
  396.    while(1)                      //死循環
  397.     {
  398.           temp=read_word(0xa0,0);    //從第0個地址讀出一個數據
  399.                  Delay1ms (10);
  400.       P1=~temp;                  //送數據到P1口顯示

  401.         }
  402. }
復制代碼




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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 国产精品视频网站 | 婷婷精品 | 夜夜夜久久久 | 欧美一级一 | 亚洲欧美日韩精品久久亚洲区 | 91视频在线看 | 久久久久久一区 | 国产综合一区二区 | 免费的色网站 | 91.色 | 国产xxxx岁13xxxxhd | 在线日韩欧美 | 亚洲国产一区二区视频 | 国产区第一页 | h漫在线观看 | 国产精品二区三区 | 亚洲一区二区三区四区五区中文 | 91传媒在线观看 | 一区二区三区久久久 | 一区二区视频 | 美女福利网站 | 日韩和的一区二区 | 色噜噜亚洲男人的天堂 | 人人干视频在线 | 国产中文视频 | 亚洲日本激情 | 麻豆精品久久 | 日本羞羞影院 | 欧美中文视频 | 国产美女一区二区三区 | 久久一二三区 | 欧美操操操 | 欧美一区二区三区视频 | 国产精品久久久久久久久久久久久 | 91免费在线播放 | se婷婷| 精品永久 | 曰韩三级| 亚洲人成网亚洲欧洲无码 | 日韩综合一区 | 一区二区三区精品视频 |