找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 6142|回复: 2
打印 上一主题 下一主题
收起左侧

STC单片机推挽输出驱动数码管 源程序 原理图与Proteus仿真 代码注释很详细

[复制链接]
跳转到指定楼层
楼主
下面是STC单片机推挽输出驱动数码管的proteus仿真原理图(工程文件可到本帖附件中下载):


单片机源程序如下:
  1. //#include <reg51.h>
  2. #include <STC12C5A60S2.h>
  3. #define u8 unsigned char
  4. #define u16 unsigned   int
  5. #define u32 unsigned long  int
  6. #define vtime        3000   //定时3ms,一帧8*3=24ms,频率=40Hz
  7. #define  jz12                                //jz132 :晶振选择132.710400MH//jz12 :12MH
  8. #ifdef        jz12
  9.                 //正常12MH
  10.         #define         t8s_n        90
  11.         #define         psv                4
  12. #else
  13.                 //132.7014MH
  14.         #define         t8s_n        1000
  15.         #define         psv                900

  16. #endif
  17. void        delay(void);

  18. //共阴数码管段码表
  19. u8 code distable[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00};
  20. //位选码表
  21. u8  code numi[]={0x01,0x02,0x04,0x08,0x10,0x20,0x40,0x80};
  22. //显示缓存
  23. u8 V_ram[]={0,0,3,4,5,6,7,8};
  24. u8 Vm[]={0,0,3,4,5,6,7,8};

  25. u8        wi=0,mn=0,nt=0,wbs=0;  //位选循环变量
  26. u8                t_l,t_h,bs=0;
  27. u32                adv=0,adsum=0;
  28. main()                                                 //m1:m0  00=标准;   01=推挽;   10=输入;   11=开漏输出
  29. {
  30.         u16                i=0;
  31.         u16                temp=0;
  32.         //u32                temp0=0,temp1,temp2;
  33.         //m1:m0  00=标准;   01=推挽;   10=输入;   11=开漏输出
  34.         //P0M1 = 0X00;
  35. //        P0M0 = 0Xff;
  36. //        P2M1 = 0X00;
  37. //        P2M0 = 0Xff; //设定P0,P2推挽输出
  38.         //P3M1 = 0Xff;
  39.         //P3M0 = 0X00;
  40.         P1M1 = 0x01;
  41.         P1M0 = 0x08;
  42.           TMOD = 0X50; //设定定时器0为16位计数方式

  43.           //TH0 = (65536-vtime )/256;
  44.           //TL0 = (65536-vtime )%256; //赋定时器0初值
  45.         AUXR=0x80; //选择1T指令系统
  46.           //ET0 = 1;  //开定时器0中断
  47.         AUXR1=AUXR1|0x04;
  48.         P1ASF=0x01;
  49.         ADC_CONTR=0x80;
  50.         //TR0=1;
  51.         //PX1=1;
  52.         //PX0=1;
  53.         //PT1=1;
  54.         //IT0=1;
  55.         //IT1=1;
  56.         CCON = 0;
  57.         CL = 0;
  58.         CH = 0;
  59.         CMOD = 0X0F;
  60.         CCAP0H = 0X80;
  61.         CCAP0L = 0X80;
  62.         CCAPM0 = 0X42;
  63.         CCAPM1 = 0X00;
  64.         PCA_PWM0 = 0;
  65.         CR = 1;






  66.           EA = 1;          //开总中断
  67.         while(1)
  68.         {                  
  69.                         if(ADC_CONTR&&0x10)
  70.                         {
  71.                                 adv=((u32)ADC_RES<<8)+ADC_RESL;
  72.                                 ADC_CONTR=0x88;//ADC_CONTR & 0xef;
  73.                                 adsum=adsum+adv;
  74.                                 i++;
  75.                                 if(i==10000)
  76.                                 {
  77.                                                 i=0;
  78.                                                 adsum=adsum/10000;
  79.                                                 if(adsum>1023)adsum=1023;
  80.                                                 V_ram[0]=adsum/1000;
  81.                                                 temp=adsum%1000;
  82.                                                 V_ram[1]=temp/100;
  83.                                                 temp=temp%100;
  84.                                                 V_ram[2]=temp/10;
  85.                                                 temp=temp%10;
  86.                                             V_ram[3]=temp/1;
  87.                                                 //V_ram[4]=temp%10;
  88.                                                 mn=~(adsum>>2);
  89.                                                 adsum=0;
  90.                                 }
  91.                         }
  92.                         delay();

  93.         }
  94. }
  95. void        delay()
  96. {
  97.          u16        x,y,z;
  98.          for(x=3;x>0;x--)
  99.          for(y=3;y>0;y--)
  100.          for(z=3;z>0;z--);
  101. }
  102. void t0_isp() interrupt 1         using                2         //13位计时中断
  103. {
  104.         u8 dm,wx;
  105.           dm=distable[V_ram[wi]];        //取显示段码
  106.         //if(wi==wbs)dm=dm|0x80;
  107.         wx=numi[wi];                           //取位选码
  108.         P2=0x00;                           //关显示
  109.         P0=dm;                                   //段码赋给P0口
  110.         P2=wx;                                   //点亮位选的那个数码管
  111.         wi++;
  112.         if(wi==4)wi=0;

  113. }
  114. void pca_isp() interrupt 7           //using        1           //计时开始中断
  115. {
  116.         CF = 0;
  117.         CCAP0H=mn;
  118.         //CCAP0H++;
  119. }
  120.   
  121. void int0_isp() interrupt 0           using        1           //计时开始中断
  122. {
  123. }
  124. void int1_isp() interrupt 2                using                3                //计时结束中断
  125. {
  126. }

  127. void t1_isp() interrupt 3           //using        1           //计时开始中断
复制代码

给大家分享一些我们老师给的一些经典的单片机程序源码, 一共有十多个.都有详细的注释,然大家快速的理解每一行代码的意思。而且有proteus仿真原理图。大家可以直接验证程序的对错.


本系列所有源码打包下载地址(含proteus仿真工程文件和源程序):
http://www.51hei.com/bbs/dpj-82474-1.html

本例程下载:
PWM.rar (79.19 KB, 下载次数: 21)

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

使用道具 举报

沙发
ID:639106 发表于 2020-5-6 16:52 | 只看该作者
谢谢分享!
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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