基于51单片机的步进电机控制系统(坐标定位、精准控制)原理图、流程图、物料清单、仿真图、源代码

请添加图片描述

基于51单片机的步进电机(坐标定位)

小型机床
1、使用2个步进电机,实现平面坐标定位
2、可以设置电机转速、坐标位置灯参数
3、步进电机驱动到指定坐标位置后蜂鸣器提示
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
在这里插入图片描述

#include "reg51.h"
#include "lcd1602.h"
#define uchar unsigned char
#define uint unsigned int
sbit k1=P3^0;//按钮
sbit k2=P3^1;
sbit k3=P3^2;
sbit AA1=P1^0;//电机1
sbit BB1=P1^1;
sbit CC1=P1^2;
sbit DD1=P1^3;
sbit AA2=P1^4;//电机2
sbit BB2=P1^5;
sbit CC2=P1^6;
sbit DD2=P1^7;
sbit beep=P3^3;//蜂鸣器

uchar speed=2;//速度
uint xx=0,yy=0;//位置
uchar flag1=0,flag2=0,wei1=0,wei2=0;//电机控制
uchar time=0;
uint sec=0,miao=0;
uchar disp1[]="sudu:000";
uchar disp2[]="X:000   Y:000   ";
uchar mode=0;
uchar start=0;//启动
uchar biao=0;
//按键检测
uchar key_scan()
{
uchar i,j;
i=0;
j=0;
P2=0x0f;
if(P2!=0x0f) //检测有无按下
{
 switch(P2)//检测行
 {
  case 0x0e:i=1;break;
  case 0x0d:i=5;break;
  case 0x0b:i=9;break;
  case 0x07:i=13;
 }
 P2=0xf0;
 switch(P2)//检测列
 {
  case 0xe0:j=0;break;
  case 0xd0:j=1;break;
  case 0xb0:j=2;break;
  case 0x70:j=3;
 }
 
}
return i+j;
}
//主函数
void main()
{
	uchar i=0;
	init_1602();
	TMOD|=0X01;
	TH0=(65536-1000)/256;
	TL0=(65536-1000)%256;	
	ET0=1;//打开定时器0中断允许
	EA=1;//打开总中断
	TR0=1;//打开定时器
	while(1)
	{
		if((xx!=wei1)||(yy!=wei2))//启动蜂鸣器
		{
			biao=0;
		}
		else
		{
			if(biao==0)
			{
				biao=1;
				miao=500;
				start=0;
			}
		}
		i=key_scan();//按键检测
		if(start==0)
		{
		if(!k1)//模式切换
		{
			if(mode<3)
				mode++;
			else
				mode=0;
			while(!k1);
		}
		}
		if(mode==1)//设置速度
		{
			if(!k2)
			{
				if(speed>0)
					speed--;
				while(!k2);
			}
			if(!k3)
			{
				if(speed<100)
					speed++;
				while(!k3);
			}
		}
		if(i==11)//启动
		{
			 start=1;
			 mode=0;
		}
		if(i==12)//暂停
		{
			 start=0;
		}
		if(i==13)//左
		{
			if(xx>0)
				xx--;
			start=1;
			while(wei1!=xx);
			start=0;
		}
		if(i==14)//右
		{
			if(xx<999)
				xx++;
			start=1;
			while(wei1!=xx);
			start=0;
		}
		if(i==15)//上
		{
			if(yy>0)
				yy--;
			start=1;
			while(wei2!=yy);
			start=0;
		}
		if(i==16)//下
		{
			if(yy<999)
				yy++;
			start=1;
			while(wei2!=yy);
			start=0;
		}
		if(mode==2)//设置x
		{
			if((i>0)&&(i<11))
			{
				xx=(xx%100)*10+i-1;
			while(P2!=0xf0);//等待按键松开
			}
		}
		if(mode==3)//设置y
		{
			if((i>0)&&(i<11))
			{
				yy=(yy%100)*10+i-1;
			while(P2!=0xf0);//等待按键松开
			}
		} 
	}
}
//定时器中断
void Timer0() interrupt 1
{
	if(miao>0)//蜂鸣器控制
	{
		miao--;
		beep=0;
	}
	else
		beep=1;
	if(start==1)
	{
	if(time<speed)
		time++;
	else
	{
		time=0;
		 //正转
	if(wei1<xx)
	{	
		switch(flag1)
		{
			case 0:BB1=1;break;
			case 1:AA1=0;break;
			case 2:CC1=1;break;
			case 3:BB1=0;break;
			case 4:DD1=1;break;
			case 5:CC1=0;break;
			case 6:AA1=1;break;
			case 7:DD1=0;
		}
		if(flag1<7)//下一个状态
			flag1++;
		else
		{
			flag1=0;
			wei1++;
		}
	}
	if(wei1>xx)	 //反转
	{	
		switch(flag1)
		{
			case 0:DD1=1;break;
			case 1:AA1=0;break;
			case 2:CC1=1;break;
			case 3:DD1=0;break;
			case 4:BB1=1;break;
			case 5:CC1=0;break;
			case 6:AA1=1;break;
			case 7:BB1=0;
		}
		if(flag1<7)//下一个状态
			flag1++;
		else
		{
			flag1=0;
			wei1--;
		}
	}
	if(wei2<yy)
	{	
		switch(flag2)
		{
			case 0:BB2=1;break;
			case 1:AA2=0;break;
			case 2:CC2=1;break;
			case 3:BB2=0;break;
			case 4:DD2=1;break;
			case 5:CC2=0;break;
			case 6:AA2=1;break;
			case 7:DD2=0;
		}
		if(flag2<7)//下一个状态
			flag2++;
		else
		{
			flag2=0;
			wei2++;
		}
	}
	if(wei2>yy)	 //反转
	{	
		switch(flag2)
		{
			case 0:DD2=1;break;
			case 1:AA2=0;break;
			case 2:CC2=1;break;
			case 3:DD2=0;break;
			case 4:BB2=1;break;
			case 5:CC2=0;break;
			case 6:AA2=1;break;
			case 7:BB2=0;
		}
		if(flag2<7)//下一个状态
			flag2++;
		else
		{
			flag2=0;
			wei2--;
		}
	}
	}
	}
	//显示
	if(sec<500)
		sec++;
	else
	{
		sec=0;
		disp1[5]=(100-speed)/100+0x30;
		disp1[6]=(100-speed)%100/10+0x30;
		disp1[7]=(100-speed)%10+0x30;
		disp2[2]=xx/100+0x30;
		disp2[3]=xx%100/10+0x30;
		disp2[4]=xx%10+0x30;
		disp2[10]=yy/100+0x30;
		disp2[11]=yy%100/10+0x30;
		disp2[12]=yy%10+0x30;
		write_com(0x0c);
		write_string(1,0,disp1);
		write_string(2,0,disp2);
		if(start)
		{
			write_string(1,10,"on ");
		}
		else
		{
			write_string(1,10,"off");
		}		
		//设置光标
		switch(mode)
		{
			case 1:write_sfm(1,7);break;
			case 2:write_sfm(2,4);break;
			case 3:write_sfm(2,12);
		}
		if(mode>0)
			write_com(0x0e);
		else
			write_com(0x0c);
	}
	TH0=(65536-1000)/256;
	TL0=(65536-1000)%256;
}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 基于51单片机步进电机控制系统设计开发diy正反转源文件包括以下几个部分: 1. 硬件设计:根据步进电机的参数,选择适当的驱动电路和控制器,并按照电路进行焊接和布线。 2. 软件设计:编写控制程序,使步进电机可以正反转,实现编码器计数器功能和自动控制功能。程序应该实现对步进电机速度、位置和加速度的精确控制。 3. 驱动程序:编写驱动程序,使控制程序和硬件可以正常协作,使步进电机能够根据控制信号准确运转。 4. 调试:对整个系统进行调试和测试,确保各个部分的功能正常,并进行性能优化。 5. 文档编写:撰写相关文档,包括测试结果、用户手册、技术规范等内容,方便后续的开发和维护工作。 以上是基于51单片机步进电机控制系统设计开发diy正反转源文件的主要内容。在实际开发过程中,应该精心设计、认真调试,以确保系统的可靠性和性能。同时,适当地使用现有的资源或借鉴其他项目的经验也是必要的,这样可以大大提高项目的开发效率和质量。 ### 回答2: 本项目基于51单片机开发了一种步进电机控制系统,可实现电机的正反转功能。本文将介绍该系统的diy源代码。 该系统设计上采用了四相驱动的方式,步进电机控制器带有一个编码器和步进电机。通过流程控制语句,该系统可以转向和控制步进电机的速度。具体步骤如下: 1. 首先定义所用的引脚数目 ``` #define IN1 P2_0 //正转 #define IN2 P2_1 #define IN3 P2_2 #define IN4 P2_3 ``` 2. 定义电机移动的步长 ``` const unsigned char code MotorSteps[]={0xA,0x6,0x5,0x9}; ``` 3. 设置电机正转,反转,或停止 ``` void Turn(int Direction, int Speed) { int i,j; for(i=0;i<44-Speed;i++) { for(j=0;j<4;j++) { if(Direction == 1) //正转 { P2 = MotorSteps[j]; i++; } else if(Direction == 2) //反转 { P2 = MotorSteps[3-j]; i++; } else //停止 { P2 = 0x00; i++; } delay(10); } } } ``` 4. 使用捕获定时器来控制转动速度 ``` void timer(void) interrupt 1 { TH0 = 0xFF; TL0 = 0x97; flag ++; if(flag == rotSpeed) //转速控制 { flag = 0; counter ++; if(counter > 3) counter = 0; P2 = MotorSteps[counter]; } } int main() { while(1) { if(buttonDown(BTN_P)) //正转控制 { Turn(1,22); } if(buttonDown(BTN_N)) //反转控制 { Turn(2,22); } if(buttonDown(BTN_S)) //停止控制 { Turn(0,22); } } } ``` 通过以上的设计,我们已经可以实现基于51单片机步进电机控制系统控制电机的正反转以及速度。通过调整代码中的步数和转速,可以使该系统适用于不同的步进电机。 ### 回答3: 在基于51单片机步进电机控制系统设计开发过程中,需要考虑到正反转操作的实现。为此,我们需要编写相应的源代码以实现这一功能。 首先,我们需要了解步进电机的工作原理。步进电机通常有两种驱动方式:全步进和半步进。在控制步进电机运行过程中,最关键的是控制电机的每一个步进,以及确保它们按预设的顺序和速度运行。 我们可以使用信号采样方式,将步进电机的电压信号作为反馈输入,实现精准控制。同时,我们需要依据正反转操作的不同需要,分别设置开关量输出,以实现正转和反转的控制。 为了实现这一操作,我们需要编写一段程序代码,以实现步进电机正反转切换时的控制。我们可以设置一个开关量输入口,通过检测开关量的状态来判断是正转信号还是反转信号。通过判断信号状态以及步进电机的当前状态,我们可以实现正反转的切换和控制,保证步进电机运行的稳定性和可靠性。 总的来说,基于51单片机步进电机控制系统设计开发diy正反转源文件编写过程需要关注如下几点:对步进电机工作原理的理解、信号采样方式的选择、开关量状态的检测、步进电机当前状态的判断,以及控制正反转切换的代码实现。只有通过精心的设计和编写源文件,我们才能够实现一个高效、稳定和可靠的步进电机控制系统

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cqtianxingkeji

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值