⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 processg72.c

📁 控制电机运动的G代码程序,如果对G代码不清楚,请先看懂G代码,然后再看本程序.
💻 C
📖 第 1 页 / 共 2 页
字号:
#include "base.h"
   

FP32        G72_Pos_U;	
FP32        G72_Pos_W;
FP32        G72_Pos_X;
FP32        G72_Pos_Z;
FP32        G72_Pos_I;
FP32        G72_Pos_K;
FP32        G72_Pos_R;

FP32        G72_Abs_PosX;
FP32        G72_Abs_PosZ;
FP32        G72_Abs_PosI;
FP32        G72_Abs_PosK;
FP32        G72_Abs_PosR;

BOOLEAN     G72_bEnd;
	 
BOOLEAN ProcessG72(INT32U StartHang,INT32U EndHang,FP32 ZaddPerTime,FP32 Zremain,FP32 Xremain,FP32 BackValue)
{

  INT32U  i;
  INT8U   ret;
  FP32    LoopStartXpos;
  FP32    LoopStartZpos;
  FP32    LoopEndXpos;
  FP32    LoopEndZpos;
  INT16U   LoopCount;
  FP32    Start_X;
  FP32    Start_Z;
  FP32    TempX,TempZ;
  
  for (i=0;i<MAXNUMBER;i++){
     LineValue[i].Pos=0;
     CircleValue[i].Pos=0;
     LineValue[i].StartX=0;
     CircleValue[i].StartZ=0;
     LineValue[i].EndX=0;
     CircleValue[i].EndZ=0;
     LineValue[i].K=0;
     CircleValue[i].K=0;
     CircleValue[i].I=0;
  }
  G72_bEnd=0;    
  G72ResetPara();
  CircleShapNum=0;
  AllNum=0;
  LineShapNum=0;
  Xdec=0;Xinc=0;Zdec=0;Zinc=0;
   
  G72.CurrentNum=G72FindStartHang(StartHang);
  if (G72.CurrentNum==0xfffff){
       DispErrCode(19);
       return FALSE;
  }
  if (G72ProcessAllCode(EndHang)!=6){
       DispErrCode(21);
       return FALSE;
  }
  if(AllNum<=1){
       DispErrCode(40);
       return FALSE;
  }  
  if(Xdec && Zinc){
       DispErrCode(39);return FALSE;
  }
  if(Xdec && Zdec){
       DispErrCode(39);return FALSE;
  }
  if(Xinc && Zinc){
        ZaddPerTime=fabs(ZaddPerTime);BackValue=fabs(BackValue);bit=FALSE;
  }
  if(Xinc && Zdec){
        ZaddPerTime=fabs(ZaddPerTime);BackValue=fabs(BackValue);bit=TRUE;
  }
  Start_X=Get_AbsPos(1);
  Start_Z=Get_AbsPos(3);
  
  i=0;
  while(1){
        if (CircleValue[i].Pos==1){
	        LoopStartZpos=CircleValue[i].StartZ;
	        break;
	    }
        if (LineValue[i].Pos==1){
	        LoopStartZpos=LineValue[i].StartZ;
	        break;
	    }
	    i++;
	    if(g_Scram)return FALSE;
  }
  
  i=0;
  while(1){
        if (CircleValue[i].Pos==AllNum){
	        LoopEndZpos=CircleValue[i].EndZ;
	        LoopEndXpos=CircleValue[i].EndX;
	        LoopStartXpos=CircleValue[i].EndX;
	        break;
	    }
        if (LineValue[i].Pos==AllNum){
	        LoopEndZpos=LineValue[i].EndZ;
	        LoopEndXpos=LineValue[i].EndX;
	        LoopStartXpos=LineValue[i].EndX;
	        break;
	    }
	    i++;
	    if(g_Scram)FALSE;
  }
//  LoopCount=(INT8U)(fabs((LoopStartZpos-LoopEndZpos)/ZaddPerTime));
//  if (LoopCount>200){DispErrCode(26);return FALSE;}
  
  LoopCount=(INT16U)(fabs((LoopStartZpos-LoopEndZpos)/ZaddPerTime));
  if (LoopCount>LOOPTIMES){DispErrCode(26);return FALSE;}
  if (LoopCount==0){DispErrCode(27);return FALSE;}
  
  Set_InpSpeed(g_Sysparam.Max_FastSpeed);
  Target_PosX=LoopStartXpos;
  Target_PosZ=LoopStartZpos;
  bRunInp=FALSE;
  while(1)
  {
	 G01_AbsPos(LoopStartXpos,LoopStartZpos);
	 g_MoveMode=1;
	 ret=WaitMotionEnd();
	 if(ret==255)return FALSE;
	 if(ret==0)break;
  }
 
  i=0;
  while(1)
  {
         g_Current_ASpeed=g_Current_PSpeed*g_Current_Inp_Rate;
	     if(g_Current_ASpeed>g_Sysparam.Max_FastSpeed)
		      g_Current_ASpeed=g_Sysparam.Max_FastSpeed;
	     Set_InpSpeed(g_Current_ASpeed);
	     if(bit)
	     {
	          TempX=G72ConstructionFunc(LoopStartZpos-i*ZaddPerTime)+Xremain;
	     }
	     else
	     {
	          TempX=G72ConstructionFunc(LoopStartZpos+i*ZaddPerTime)+Xremain;
	     }     
	     Target_PosX=TempX;
         Target_PosZ=Get_AbsPos(3);
	     bRunInp=TRUE;
	     while(1){
	          G01_AbsPos(TempX,Get_AbsPos(3));
	          g_MoveMode=1;
	          ret=WaitMotionEnd();
	          if(ret==255)return FALSE;
	          if(ret==0)break;
	     }
	     g_Current_ASpeed=g_Current_PSpeed*g_Current_Inp_Rate;
	     if(g_Current_ASpeed>g_Sysparam.Max_FastSpeed)
		      g_Current_ASpeed=g_Sysparam.Max_FastSpeed;
	     Set_InpSpeed(g_Current_ASpeed);
	     if(bit){
	           TempX=Get_AbsPos(1)+BackValue;TempZ=Get_AbsPos(3)+BackValue;
	     }else{
	           TempX=Get_AbsPos(1)+BackValue;TempZ=Get_AbsPos(3)-BackValue;
	     }
	     Target_PosX=TempX;
         Target_PosZ=TempZ;
	     bRunInp=TRUE;
	     while(1){
	          G01_AbsPos(TempX,TempZ);
	          g_MoveMode=1;
	          ret=WaitMotionEnd();
	          if(ret==255)return FALSE;
	          if(ret==0)break;
	     }
         Set_SipSpeed(1,g_Current_Fast_Rate*g_Sysparam.X_FastSpeed);
	     Set_SipSpeed(3,g_Current_Fast_Rate*g_Sysparam.Z_FastSpeed);
	     Target_PosX=LoopStartXpos;
	     bRunInp=FALSE;
         while(1){
	          Move_AbsPos(1,LoopStartXpos);
	          g_MoveMode=1;
	          ret=WaitMotionEnd();
	          if(ret==255)return FALSE;
	          if(ret==0)break;
         }
	     Set_SipSpeed(1,g_Current_Fast_Rate*g_Sysparam.X_FastSpeed);
	     Set_SipSpeed(3,g_Current_Fast_Rate*g_Sysparam.Z_FastSpeed);
	     if(bit){
	          TempZ=Get_AbsPos(3)-ZaddPerTime-BackValue;
	     }else{
	          TempZ=Get_AbsPos(3)+ZaddPerTime+BackValue;
	     }
	     Target_PosZ=TempZ;
	     bRunInp=FALSE;
         while(1){
	          Move_AbsPos(3,TempZ);
	          g_MoveMode=1;
	          ret=WaitMotionEnd();
	          if(ret==255)return FALSE;
	          if(ret==0)break;
         }
	     i++;
	     if (i==LoopCount)break;
  }
  
  Set_InpSpeed(g_Sysparam.Max_FastSpeed);
  Target_PosX=Start_X;
  Target_PosZ=Start_Z;
  bRunInp=FALSE;
  while(1){
	 G01_AbsPos(Start_X,Start_Z);
	 g_MoveMode=1;
	 ret=WaitMotionEnd();
	 if(ret==255)return FALSE;
	 if(ret==0)break;
  }
  return TRUE;
  
}


INT8U G72GetNextSeg(INT8U *First,INT8U *buf,INT8U *End)
{
	INT8U    s;
	INT16U   i;
	
	for(;;)
	{
		s=g_DataBuf.DataBuf[G72.CurrentNum];
		switch(s)
		{
		case '%':       
		     *First=s;
 			 buf[0]=0x0;
 			 Uart_Printf("%");
 			 Uart_Printf("%d",G72.CurrentNum);
			 return 4;//
		     break;
		case '(':
		case '/'://注释	
			*First=s;
			i=0;
			while(i<=255){
				G72.CurrentNum++;
				if(g_iCurrentNum>=g_DataBuf.DataLength)
				{
					buf[0]=0x0;
					*End=FALSE;
					return 255;			
				}
				s=g_DataBuf.DataBuf[G72.CurrentNum];
				if(s!=0x0a && s!=0x0d){
					buf[i]=s;		
				}
				if(s==0x0a){
					buf[i]=0x00;	
					*End=FALSE;
					G72.CurrentNum++;
					if(G72.CurrentNum>=g_DataBuf.DataLength)return 255;
					return 0;//一行代码结束
				}
				i++;
			}
			buf[0]=0x0;
			*End=TRUE;
			return 2;//注释超长
		case 0x0d:
		     G72.CurrentNum++;
		    break;
		case 0x0a:
			*First=s;
			G72.CurrentNum++;
			if(G72.CurrentNum>=g_DataBuf.DataLength)
			{	
				buf[0]=0x0;
				*End=FALSE;
				return 255;			
			}
			return 0;//一行代码结束
			break;
		case 'A':case 'B':case 'C':case 'D':case 'E':
		case 'F':case 'G':case 'H':case 'I':case 'J':
		case 'K':case 'L':case 'M':case 'N':case 'O':
		case 'P':case 'Q':case 'R':case 'S':case 'T':
		case 'U':case 'V':case 'W':case 'X':case 'Y':case 'Z':
			*First=s;
			i=0;
			while(i<=255){
				G72.CurrentNum++;
				if(G72.CurrentNum>=g_DataBuf.DataLength)
				{
					buf[0]=0x0;
					*End=TRUE;
					return 255;	
				}
				s=g_DataBuf.DataBuf[G72.CurrentNum];
				if((s>='0' && s<='9') || s=='.' || s=='-' || s=='+'){
					buf[i]=s;		
					i++;
				}
				else if(s==0x0d)	
				{
					;
				}
				else if(s==0x0a)    
				{
					buf[i]=0x00;
					*End=FALSE;
					G72.CurrentNum++;
					if(G72.CurrentNum>=g_DataBuf.DataLength)
						return 255;			
					return 0;//一行代码结束
				}
				else 
				{
					buf[i]=0x00;
					*End=FALSE;
					return 5;//字代码结束
				}
			}
			return 2; //数据超长	
		default:
			*First=s;
			buf[0]=0x00;
			*End=TRUE;
			return 3;//其它的字
		}
	}
}
 
INT8U G72ProcessAllCode(INT32U EndHang)
{
	INT8U 		    Error;
	INT8U 		    End;
	INT8U 		    num,len;
	INT8U 		    First,buf[255];
    INT8U           k,j;
    INT32U          Hang;
    
	while(1){			
    
        Error=G72GetNextSeg(&First,buf,&End);
        if(Error != 0 &&  Error !=5)break;
		if(End)break;
		switch(First)
		{
		case '%':		
		case '/':		
		case '(':		
		case 0x0d:
		case 0x0a:
             break;
		case 'N':	  
			 if(strlen((char *)buf)==0){Error=72;break;}
			 if(bN_Code==1) {Error=72;break;}
			 
             k=0;Hang=0;j=strlen((char *)buf);
	         while(j){
	               Hang=(buf[k]-'0')+Hang*10; 
              	   k++; 
              	   j--;    
	         }
			 if(EndHang==Hang)
			 {
			    G72_bEnd=TRUE;
			    G72ResetPara();
			 }
   		     bN_Code=TRUE;
			 break;
		case 'G':	
			len=strlen((char *)buf);
			if(len !=1 && len !=2 ){Error=72;break;}
			if(len==1) num=buf[0]-'0';
			else       num=(buf[0]-'0')*10+buf[1]-'0';
			switch(num){
			  case 0:		
			  case 1:		
			  case 2:		
			  case 3:	
			  case 4:	
				  bG_Code=1;
				  break;
			  default:
			      Error=72;
				  break;
			}
			iG_Code=num;
			break;
		case 'M':		
			len=strlen((char *)buf);
			if(len !=1 && len !=2 ){Error=72;break;}
			if(len==1) num=buf[0]-'0';
			else       num=(buf[0]-'0')*10+buf[1]-'0';
			switch(num){
			  case 3:		
			  case 4:		
			  case 5:		
			  case 8:		
			  case 9:		
			  case 10:	
			  case 11:	
			  case 32:
			  case 33:
				   iM_Code=num;
				   bM_Code=1;
				   break;
			  case 0:		
				   g_IsRun=2;
				   break;
			  default:
				   Error=72;
				   break;
			}		
			break;
		case 'X':
			if(strlen((char *)buf)==0){Error=72;break;}
			if(bU_Code||bX_Code){Error=72;break;}
			G72_Pos_X=BfFromStr(buf);
			if(g_Sysparam.DiaOrRadius)G72_Pos_X=G72_Pos_X/2;
		    bX_Code=TRUE;
			break;
		case 'Z':		
			if(strlen((char *)buf)==0){Error=72;break;}
			if(bW_Code||bZ_Code){Error=72;break;}
			G72_Pos_Z=BfFromStr(buf);
			bZ_Code=TRUE;
			break;
		case 'U':	
		    if(strlen((char *)buf)==0){Error=72;break;}
			if(bX_Code||bU_Code){Error=72;break;}
			G72_Pos_U=BfFromStr(buf);
		    if(g_Sysparam.DiaOrRadius)G72_Pos_U=G72_Pos_U/2;
			bU_Code =TRUE;
			break;
		case 'W':	
			if(strlen((char *)buf)==0){Error=72;break;}
			if(bZ_Code||bW_Code){Error=72;break;}
			G72_Pos_W=BfFromStr(buf);
			bW_Code = 1;
			break;
		case 'I':		
			if(strlen((char *)buf)==0){Error=72;break;}
			if(bI_Code){Error=72;break;}
			G72_Pos_I=BfFromStr(buf);
			bI_Code = TRUE;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -