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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

帖子
查看: 3192|回復(fù): 0
打印 上一主題 下一主題
收起左側(cè)

C51單片機計算器Proteus仿真代碼

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:784201 發(fā)表于 2020-6-19 15:38 | 只看該作者 |只看大圖 回帖獎勵 |倒序瀏覽 |閱讀模式
C51簡單計算器
包含proteus仿真 C程序  仿真視頻(搬運的


單片機源程序如下:
  1. #include <reg51.h>
  2. #include <stdio.h>
  3. #include <intrins.h>
  4. #define u8  unsigned char
  5. #define u16  unsigned char
  6. sbit LCDEN=P3^4;
  7. sbit RS=P3^5;
  8. sbit RW=P3^6;
  9. sbit BF=P0^7;
  10. u8 code keyval[]="789/456*123-c0=+"; //按鍵對應(yīng)的符號
  11. u8 data1[10];
  12. u8 k=0;
  13. char  m[10]={0};
  14. double sum=0;
  15. void delay(u16 x)          //延時x毫秒
  16. {
  17. u16 i,j;
  18. for(i=0;i<x;i++)
  19.         for(j=0;j<115;j++)
  20.                 ;
  21. }

  22. u8 keypad4_4()//按鍵掃描函數(shù):要去抖,若有按鍵按下,返回對應(yīng)的按鍵值(0-15),沒有按鍵按下返回16
  23. {
  24. u8 i,row,temp;
  25. u8 key=16;//按鍵號,初值設(shè)置為16,目的是:沒有按鍵按下時返回16;
  26.           //若不設(shè)初值(默認(rèn)值為0),沒有按鍵按下時,將返回0,會誤認(rèn)為0被按下  
  27. row=0xef; //從第一列開始      
  28. for(i=0;i<4;i++)
  29. {
  30.         P1=0xff;  
  31.         P1=row;        //第i列信號,對應(yīng)列為低,其他全為高
  32.         row=_crol_(row,1);           //生成下一列信號
  33.         temp=P1; //讀入掃描信號
  34.         temp=temp&0x0f; //屏蔽高4位列信號,只保留低4位行信號
  35.         if(temp!=0x0f)//有按鍵被按下,因為第i列某行有按鍵按下,則低4位中有一位為低  
  36.         {  
  37.                 delay(20);  //延時去抖
  38.                 temp=P1;  
  39.                 temp=temp&0x0f;  
  40.                 if(temp!=0x0f)   //再次確認(rèn)有按鍵被按下
  41.                   {  
  42.                 switch(temp)  //根據(jù)低4位行信號,判斷哪個按鍵被按下
  43.             {  
  44.                     case 0x0e:key=0+i;break; //第i列第1行按鍵被按下
  45.                 case 0x0d:key=4+i;break; //第i列第2行按鍵被按下  
  46.                 case 0x0b:key=8+i;break; //第i列第3行按鍵被按下
  47.                                 case 0x07:key=12+i;      //第i列第4行按鍵被按下
  48.             }
  49.                        
  50.                         do
  51.                         {
  52.                                 temp=P1;              //再次掃描按鍵
  53.                                   temp=temp&0x0f;  
  54.                           }while(temp!=0x0f); //等待按鍵釋放   
  55.                   }  
  56.      }
  57. }  
  58. return(key);//掃面結(jié)束,返回按鍵值
  59. }

  60. unsigned char DectectBusyBit(void)//狀態(tài)判斷函數(shù)(忙/閑?)
  61. {   
  62.         bit result;
  63.         P0 = 0xff;        //讀狀態(tài)前先置高電平,防止誤判
  64.         RS = 0;
  65.         delay(5);
  66.     RW = 1;
  67.         LCDEN = 1;
  68.         delay(5);
  69.         result=BF; //若LCM忙,則反復(fù)測試,在此處原地踏步;當(dāng)LCM閑時,才往下繼續(xù)
  70.         LCDEN = 0;
  71.         return result;                     
  72. }

  73. void WrComLCD(unsigned char ComVal)//寫命令函數(shù)
  74. {
  75.         while(DectectBusyBit()==1);         //先檢測LCM是否空閑
  76.         RS = 0;
  77.         delay(1);
  78.     RW = 0;
  79.         LCDEN = 1;
  80.         P0 = ComVal;
  81.         delay(1);
  82.         LCDEN = 0;       
  83. }

  84. void WrDatLCD(unsigned char DatVal)//寫數(shù)據(jù)函數(shù)
  85. {
  86. while(DectectBusyBit()==1);
  87.         RS = 1;
  88.         delay(1);
  89.     RW = 0;
  90.         LCDEN = 1;
  91.         P0 = DatVal;
  92.         delay(1);
  93.         LCDEN = 0;       
  94. }

  95. void LCD_Init(void)//1602初始化函數(shù)
  96. {
  97.         WrComLCD(0x38);     // 功能設(shè)定:16*2行、5*7點陣、8位數(shù)據(jù)接口
  98.         WrComLCD(0x38);
  99.         WrComLCD(0x38);   
  100. //多次重復(fù)設(shè)定功能指令,因為LCD啟動后并不知道使用的是4位數(shù)據(jù)接口還是8位的,所以開始時總是默認(rèn)為4位
  101.         WrComLCD(0x01);    // 清屏
  102.         WrComLCD(0x06);    // 光標(biāo)自增、屏幕不動  
  103.         delay(1);              // 延時,等待上面的指令生效,下面再顯示,防止出現(xiàn)亂碼
  104.         WrComLCD(0x0c);    // 開顯示
  105. }
  106.                                                          
  107. void compute(){
  108.         u8 i,j=0,k,n=0;
  109.         char data3[10]={0};
  110.         int sum1,data2[10]={0};
  111.         sum=0;
  112.                
  113.         for(i=0;data1[i]!='\0';i++){
  114.                   if(data1[i]!='+' && data1[i]!='-' && data1[i]!='*' && data1[i]!='/'){
  115.                           data2[j] =data2[j]*10+(data1[i]-'0');
  116.                   }
  117.                   else{
  118.                           data3[n++] = data1[i];
  119.                           j++;
  120.                   }
  121.         }
  122.         for(i=0;i<n;i++){
  123.                 if(i==0){
  124.                         if(data3[0]=='+')  sum = data2[0] + data2[1];
  125.                         if(data3[0]=='-')  sum = data2[0] - data2[1];
  126.                         if(data3[0]=='*')  sum = data2[0] * data2[1];
  127.                         if(data3[0]=='/')  sum = data2[0] / (double)data2[1];
  128.                 }
  129.                 if(i==1){
  130.                         if(data3[1]=='+')  sum = sum+data2[2];
  131.                         if(data3[1]=='-')  sum = sum-data2[2];
  132.                         if(data3[1]=='*')  sum = sum*data2[2];
  133.                         if(data3[1]=='/')  sum = sum/((float)data2[2]);
  134.                 }
  135.                 if(i==2){
  136.                         if(data3[2]=='+')  sum = sum+data2[3];
  137.                         if(data3[2]=='-')  sum = sum-data2[3];
  138.                         if(data3[2]=='*')  sum = sum*data2[3];
  139.                         if(data3[2]=='/')  sum = sum/((float)data2[3]);
  140.                 }

  141.        
  142.         }

  143.         //判斷是小數(shù)輸出還是整數(shù)輸出
  144.         sum1 = sum;
  145.         if(sum1==sum){
  146.                 sprintf(m,"%d",sum1);
  147.         }
  148.         else{
  149.                 sprintf(m,"%f",sum);
  150.         }
  151.         //把結(jié)果輸出出來
  152.         for(k=0;m[k]!='\0';k++){
  153.                  WrDatLCD(m[k]);
  154.         }
  155. }  



  156. void main()
  157. {
  158.         u8 y;       
  159. ……………………

  160. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼

所有資料51hei提供下載:
計算器.7z (875.39 KB, 下載次數(shù): 63)



Snipaste_2020-06-19_16-17-10.png (37.88 KB, 下載次數(shù): 179)

仿真圖

仿真圖
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

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

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 亚洲免费视频一区 | 9l视频自拍九色9l视频成人 | 乳大翘臀1v1h糙汉 | 国产欧美日韩一区 | 成人看| 亚洲在线中文字幕 | 免费观看一区二区三区 | 精品视频免费观看 | 可以看毛片的网站 | 日韩一区二区三区视频 | 欧美性生交xxxxx | 亚洲精品在线看 | 成年人午夜视频 | 欧美激情久久久 | 国产在线一区二区三区 | 无套内谢的新婚少妇国语播放 | 日韩国产中文字幕 | 色人人 | 久久久久亚洲 | 亚洲成人日韩 | 久久成人av | 老司机午夜视频 | 天天看天天操 | 久草青青草 | 日本少妇高潮达到高潮 | 免费毛片在线 | 亚洲国产小视频 | 免费看a级片 | 成人高潮片免费网站 | av中文天堂 | 亚洲狠狠爱 | 婷婷第四色 | 天堂网久久 | 日韩中文字幕视频 | 91精品国产日韩91久久久久久 | 免费看黄色的视频 | 成人在线a | 国产乱码一区二区 | 夜夜躁狠狠躁日日躁av | 国产综合久久久 | 911精品国产一区二区在线 |