找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5745|回复: 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, 下载次数: 41)


评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表