找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机同步电机控制程序

[复制链接]
跳转到指定楼层
楼主
ID:451728 发表于 2019-1-9 10:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. #include<reg51.h>
  2. int n,m,k,temp;
  3. sbit run=P2^7;
  4. sbit stop=P2^3;
  5. sbit Frun=P2^6;
  6. sbit up=P2^5;
  7. sbit down=P2^4;  //定义操作按键 开始 停止 反转 不同速度的控制口
  8. sbit X=P1^0;
  9. sbit Y=P1^1;
  10. sbit Z=P1^2;
  11. sbit W=P1^3;  //定义电机控制口
  12. sbit LSA=P1^5;
  13. sbit LSB=P1^6;
  14. sbit LSC=P1^7;  //定义数码管显示口
  15. void delay(int i) //家中常备 延时函数
  16. {
  17.         while(i--);        
  18. }
  19. void show(unsigned int k)  //动态数码管显示程序
  20. {        int d[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};                                       
  21.         char i;        
  22.         int b[8];
  23.         b[0]=0;
  24.          b[1]=0;
  25.         b[2]=0;
  26.         b[3]=(k/10000)%10;
  27.         b[4]=(k/1000)%10;
  28.         b[5]=(k/100)%10;
  29.         b[6]=(k/10)%10;
  30.         b[7]=k%10;

  31.         for(i=0;i<8;i++)
  32.         {
  33.                 switch(i)        
  34.                 {
  35.                         case(0):LSA=0;LSB=0;LSC=0; break;
  36.                         case(1):LSA=1;LSB=0;LSC=0; break;
  37.                         case(2):LSA=0;LSB=1;LSC=0; break;
  38.                         case(3):LSA=1;LSB=1;LSC=0; break;
  39.                         case(4):LSA=0;LSB=0;LSC=1; break;
  40.                         case(5):LSA=1;LSB=0;LSC=1; break;
  41.                         case(6):LSA=0;LSB=1;LSC=1; break;
  42.                         case(7):LSA=1;LSB=1;LSC=1; break;        
  43.                 }
  44.                 if(i==0&&temp==1)P0=0x71;
  45.                 if(i==5)P0=d[b[i]]|0x80;
  46.                 if(i>0)P0=d[b[i]];//发送段码
  47.                 delay(100); //间隔一段时间扫描        
  48.                 P0=0x00;//消隐
  49.         }
  50.         
  51.         
  52. }

  53. void Zturn()  //正转程序
  54. {        
  55.         X=0;Y=0;Z=1;W=0;n=0; //状态
  56.         while(n/m==0);         //延时
  57.         X=1;Y=0;Z=0;W=0;n=0;
  58.         while(n/m==0);
  59.         X=0;Y=0;Z=0;W=1;n=0;
  60.         while(n/m==0);
  61.         X=0;Y=1;Z=0;W=0;n=0;
  62.         while(n/m==0);        
  63.         
  64. }
  65. void Fturn()  //反转程序
  66. {
  67.         X=0;Y=1;Z=0;W=0;n=0;
  68.         while(n/m==0);
  69.         X=0;Y=0;Z=0;W=1;n=0;
  70.         while(n/m==0);
  71.         X=1;Y=0;Z=0;W=0;n=0;
  72.         while(n/m==0);
  73.         X=0;Y=0;Z=1;W=0;n=0;
  74.         while(n/m==0);        
  75. }
  76. void time1_ISR()interrupt 1
  77. {
  78.         show(k);  //调用数码管显示函数
  79.         TH0=0XD8;TL0=0XF0;
  80. }
  81. void time0_ISR()interrupt 3
  82. {        
  83.         
  84.         n++;                                 //每一毫秒自加一次
  85.         TH1=0XFC;TL1=0X18;         //定时器复位
  86.         
  87. }
  88. void main()
  89. {
  90. TMOD=0x11;TH1=0XFC;TL1=0X18;TR1=1;
  91. TH0=0XD8;TL0=0XF0;TR0=1;        //使用定时器1和定时器0
  92. ET1=1;ET0=1;EA=1;           //打开定时器1的中断
  93. P2=0XFF;
  94. while(1)
  95.         {
  96.                  if(run==0)
  97.                 {        m=50;temp=0;
  98.                         while(stop&Frun)
  99.                         {
  100.                                                         
  101.                                 if(up==0){m=m-1;if(m<6){m=6;}}
  102.                                 if(down==0){m=m+1;if(m>1000){m=1000;}}
  103.                                 k=6000000/80/m;                                
  104.                                  Zturn();
  105.                         }
  106.                 }                                                
  107.                 if(Frun==0)
  108.                 {        m=50;temp=1;
  109.                         while(run&stop)
  110.                         {
  111.                                                         
  112.                                 if(up==0){m=m-1;if(m<6){m=6;}}
  113.                                 if(down==0){m=m+1;if(m>1000){m=1000;}}
  114.                                 k=6000000/80/m;        
  115.                                 Fturn();
  116.                         }
  117.                 }
  118.                 if(stop==0){k=0;temp=0;}        
  119.         }
  120. }        
复制代码
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:451728 发表于 2019-1-9 10:52 | 只看该作者
程序代码

同步电机控制.zip

28.61 KB, 下载次数: 6, 下载积分: 黑币 -5

回复

使用道具 举报

板凳
ID:1 发表于 2019-1-10 03:18 | 只看该作者
补全原理图或者详细说明一下电路连接即可获得100+黑币
回复

使用道具 举报

地板
ID:451728 发表于 2019-1-10 09:24 | 只看该作者
多机通信

通信步进电机接收.zip

16.56 KB, 下载次数: 4, 下载积分: 黑币 -5

通信步进电机控制.zip

26.16 KB, 下载次数: 3, 下载积分: 黑币 -5

回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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