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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2076|回復: 0
收起左側

1602顯示的基本功能計算器單片機源程序Proteus仿真

[復制鏈接]
ID:589336 發表于 2019-8-7 09:03 | 顯示全部樓層 |閱讀模式
只能實現一些基本功能,進行加減運算
電路原理圖如下:
0.jpg

單片機源程序如下:
  1. /**************************************
  2. 工程名:簡易計算器
  3. ***************************************/
  4. #include <reg51.h>
  5. #define uchar unsigned char
  6. #define uint  unsigned int

  7. //定義位選編碼
  8. #define WEI1  0xfe         //千位控制
  9. #define WEI2  0xfd         //百位控制
  10. #define WEI3  0xfb         //十位控制
  11. #define WEI4  0xf7         //個位控制

  12. //定義運算操作符代號
  13. #define add 0x0c        //加
  14. #define dec 0x0d        //減
  15. #define        mul 0x0e        //乘
  16. #define div 0x0f        //除
  17. #define equ        0x0b        //等于
  18. #define clr 0x0a        //清零

  19. sbit P3_4=P3^4;
  20. sbit P3_5=P3^5;  
  21. sbit P3_6=P3^6;
  22. sbit P3_7=P3^7;

  23. uchar step;                //操作步驟變量
  24. uchar sybol;        //運算符號變量
  25. uint  first;        //第一個操作數變量
  26. uint  second;        //第二個操作數變量
  27. uint  res;                //結果的變量
  28. uint  tempres;        //中間結果的變量

  29. uchar code table[] = {0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f };//數字0~9的編碼,共陰
  30. uchar code err[] =         {   0x00,//NULL
  31.                                                 0x79,//E
  32.                                                 0x50,//R
  33.                                                 0x50 //R
  34.                                         };                 //單詞 ERR的編碼                       
  35. void delayms(uint z)
  36. {
  37.         uint i,j;
  38.         for(i=z;i>0;i--)
  39.                 for(j=120;j>0;j--);
  40. }
  41. //***********************************************************************************
  42. //功能按鍵掃描程序
  43. //返回值:有鍵按下,返回具體的鍵值,無鍵按下,返回0xff
  44. //***********************************************************************************
  45. uchar keyscan(void)                 
  46. {
  47.    unsigned char temp;   //用于檢測按鍵的臨時變量
  48.     unsigned char key;
  49.           P3=0xff;
  50.       P3_4=0;                       //第一行輸出低電平
  51.       temp=P3;                                   //讀取P3口數據
  52.       temp=temp & 0x0f;           //臨時變量高4位清零,保持低4位
  53.       if (temp!=0x0f)                   //判斷是否有鍵按下
  54.         {
  55.           delayms(10);                  //延時10ms
  56.           temp=P3;                           //讀取P3口數據
  57.           temp=temp & 0x0f;
  58.           if (temp!=0x0f)            //再次判斷是否有鍵按下
  59.             {
  60.               temp=P3;                    //有鍵按下,讀取P3口數據
  61.               temp=temp & 0x0f;              
  62.               switch(temp)                 //判斷具體是哪個鍵按下
  63.                 {
  64.                   case 0x0e:key=3;break;
  65.                   case 0x0d:key=2;break;
  66.                   case 0x0b:key=1;break;
  67.                   case 0x07:key=0;break;
  68.                                   default:break;
  69.                 }
  70.               temp=P3;   
  71.               temp=temp & 0x0f;              
  72.               while(temp!=0x0f)  //等待按鍵釋放
  73.                 {
  74.                   temp=P3;
  75.                   temp=temp & 0x0f;              
  76.                 }
  77.                                 return key;
  78.             }
  79.         }
  80.       P3=0xff;
  81.       P3_5=0;                                           //第二行輸出低電平
  82.       temp=P3;
  83.       temp=temp & 0x0f;
  84.       if (temp!=0x0f)
  85.         {
  86.           delayms(10);                  
  87.           temp=P3;
  88.           temp=temp & 0x0f;
  89.           if (temp!=0x0f)
  90.             {
  91.               temp=P3;
  92.               temp=temp & 0x0f;              
  93.               switch(temp)
  94.                 {
  95.                   case 0x0e:key=7;break;
  96.                   case 0x0d:key=6;break;
  97.                   case 0x0b:key=5;break;
  98.                   case 0x07:key=4;break;
  99.                                   default:break;
  100.                 }
  101.                           temp=P3;
  102.               temp=temp & 0x0f;              
  103.               while(temp!=0x0f)
  104.                 {
  105.                   temp=P3;
  106.                   temp=temp & 0x0f;              
  107.                 }
  108.                         return key;
  109.             }
  110.         }
  111.   
  112.       P3=0xff;
  113.       P3_6=0;                                         //第三行輸出低電平
  114.       temp=P3;
  115.       temp=temp & 0x0f;
  116.       if (temp!=0x0f)
  117.         {
  118.           delayms(10);                  
  119.           temp=P3;
  120.           temp=temp & 0x0f;
  121.           if (temp!=0x0f)
  122.             {
  123.               temp=P3;
  124.               temp=temp & 0x0f;              
  125.               switch(temp)
  126.                 {
  127.                   case 0x0e:key=11;break;
  128.                   case 0x0d:key=10;break;
  129.                   case 0x0b:key=9;break;
  130.                   case 0x07:key=8;break;
  131.                                   default:break;
  132.                 }
  133.                           temp=P3;
  134.               temp=temp & 0x0f;               
  135.               while(temp!=0x0f)
  136.                 {
  137.                   temp=P3;
  138.                   temp=temp & 0x0f;              
  139.                 }
  140.                         return key;  
  141.             }

  142.         }
  143.   
  144.       P3=0xff;
  145.       P3_7=0;                                          //第四行輸出低電平
  146.       temp=P3;
  147.       temp=temp & 0x0f;
  148.       if (temp!=0x0f)
  149.         {
  150.            delayms(10);                  
  151.           temp=P3;
  152.           temp=temp & 0x0f;
  153.           if (temp!=0x0f)
  154.             {
  155.               temp=P3;
  156.               temp=temp & 0x0f;              
  157.               switch(temp)
  158.                 {
  159.                   case 0x0e:key=15;break;
  160.                   case 0x0d:key=14;break;
  161.                   case 0x0b:key=13;break;
  162.                   case 0x07:key=12;break;
  163.                                   default:break;
  164.                 }
  165.                           temp=P3;
  166.               temp=temp & 0x0f;      
  167.               while(temp!=0x0f)
  168.                 {
  169.                   temp=P3;
  170.                   temp=temp & 0x0f;              
  171.                 }
  172.                         return key;
  173.             }
  174.         }
  175.                 return 0xff;
  176. }
  177. //***********************************************************************************
  178. //對兩個數進行數學運算
  179. //返回值:返回運算結果,結果為大于或等于零的整數
  180. //***********************************************************************************
  181. uint jisuan()
  182. {
  183.         uint result;
  184.         switch(sybol)
  185.         {
  186.                 case(add):
  187.                         result = first + second;break;
  188.                 case(dec):
  189.                         result = first - second;break;
  190.                 case(mul):
  191.                         result = first * second;break;
  192.                 case(div):
  193.                         result = first / second;break;
  194.                         default:break;
  195.         }
  196.         return result;
  197. }

  198. void init()                //變量初始化
  199. {
  200.         step = 0;
  201.         first = 0;
  202.         second = 0;
  203.         res = 0;
  204.         tempres = 0;
  205. }

  206. void display(uint dat)        //數碼管顯示數字
  207. {
  208.         uchar q,b,s,g;
  209.         if(dat<0||dat>9999)        // 顯示錯誤
  210.         {
  211.                 P2 = WEI1;
  212.                 P0 = err[0];
  213.                 delayms(5);

  214.                 P2 = WEI2;
  215.                 P0 = err[1];
  216.                 delayms(5);
  217.                 P2 = WEI3;
  218.                 P0 = err[2];
  219.                 delayms(5);

  220.                 P2 = WEI4;
  221.                 P0 = err[3];
  222.                 delayms(5);
  223.         }  
  224.         else
  225.         {
  226.                 q = dat/1000;
  227.                 b = (dat/100)%10;
  228.                 s = (dat/10)%10;
  229.                 g = dat%10;
  230.                 if(q==0)                                    //最高位數據為0時不顯示
  231.                 {
  232.                         if(b==0)
  233.                         {
  234.                                 if(s==0)
  235.                                 {
  236.                                         P2 = WEI4;
  237.                                         P0 = table[g];
  238.                                         delayms(5);
  239.                                 }
  240.                                 else
  241.                                 {
  242.                                         P2 = WEI3;
  243.                                         P0 = table[s];
  244.                                         delayms(5);
  245.                                         P2 = WEI4;
  246.                                         P0 = table[g];
  247.                                         delayms(5);
  248.                                 }
  249.                         }
  250.                         else
  251.                         {
  252.                                 P2 = WEI2;
  253.                                 P0 = table[b];
  254.                                 delayms(5);
  255.                                 P2 = WEI3;
  256.                                 P0 = table[s];
  257.                                 delayms(5);
  258.                                 P2 = WEI4;
  259.                                 P0 = table[g];
  260.                                 delayms(5);
  261.                         }
  262.                 }
  263.                 else
  264.                 {
  265.                         P2 = WEI1;
  266.                         P0 = table[q];
  267.                         delayms(5);
  268.                         P2 = WEI2;
  269.                         P0 = table[b];
  270.                         delayms(5);
  271.                         P2 = WEI3;
  272.                         P0 = table[s];
  273.                         delayms(5);
  274.                         P2 = WEI4;
  275.                         P0 = table[g];
  276.                         delayms(5);
  277.                 }
  278.         }
  279. }

  280. void main(void)
  281. {
  282.         uchar key;
  283.         init();
  284.         while(1)
  285.         {
  286.         key=keyscan();
  287.                 if(step==0 && key<10 )                              //第一步;第一操作數按123+鍵按下
  288.                 {
  289.                         first = first*10 +key;                           //連續按鍵按下進行數據組合
  290.                 }
  291.                 if(step==0 && (key>=12&&key<=15))  //功能鍵按下        ,進入第二步
  292.                 {
  293.                         sybol = key;
  294.                         second = 0;
  295.                         step = 1;
  296.                 }
  297.                 if(step==1 && (key>12&&key<=15))   //第二次功能鍵按下,替換原功能鍵
  298.                 {        sybol = key; }
  299.                 if(step==1 && key<10)                             //第二個運算數據按下        ,進入第三步
  300.                 {
  301.                         step = 2;
  302.                         second = key;                                              //
  303.                         key =0xff;                                           // 防止一次按鍵按下連續出現兩個數,賦予一個大于15即可
  304.                 }
  305.                 if(step==2 && key<10 )
  306.                         second = second*10 +key;
  307.                 if(step==2 && key==11)                           //獲得兩個運算數據后,按下"="號鍵進行運算,進入第四步
  308.                 {
  309.                         res = jisuan();
  310.                         first = 0;
  311.                         second = 0;
  312.                         step = 3;
  313.                 }
  314.                 if(key == 10)                                           //按下清除鍵"C",清0返回初始狀態
  315.                 {
  316.                         step = 0;
  317.                         first = 0;
  318.                         second = 0;
  319.                         res = 0;
  320.                 }

  321.                
  322.                 if(step==0 || step==1)
  323.                         display(first);
  324.                 if(step==2)
  325.                         display(second);
  326.                 if(step==3)       
  327.                 display(res);
  328.         }
  329. }
復制代碼

所有資料51hei提供下載:
簡易計算器.zip (3.91 MB, 下載次數: 17)
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久久婷婷 | 国产三级一区二区 | 久久精品二区亚洲w码 | 国产乱码精品1区2区3区 | av片免费观看 | 波多野结衣一二三区 | 激情影院久久 | 亚洲永久入口 | 91精品国产综合久久久久久蜜臀 | 久草免费在线视频 | 中文字幕精品视频 | 精品久久久久一区二区国产 | 中文字幕在线视频观看 | 黑人巨大精品欧美一区二区一视频 | 91丨九色丨国产在线 | 日韩和的一区二区 | 免费性视频| 中文字幕国产精品 | 国产一区视频在线 | 99久久精品视频免费 | 国产激情免费视频 | 欧美日韩精品一区 | 欧美白人做受xxxx视频 | 日韩精品一区二区三区中文在线 | 一区二区免费视频 | 久久激情网| 成人综合视频在线观看 | 99这里只有精品视频 | 精品国产黄a∨片高清在线 成人区精品一区二区婷婷 日本一区二区视频 | 成人三级视频在线观看 | 国产一区二 | 在线视频第一页 | 久久国产精品免费一区二区三区 | 一级片视频免费观看 | 黄网址在线观看 | 久久久人 | 又爽又黄axxx片免费观看 | 99re在线| 免费看欧美一级片 | 欧美日韩不卡 | 亚洲第一天堂 |