欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

51單片機計算機源碼+proteus仿真圖

[復制鏈接]
跳轉到指定樓層
樓主
通過矩陣鍵盤輸入數值、運算符進行運算,支持多運算符運算。
仿真圖用的12864,可自行替換成其他液晶屏。

說明:
lcd12864.c     包含液晶顯示的程序文件
calc.c             包含實現計算的程序文件
keyscanf.c       包含按鍵掃描的程序文件

仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. #include <reg51.h>
  2. #include <intrins.h>
  3. #include <math.h>
  4. #include "keyscanf.h"
  5. #include "calc.h"
  6. #include "lcd12864.h"

  7. #include <stdio.h>

  8. bit error = 0;
  9. bit czfFlag = 0;                //當前輸入是否為運算符
  10. bit float_flag = 0;                //輸入是否浮點數
  11. bit fs_flag = 0;                //輸入是否浮點數
  12. unsigned char keyValue;                //按鍵碼
  13. unsigned char float_num = 0;        //浮點位數

  14. float number1 = 0.0;
  15. float number2 = 0.0;
  16. float tempNum = 0.0;        //等待運算的數

  17. unsigned char caozuofu = add;
  18. unsigned char tempczf = 'A';        //運算符和臨時運算符

  19. unsigned char charNum = 0;
  20. unsigned char czsNum = 0;        //操作數數量

  21. unsigned char weishu = 0;
  22. float rest = 0;
  23. unsigned int sbuf1[255] = {0};
  24. unsigned char jieguo[255] = {0};

  25. void loop111()
  26. {
  27.                 clac_loop1();
  28.                 if (error == 1)
  29.                 {
  30.                         lcd_showStr(0,0,"盧某提醒:錯誤",14);
  31.                 }
  32.                 else
  33.                 {
  34.                                 if (charNum > 0)
  35.                                         lcd_showInt(0,0,sbuf1,charNum);
  36.                                 if (caozuofu == 40)
  37.                                         lcd_showChars(1,0,jieguo,9);
  38.                 }
  39.                
  40. }
  41. void clac_loop1()
  42. {
  43.         keyValue = getkey();

  44.         if (keyValue < 10)
  45.         {
  46.                         float temp = 0.0;
  47.                         float czstemp = czsNum == 0 ? number1 : number2;
  48.                         sbuf1[charNum] = keyValue;
  49.                         charNum++;
  50.                
  51.                         czstemp = czfFlag == 1 ? 0.0 : czstemp;
  52.                
  53.                         if (float_flag == 0)
  54.                         {
  55.                                 czstemp *= 10;
  56.                                 czstemp += keyValue;
  57.                         }
  58.                         else
  59.                         {
  60.                                 float_num++;
  61.                                 temp = (float)keyValue / (pow(10,float_num));
  62.                         }
  63.                
  64.                         czstemp += temp;        
  65.                         if (tempczf == 'A')
  66.                         {
  67.                                         if (czsNum == 0)
  68.                                                 number1 = czstemp;
  69.                                         else
  70.                                                 number2 = czstemp;
  71.                         }
  72.                         else
  73.                         {
  74.                                 tempNum = czstemp;
  75.                         }
  76.                         czfFlag = 0;
  77.                         weishu++;
  78.                         return ;
  79.         }
  80.         
  81.         
  82.         //        防止重復符號
  83.         if (keyValue > 9 && keyValue != 999)
  84.         {
  85.                 if (czfFlag == 1)
  86.                         return ;
  87.         }
  88.         
  89.         //        防止第一個操作數是符號
  90.         if (keyValue != 999 &&  keyValue > 6 && charNum == 0)
  91.         {
  92.                 return ;
  93.         }
  94.         // + -
  95.         if (keyValue == 11 || keyValue == 22)
  96.         {
  97.                         sbuf1[charNum] = keyValue == 11 ? 10 : 11;
  98.                         charNum++;czsNum++;
  99.                
  100.                         czfFlag = 1;
  101.                
  102.                 //核心
  103.                         if (isCzf(tempczf))
  104.                         {
  105.                                 number2 = js(number2, tempNum, tempczf);
  106.                                 tempczf = 'A';
  107.                                 czsNum--;
  108.                         }
  109.                
  110.                         if (czsNum == 2)
  111.                         {
  112.                                 number1 = js(number1, number2, caozuofu);
  113.                                 czsNum--;
  114.                                 number2 = 0.0;
  115.                         }
  116.                         caozuofu = keyValue;
  117.         }
  118.         
  119.         // * /
  120.         if (keyValue == 33 || keyValue == 43)
  121.         {
  122.                         sbuf1[charNum] = keyValue == 33 ? 12 : 13;
  123.                         charNum++;
  124.                         
  125.                         czsNum++;
  126.                         czfFlag = 1;
  127.                
  128.                         if ((tempczf == dvi && tempNum <= 0)|| (caozuofu == dvi && number2 <= 0))
  129.                         {
  130.                                         error = 1;
  131.                         }
  132.                         //核心
  133.                         if (isCzf(tempczf))
  134.                         {
  135.                                 number2 = js(number2, tempNum, tempczf);
  136.                                 tempczf = 'A';
  137.                                 czsNum--;
  138.                         }
  139.                         
  140.                         if (czsNum == 2)
  141.                         {
  142.                                 tempczf = keyValue;
  143.                         }
  144.                         else
  145.                                 caozuofu = keyValue;
  146.         }
  147.         
  148.         
  149.         //小數點
  150.         if (keyValue == 42)
  151.         {
  152.                
  153.                 //防止輸入兩個小數點
  154.                         if (float_flag == 1)
  155.                         {
  156.                                 return ;
  157.                         }
  158.                         float_flag = 1;
  159.                         sbuf1[charNum] = 14;
  160.                         charNum++;
  161.         }
  162.         
  163.         
  164.         //等于號
  165.         if (keyValue == 40)
  166.         {
  167.                         if ((tempczf == dvi && tempNum <= 0)|| (caozuofu == dvi && number2 <= 0))
  168.                         {
  169.                                 error = 1;
  170.                         }
  171.                         
  172.                         //核心
  173.                         if (isCzf(tempczf))
  174.                         {
  175.                                 number2 = js(number2, tempNum, tempczf);
  176.                                 tempczf = 'A';
  177.                                 czsNum--;
  178.                         }
  179.                         rest = js(number1, number2, caozuofu);
  180.                
  181.                         sbuf1[charNum] = 15;
  182.                         charNum++;
  183.                         
  184.                         //結果轉換成字符數組
  185.                         sprintf(jieguo,"%f",rest);
  186.                         caozuofu = 40;
  187.                         float_flag = 0;
  188.                         float_num = 0;
  189.         }

  190.         if (rest > 99999999 || float_num > 8 || weishu > 8)
  191.         {
  192.                 error = 1;
  193.                 return;
  194.         }
  195.         
  196.         //復位
  197.         if (isCzf(keyValue))
  198.         {
  199.                 float_flag = 0;
  200.                 float_num = 0;
  201.                 weishu = 0;
  202.         }
  203.         
  204. }

  205. bit isCzf(unsigned char n)
  206. {
  207.         return (bit)(n == add || n == sub || n == mul || n == dvi || n == equal);
  208. }

  209. float js(float a, float b, unsigned char c)
  210. {
  211.         switch (c)
  212.         {
  213.                 case add:
  214.                         return a+b;
  215.                 case sub:
  216.                         return a-b;
  217.                 case mul:
  218.                         return a*b;
  219.                 case dvi:
  220.                         return a/b;
  221.         }
  222.         return 0;
  223. }
復制代碼

所有資料51hei提供下載:
CalcEx.zip (100.17 KB, 下載次數: 42)


評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

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

使用道具 舉報

無效樓層,該帖已經被刪除
您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表