找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3137|回复: 1
收起左侧

单片机串口计算器源码

[复制链接]
ID:221388 发表于 2017-7-21 15:48 | 显示全部楼层 |阅读模式
这个计算器的结果是在电脑串口上面显示的
串口计算器所有资料51hei提供下载:
串口练习.zip (22.33 KB, 下载次数: 37)

单片机源程序如下:
  1. #include<reg52.h>
  2. #include<intrins.h>
  3. //  # include <stdlib. h>
  4. #include<math.h>
  5. sbit dula=P2^6;                //段选信号的锁存器控制
  6. sbit wela=P2^7;                //位选信号的锁存器控制                                   ,0x77,0x7c,0x39,0x5e,0x79,0x71
  7. bit flag0=0; //"="号按键标志
  8. bit flag1=0; //"+"号按键标志
  9. bit flag2=0; //"-"号按键标志
  10. bit flag3=0; //"*"号按键标志
  11. bit flag4=0; //"^"号按键标志
  12. bit flag5=0; //清楚标志                                                                                                         
  13. #define uint unsigned int
  14. #define uchar unsigned char
  15. unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};
  16. unsigned int j,t,sum,s1=0,s2=0,a1,a2,a3;
  17. uint m;
  18. void delay(unsigned int i)
  19. {
  20.         unsigned int m,n;
  21.         for(m=i;m>0;m--)
  22.                 for(n=90;n>0;n--);
  23. }  
  24. void display(uint s)
  25. {
  26.                 P0=0xfe;
  27.                 wela=1;              
  28.                 wela=0;
  29.                 P0=table[s/100];
  30.                 dula=1;
  31.                 dula=0;
  32.                 delay(6);
  33.         
  34.                 P0=0xfd;
  35.                 wela=1;              
  36.                 wela=0;
  37.                 P0=table[s%100/10];               
  38.                 dula=1;
  39.                 dula=0;
  40.                 delay(6);
  41.                
  42.                
  43.                 P0=0xfb;
  44.                 wela=1;              
  45.                 wela=0;
  46.                 P0=table[s%10];               
  47.                 dula=1;
  48.                 dula=0;
  49.                 delay(6);
  50. }        
  51.   
  52. void InitUART(void)
  53. {
  54.     TMOD = 0x20;
  55.     SCON = 0x50;
  56.     TH1 = 0xFD;
  57.     TL1 = TH1;
  58.     PCON = 0x00;
  59.     EA = 1;
  60.     ES = 1;
  61.     TR1 = 1;
  62. }
  63. void SendOneByte(unsigned char c)
  64. {
  65.     SBUF = c;
  66.     while(!TI);
  67.     TI = 0;
  68. }
  69.   
  70. void main(void)
  71. {  
  72.         InitUART();               
  73.         while(1)
  74.         {        
  75.                 display(sum);
  76.         
  77.             
  78.    }                  
  79. }

  80. void UARTInterrupt(void) interrupt 4
  81. {
  82.          
  83.                 if(RI)
  84.                 {
  85.                         RI = 0;
  86.                         m= SBUF;
  87.                
  88.                         SendOneByte(m);
  89.                         if((m-0x30)>=0 && (m-0x30)<=9)
  90.                               {
  91.                                    s1=s1*10+(m-0x30);
  92.                                  //         display(m);
  93.                                 }
  94.                         switch(m)
  95.                         {
  96.                                         case 0x2B:{        s2=s1;s1=0;flag1=1;}break; //加法
  97.                                         case 0x2a:{s2=s1; s1=0;flag3=1;}break; //乘法
  98.                                                 case 0x2d: {s2=s1; s1=0;flag2=1;}break; //减法
  99.                                         case 0x5e: {s2=s1; s1=0;flag4=1;}break; //幂运算
  100.                                         case 0x3d: flag0=1;   break; //"="号按键
  101.                                         case 0xFF: flag5=1; break;        //"/"号按键        
  102.                                         default:         break;
  103.                                 }
  104.                                 if(flag0==1)
  105.                 {        if(flag1==1)
  106.                         {
  107.                                 sum=0;
  108.                                 sum=s1+s2;        
  109.                         }
  110.                         else if(flag3==1)
  111.                         {
  112.                                 sum=s1*s2;        
  113.                         }
  114.                         else if(flag2==1)
  115.                         {
  116.                                 sum=s2-s1;
  117.                         }
  118.                                 else if(flag4==1)
  119.                         {
  120.                                 sum=pow(s1,s2);        
  121.                         }
  122.                                    display(sum);

  123.                                  a1=sum/10;
  124.                                  a2=sum%10;
  125.                                 
  126.                         SendOneByte(a1+0x30);         
  127.                          SendOneByte(a2+0x30);
  128.                                  
  129.                                  
  130.                                  
  131.                                          
  132.                 }

  133. ……………………

  134. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码




回复

使用道具 举报

ID:677261 发表于 2020-1-1 23:39 | 显示全部楼层
本帖最后由 卢卡 于 2020-1-2 00:00 编辑

感谢,如果加上图片更好
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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