ldy7474 发表于 2018-4-16 17:02:25

STC12C5A60S2做雕刻机驱动器

51单片机源程序:
/*z地址定义
50 1=x+,2=x-,3=y+,4=y-
51 前进后退步数高
52 前进后退步数低
53
54/55 字宽
56
57 弱光开关
58/59 激光强度
60 x轴速度
61 y轴速度
62 开始打印0,57
63 暂停
64 停止标志
65
66左右标记
100开始时灰度图数据
*/

#include <reg52.h>
#define uint unsigned int
#define uchar unsigned char
#define N z         //X速度
#define M z         //Y速度
sbit a=P1^3;//步进电机接线定义移动激光头
sbit a_=P1^2;
sbit b=P1^1;
sbit b_=P1^0;
sbit xa=P1^4;
sbit xa_=P1^5;
sbit xb=P1^6;
sbit xb_=P1^7;
/*sbit a=P1^4;//步进电机接线定义 移动底板
sbit a_=P1^5;
sbit b=P1^6;
sbit b_=P1^7;
sbit xa=P1^3;
sbit xa_=P1^2;
sbit xb=P1^1;
sbit xb_=P1^0;*/
sbit jg=P2^0;
sbit led=P2^1;//指示灯
uchar xdata z={0};//缓存
uchar buff;//串口缓存
uchar x1,x0,y1,y0,cont2=0;
uchar xfb=4,yfb=4;//走步标志位


unsigned char HighRH = 0;//高电平重载值的高字节
unsigned char HighRL = 0;//高电平重载值的低字节
unsigned char LowRH= 0;//低电平重载值的高字节
unsigned char LowRL= 0;//低电平重载值的低字节



void delayms(uint xms)                              
{   
      uint i,j;
      for(i=xms;i>0;i--)                      //i=xms即延时约xms毫秒
                for(j=110;j>0;j--);
}

/* 配置并启动PWM,fr-频率,dc-占空比 */
void ConfigPWM(unsigned int fr, unsigned char dc)
{
    unsigned inthigh, low;
    unsigned long tmp;
   
    tmp= (11059200/12) / fr;//计算一个周期所需的计数值
    high = (tmp*dc) / 100;      //计算高电平所需的计数值
    low= tmp - high;          //计算低电平所需的计数值
    high = 65536 - high + 12;   //计算高电平的重载值并补偿中断延时
    low= 65536 - low+ 12;   //计算低电平的重载值并补偿中断延时
    HighRH = (unsigned char)(high>>8); //高电平重载值拆分为高低字节
    HighRL = (unsigned char)high;
    LowRH= (unsigned char)(low>>8);//低电平重载值拆分为高低字节
    LowRL= (unsigned char)low;
    TMOD &= 0xF0;   //清零T0的控制位
    TMOD |= 0x01;   //配置T0为模式1
    TH0 = HighRH;   //加载T0重载值
    TL0 = HighRL;
    ET0 = 1;      //使能T0中断
    TR0 = 1;      //启动T0
    jg = 1;   //输出低电平,关闭激光
}
/* 关闭PWM */
void ClosePWM()
{
    TR0 = 0;   //停止定时器0
    ET0 = 0;   //禁止定时器0中断
    jg = 1;//输出低电平,关闭激光
}
/* T0中断服务函数,产生PWM输出 */
void InterruptTimer0() interrupt 1
{
    if (jg == 1)//当前输出为低电平时,装载高电平值并输出高电平
    {
      TH0 = LowRH;
      TL0 = LowRL;
      jg = 0;
    }
    else            //当前输出为高电平时,装载低电平值并输出低电平
    {
      TH0 = HighRH;
      TL0 = HighRL;
      jg = 1;
    }
}



void xfor(uint i)                //x轴前进函数,前进多少步
{   
while(1)
{
                if(xfb==4)
                  {
         xa=xb=1;
               xb_=xa_=0;
                     xfb=1;
                     i--;                        
               delayms(N);
                     if(i==0){xa=xb=0; break;}
                  }
                   if(xfb==1)
                  {
         xb=xa_=1;
               xa=xb_=0;
                     xfb=2;
                     i--;      
               delayms(N);
                     if(i==0){xa_=xb=0; break;}
                  }
                   if(xfb==2)
                  {
         xa_=xb_=1;
         xb=xa=0;
                     xfb=3;      //走步标志位
                     i--;
               delayms(N);
                     if(i==0){xa_=xb_=0; break;}
                   }
                   if(xfb==3)
                  {
         xa_=xb=0;
               xb_=xa=1;
                     xfb=4;
                     i--;      
               delayms(N);
                     if(i==0){xa=xb_=0; break;}
                  }


                }

}


void xbac(uint i)                //xxx后退函数
{   
   while(1)
         {
                if(xfb==1)
                  {
         xa_=xb=0;
               xb_=xa=1;
                     xfb=4;
                     i--;                              //走步标志位
               delayms(N);
                     if(i==0){xa=xb_=0; break;}
                   }
                   if(xfb==4)
                  {
         xa_=xb_=1;
         xb=xa=0;
                     xfb=3;
                     i--;      
               delayms(N);
                     if(i==0){xa_=xb_=0; break;}
                   }
                   if(xfb==3)
                  {
         xb=xa_=1;
               xa=xb_=0;
                     xfb=2;      //走步标志位
                     i--;      
               delayms(N);
                     if(i==0){xa_=xb=0; break;}
                   }
                   if(xfb==2)
                  {
         xa=xb=1;
               xb_=xa_=0;
                     xfb=1;
                     i--;      
               delayms(N);
                     if(i==0){xa=xb=0; break;}
                  }
                }
}



void yfor(uint i)                //y轴前进函数
{   
   while(1)
   {
               switch(yfb)
                   {
                     case 4:{a=b=1; b_=a_=0; yfb=1; i--; delayms(M); if(i==0){a=b=0;break;}}
                                 case 1:{b=a_=1; a=b_=0; yfb=2; i--; delayms(M); if(i==0){a_=b=0;break;}}
                                 case 2:{a_=b_=1; b=a=0; yfb=3; i--; delayms(M); if(i==0){a_=b_=0;break;}}
                                 case 3:{b_=a=1; a_=b=0; yfb=4; i--; delayms(M); if(i==0){a=b_=0;break;}}
                   }
                   if(i==0)break;
      }
}

void ybac(uint i)                //yy后退函数
{   
   while(1)
   {
               switch(yfb)
                   {
                     case 1:{a=b_=1; b=a_=0; yfb=4; i--; delayms(M); if(i==0){a=b_=0;break;}}
                                 case 4:{b_=a_=1; a=b=0; yfb=3; i--; delayms(M); if(i==0){a_=b_=0;break;}}
                                 case 3:{a_=b=1; b_=a=0; yfb=2; i--; delayms(M); if(i==0){a_=b=0;break;}}
                                 case 2:{b=a=1; a_=b_=0; yfb=1; i--; delayms(M); if(i==0){a=b=0;break;}}
                   }
                   if(i==0)break;
      }
}

void dazi(uint zik)//打印函数                   ******打印函数已更改******
{
    uint x;
                jg=0;

                        for(x=0;x<zik;x++)//执行zik个循环,x轴右移zik步
                        {
                        while(z);      //暂停等待
                              if(z==1) break;//停止标志 跳出循环
                              SBUF=255;                  // 每开始打印一个点,向上位机发送255,上位机进度显示用
                              jg=0;            //开激光
                              delayms((z*(z*256+z))/100);
                            jg=1;            //关闭激光
                        if(z==1)
                        {
                        xbac(1);
                        }      
             else
                         {
                         xfor(1);
                         }                        
                        }         
                if(z)    z=0;
            else{yfor(1);}             //y轴进一行
            z=0;                   //一行打印完成
                SBUF=1;                  //发送信息,表示打印一行完成
               
}

/* 串口配置函数,baud-通信波特率 */
void ConfigUART(unsigned int baud)
{
    SCON= 0x50;//配置串口为模式1
    TMOD &= 0x0F;//清零T1的控制位
    TMOD |= 0x20;//配置T1为模式2
    TH1 = 256 - (11059200/12/32)/baud;//计算T1重载值
    TL1 = TH1;   //初值等于重载值
    ET1 = 0;       //禁止T1中断
    ES= 1;       //使能串口中断
    TR1 = 1;       //启动T1
}


void chuanlo() interrupt 4
{
if(RI)
{
   buff=SBUF;//每次3字节,地址高,地址低,数据,,
   
         cont2++;
   if(cont2==3)//每收3个字节,把数据写入地址中
         {
            z[(buff*256)+buff]=buff;
                  cont2=0;
               SBUF=0;//*****************在这里加入这行代码测试一下*******************************
         }
         RI=0;


   
}
if(TI)
   {
   TI=0;

   }
}

main()
{
   EA=1;
   P0=0xff;
   ConfigUART(9600)      ;
      z=15;//默认的参数
      z=15;
      z=1;
      z=0;
      jg=0;
      cont2=0;
      
   while(1)
   {
                                                                                                                      //      *****此处已更改******

    if(z==100){ConfigPWM(100, 98);delayms(10);}         //上位机指令处理,打开弱光定位,频率100Hz,占空比98%                                                                     
    else if(z==1)   jg=0;                                                   //打开强光
      else   { ClosePWM(); delayms(10);}
         
          if(cont2!=0) led=0;else led=1;//指示通信是否可用
      if(z==1){xfor(z*256+z);z=0;}//x+
          if(z==2){xbac(z*256+z);z=0;}//x-
          if(z==3){yfor(z*256+z);z=0;}//y+
          if(z==4){ybac(z*256+z);z=0;}//y-

         
      if(z)//开始打印标志
          {
            dazi(z*256+z);
          }
   
}

}

ToyBoy 发表于 2018-4-16 17:31:16

第一次见发帖全是代码的http://www.moz8.com//mobcent//app/data/phiz/default/05.png

独行者 发表于 2018-4-16 17:36:55

谢谢楼主分享,静待楼主更新。

落木。 发表于 2018-4-16 18:25:08

期待楼主弄个像萝丽大神那样的教程

mingmingco 发表于 2018-4-17 10:09:21

thx.........................

清枫城主 发表于 2018-4-24 11:51:43

落木。 发表于 2018-4-16 18:25
期待楼主弄个像萝丽大神那样的教程

这广告是啥意思?评论还自带视频广告的?

落木。 发表于 2018-4-24 14:36:10

清枫城主 发表于 2018-4-24 11:51 static/image/common/back.gif
这广告是啥意思?评论还自带视频广告的?

论坛自带的吧!

pamhobby 发表于 2018-5-3 18:13:04

谢谢了楼主好人

昶春斋 发表于 2018-5-22 09:24:34

都是代码{:1_1:}{:1_1:}{:1_1:}

suyijiang 发表于 2019-1-21 15:46:12

感谢楼主分享。再具体说一下就更好啦,还有就是上位机的软件在哪里?

ldy7474 发表于 2019-1-22 19:47:39

suyijiang 发表于 2019-1-21 15:46 static/image/common/back.gif
感谢楼主分享。再具体说一下就更好啦,还有就是上位机的软件在哪里?

上位机用的微雕管家

就一修笔记本的 发表于 2019-1-25 00:26:16

电路图什么时候发

ldy7474 发表于 2019-1-26 20:45:08

就一修笔记本的 发表于 2019-1-25 00:26 static/image/common/back.gif
电路图什么时候发

P1口接 L298N驱动 步进电机


ldy7474 发表于 2019-1-26 20:46:19

本帖最后由 ldy7474 于 2019-1-26 21:12 编辑

就一修笔记本的 发表于 2019-1-25 00:26 static/image/common/back.gif
电路图什么时候发

P20接激光
P21接指示灯
用USB转TTL连接单片机和电脑


suyijiang 发表于 2019-1-30 07:44:46

ldy7474 发表于 2019-1-26 20:45
P1口接 L298N驱动 步进电机

X轴和Y轴在程序里没有啊

ldy7474 发表于 2019-1-30 07:54:58

suyijiang 发表于 2019-1-30 07:44 static/image/common/back.gif
X轴和Y轴在程序里没有啊

P1.0/P1.3Y轴   P1.4/P1.7X轴
2个步进电机分别对应X Y轴不太明白你说的程序
中没有是什么意思

suyijiang 发表于 2019-2-19 16:14:15

ldy7474 发表于 2019-1-30 07:54
P1.0/P1.3Y轴   P1.4/P1.7X轴
2个步进电机分别对应X Y轴不太明白你说的程序
中没有是什么意思


感谢回复,不是雕刻机,是用激光。哪Z轴没有控制啊?

独行者 发表于 2019-2-22 10:32:13

谢谢楼主分享!期待更新。

ldy7474 发表于 2019-2-24 21:34:03

suyijiang 发表于 2019-2-19 16:14 static/image/common/back.gif
感谢回复,不是雕刻机,是用激光。哪Z轴没有控制啊?

Z轴是控制激光器   

suyijiang 发表于 2019-2-25 09:54:47

ldy7474 发表于 2019-2-24 21:34
Z轴是控制激光器

楼主你好,程序里面没用控制Z轴的函数吧
页: [1] 2
查看完整版本: STC12C5A60S2做雕刻机驱动器