JuYueChuantou_HeLian.c 73 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560
  1. #include "global.h"
  2. #if JUN_YUE_MACHINE == 1
  3. unsigned long CTXM_DOWN_TIME=0,PRV_CTXM_DOWN_TIME=0;
  4. unsigned long HSLIAO_OUT_DELAY=0,PRV_HSLIAO_OUT_DELAY=0;
  5. unsigned char FZ_ALARM_FLG=0;
  6. unsigned short XCCR_LENGTH;
  7. unsigned short CTHL_XCCR_Time;//小插传入次数
  8. void CTHL_SetAlarmCode(unsigned short alarm_code,unsigned short cStopFlag);
  9. void CTHL_ManualAction(void);
  10. void CTHL_AutoStepAction(void);
  11. void CTHL_TD_Motor(void);
  12. void CTHL_FZ_Motor(void);
  13. void CTHL_CheckStart(void);
  14. void CTHL_TLiao_Step(void); //推料(推拉头)
  15. void CTHL_AlarmProtect(void);
  16. void CTHL_ZLT_Step(void);
  17. void CTHL_ZhenDongAction(void);
  18. void CTHL_CTXMSS_Proc(void);
  19. void ExtiAcitionX02(void)
  20. {
  21. }
  22. //故障报警
  23. void CTHL_SetAlarmCode(unsigned short alarm_code,unsigned short cStopFlag)
  24. {
  25. SetAlarmCode(CTHL_ALARM_ADDR,alarm_code);
  26. if(!CTHL_wltzi && !bCxcAuto )
  27. bAlarmStop = 1;
  28. if(bCxcAuto)
  29. {
  30. SetEn(X_AXIS, MOTOR_EN);
  31. SetEn(Y_AXIS, MOTOR_EN);
  32. }
  33. }
  34. //初始化动作
  35. void CTHL_InitAction(void)
  36. {
  37. float buff_pulse,buff_dist;
  38. buff_pulse = CTHL_PARAM_TDCYCLE_PULSE;
  39. buff_dist = CTHL_PARAM_TDCYCLE_LENGTH;
  40. XGearRatio = buff_pulse/buff_dist;
  41. buff_pulse = CTHL_PARAM_TDCYCLE_PULSE;
  42. buff_dist = CTHL_PARAM_FZCYCLE_LENGTH;
  43. YGearRatio = buff_pulse/buff_dist;
  44. //传递伺服齿轮比参数
  45. set_com_servo_param(X_AXIS,CTHL_PARAM_TDCYCLE_PULSE,CTHL_PARAM_TDCYCLE_LENGTH);
  46. set_com_servo_param(Y_AXIS,CTHL_PARAM_TDCYCLE_PULSE,CTHL_PARAM_FZCYCLE_LENGTH);
  47. SetAlarmCode(CTHL_ALARM_ADDR,0);
  48. user_datas[121] = 0;
  49. user_datas[122] = 0;
  50. user_datas[123] = 0;
  51. SetEnReverse(X_AXIS, 0);
  52. SetEnReverse(Y_AXIS, 0);
  53. SetEnReverse(Z_AXIS, 0);
  54. SetDirReverse(X_AXIS, 0);
  55. SetDirReverse(Y_AXIS, 0);
  56. SetDirReverse(Z_AXIS, 0);
  57. //设置伺服告警极性,
  58. //伺服设置常开,则极性设置为0, 0为正常,1为告警,;
  59. //伺服设置为常闭,则极性设置为1,0,为正常,1位告警
  60. //SetAlarmReverse(X_AXIS,1);
  61. //SetAlarmReverse(Y_AXIS,0);
  62. SetServoComUse(X_AXIS,0);//Y轴正常模式。
  63. SetServoComUse(Y_AXIS,1);//X轴伺服扭矩通讯。
  64. ReadServoAlarm_Enable(Y_AXIS,1);
  65. ReadServoEncode_Enable(Y_AXIS,1);
  66. SetServoComUse(Z_AXIS,0);//Y轴正常模式。
  67. SetEn(X_AXIS, MOTOR_EN);
  68. SetEn(Y_AXIS, MOTOR_EN);
  69. SetEn(Z_AXIS, MOTOR_EN);
  70. SetPos(X_AXIS, 0); //启动位置设为0点
  71. SetPos(Y_AXIS, 0); //启动位置设为0点
  72. SetPos(Z_AXIS, 0); //启动位置设为0点
  73. cBAOjin=1;
  74. }
  75. void CTHL_Action(void)
  76. {
  77. dwXRealPos = GetPos(X_AXIS);
  78. dwYRealPos = GetPos(Y_AXIS);
  79. dwZRealPos = GetPos(Z_AXIS);
  80. dwYRealPos_com=get_encode_value(Y_AXIS);
  81. user_datas[121] = CTHL_Auto_RunState;//CTHL_PARAM_XMZM_MODE;//XCCR_LENGTH;//CTXM_DOWN_TIME;//dwYRealPos_com;//servo_y.init_step;//CTHL_ZhuangLiaoStep;
  82. user_datas[122] = bSingOneFlg;//;CTHL_CTXMSSStep;
  83. user_datas[123] = CTHL_TD_MotorStep;
  84. user_datas[124] = CTHL_LianLengthCheck;//CTHL_ZhuangLiaoStep;
  85. user_datas[125] = CTHL_LianLengthCheckOld;//CTHL_TLiaoStep;
  86. user_datas[126] = CTHL_AutoStep;//CTHL_FZ_MotorStep;//CTHL_TD_MotorStep;
  87. // user_datas[127] = CTHL_cZipCnt;//CTHL_ZhuangLiaoStep;
  88. // user_datas[128] = CTHL_FZ_MotorStep;//CTHL_LianLengthAutolengthcheck;
  89. CTHL_SERVO_COM=servo_y.IO_TO_COM;
  90. CTHL_ZhenDongAction();
  91. CTHL_AlarmProtect();
  92. CTHL_CheckStart();
  93. CTHL_ZLT_Step();
  94. CTHL_TLiao_Step();
  95. CTHL_TD_Motor();
  96. CTHL_FZ_Motor();
  97. CTHL_ManualAction();
  98. CTHL_AutoStepAction();
  99. CTHL_Test++;
  100. servo_com_run();
  101. CTHL_CTXMSS_Proc();
  102. }
  103. void CTHL_AlarmProtect(void)
  104. {
  105. }
  106. //自动动作
  107. void CTHL_AutoStepAction(void)
  108. {
  109. unsigned short freq;
  110. //测试用
  111. if(dwTickCount >= CTHL_TestDelay)
  112. {
  113. CTHL_TestDelay = dwTickCount + 200;
  114. CTHL_TestLED = !CTHL_TestLED;
  115. CTHL_Test = 0;
  116. }
  117. if(bRunning)
  118. {
  119. switch(CTHL_AutoStep)
  120. {
  121. case 1:
  122. CTHL_Auto_RunState=CTHL_STATE_START;//存在着装拉头,拖带,下模上升
  123. if(dwTickCount >= CTHL_AutoDelay)
  124. {
  125. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  126. {
  127. CTHL_TXM_VAVLE=0;
  128. CTHL_AutoStep = 2;
  129. //设置反转电机的扭矩和速度的设置
  130. freq=CTHL_PARAM_FZ_Speed+SERVO_PARAM_SPEED_DIFFER;
  131. if(CTHL_cZipCnt >=1)
  132. {
  133. set_servo_postotarr_limit(Y_AXIS,SERVO_PARAM_TRARR_LIMITMIN,freq,freq,SERVO_TARR_CW);
  134. }
  135. else
  136. {
  137. set_servo_postotarr_limit(Y_AXIS,SERVO_PARAM_TRARR_LIMITMAX,freq,freq,SERVO_TARR_CW);
  138. }
  139. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  140. bCxcAuto=0;
  141. if(CTHL_cZipCnt > 1) CTHL_AutoDelay = dwTickCount + 2;//拉头检测时间
  142. else CTHL_AutoDelay = dwTickCount + 100;//拉头检测时间
  143. CTHL_GF_Change = 0;
  144. }
  145. }
  146. break;
  147. case 2:
  148. if(bZhuangLiaoOkFlg && (CTHL_ZhuangLiaoStep == 0)&&(CTHL_TD_MotorStep==0)&&(CTHL_CTXMSSStep==0))
  149. {
  150. if(dwTickCount >= CTHL_AutoDelay )
  151. {
  152. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  153. {
  154. //if(!CTHL_PARAM_XMZM_MODE) {
  155. // CTHL_QMDW_VAVLE = 1;//0为斜码,1为直码
  156. //CTHL_FKDW_VAVLE = 0; //方块定位退
  157. // }
  158. CTHL_QMDW_VAVLE = 1;
  159. CTHL_YXC_VAVLE=1;
  160. CTHL_YFK_VAVLE=1;
  161. CTHL_JXM_VAVLE = 1; //夹斜码电磁阀
  162. if(CTHL_cZipCnt==0)CTHL_CTXM_VAVLE=1;
  163. CTHL_JLTou_VAVLE = 0; //接拉头
  164. CTHL_AutoStep = 3;
  165. CTHL_AutoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  166. CTHL_Auto_RunState=CTHL_STATE_QMDW;
  167. }
  168. }
  169. }
  170. break;
  171. case 3:
  172. if(CTHL_CTM_Limit_IN) //下模上到位
  173. {
  174. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  175. {
  176. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_XCDWFZ_DELAY;
  177. if(!CTHL_PARAM_XMZM_MODE)
  178. CTHL_AutoStep = 4;
  179. else
  180. CTHL_AutoStep = 5;
  181. }
  182. }
  183. else if((dwTickCount >= CTHL_AutoDelay) && !CTHL_bDANBU_MODE)
  184. {
  185. CTHL_SetAlarmCode(CTHL_CTM_Limit_ALARM,bRunning);//横送料原位异常
  186. }
  187. break;
  188. case 4:
  189. if(CTHL_QMDW_IN&&dwTickCount >= CTHL_AutoDelay&&!X_DRV)
  190. {
  191. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  192. {
  193. //AxisContinueMoveAcc(X_AXIS,1000,DIR_N,1000,600,15,5);
  194. AxisMovePosAccDec(X_AXIS,1500,-CTHL_PARAM_JMDW_LENGTH,1500,800,10,10,0); //前拖带松一点带
  195. AxisContinueMoveAcc(Y_AXIS,1500,DIR_N,1500,610,15,5);
  196. //Set_Ctrlmode_trans(Y_AXIS,TARR_MODE);
  197. CTHL_AutoStep = 5;
  198. CTHL_AutoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  199. //CTHL_JXM_VAVLE = 1; //夹斜码电磁阀
  200. }
  201. }
  202. else if((dwTickCount >= CTHL_AutoDelay+3000))
  203. {
  204. CTHL_SetAlarmCode(CTHL_QMDW_Limit_ALARM,bRunning);//前码定位感应异常
  205. }
  206. break;
  207. case 5:
  208. if(!CTHL_QMDW_IN || CTHL_PARAM_XMZM_MODE)
  209. //if(!X_DRV|| CTHL_PARAM_XMZM_MODE)
  210. {
  211. //上升沿只能一次,不能做断点
  212. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  213. {
  214. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_TXM_DELAY;
  215. CTHL_AutoStep = 6;
  216. }
  217. AxisEgmStop(X_AXIS);
  218. AxisEgmStop(Y_AXIS);
  219. //Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  220. }
  221. else if((dwTickCount >= CTHL_AutoDelay) && (!CTHL_bHandWork_MODE))
  222. {
  223. CTHL_SetAlarmCode(CTHL_QMDW_Limit_ALARM,bRunning);//前码定位感应异常
  224. }
  225. break;
  226. case 6:
  227. if(dwTickCount >= CTHL_AutoDelay) //顶斜码后拖反转
  228. {
  229. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  230. {
  231. AxisMovePosAccDec(X_AXIS,2000,-CTHL_PARAM_XMDD_LENGTH,2000,800,10,10,0); //前拖带松一点带
  232. AxisMovePosAccDec(Y_AXIS,2000,20,2000,800,10,10,0);
  233. CTHL_TXM_VAVLE=1; //Y06推斜码电磁阀
  234. CTHL_AutoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  235. CTHL_AutoStep = 7;
  236. }
  237. }
  238. break;
  239. case 7:
  240. if(CTHL_TXM_Limit_IN && CTHL_TXM_VAVLE ) //推斜码到位
  241. {
  242. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_TQMDW_DELAY;
  243. if(get_tarr_set(Y_AXIS)!=2)//伺服配置转矩限制失败
  244. {
  245. SetEn(Y_AXIS, MOTOR_DISEN);//设置扭矩做准备
  246. CTHL_wltzi=0;//停机
  247. CTHL_SetAlarmCode(CTHL_SERVO_CONFIG_ALARM,bRunning);//伺服转矩配置失败
  248. }
  249. CTHL_AutoStep = 8;
  250. }
  251. else if((dwTickCount >= CTHL_AutoDelay) && (!CTHL_bDANBU_MODE))
  252. {
  253. CTHL_SetAlarmCode(CTHL_TXM_Limit_ALARM,bRunning);//推斜码到异常
  254. }
  255. break;
  256. case 8:
  257. if(dwTickCount >= CTHL_AutoDelay&& !X_DRV&&!Y_DRV)
  258. {
  259. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  260. {
  261. CTHL_Auto_RunState=CTHL_STATE_FZDW;
  262. CTHL_QMDW_VAVLE=0;
  263. CTHL_FZ_MotorStep=1; //反转穿入
  264. //CTHL_FKDW_VAVLE = 0;
  265. //Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  266. CTHL_FZ_MotorDelay = dwTickCount + CTHL_PARAM_CRTD_DELAY;//延时穿入拖带
  267. CTHL_AutoStep = 9;
  268. }
  269. }
  270. break;
  271. case 9:
  272. if(CTHL_FZ_MotorStep==0)
  273. {
  274. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  275. {
  276. cBAOjin=0;
  277. CTHL_TFK_VAVLE=1;
  278. CTHL_YFK_VAVLE=0;
  279. CTHL_XCDW_VAVLE=1;
  280. CTHL_AutoStep = 10;
  281. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_FKDW_FZSTOP_DELAY;//拖带定位
  282. }
  283. }
  284. break;
  285. case 10:
  286. if(dwTickCount >= CTHL_AutoDelay)
  287. {
  288. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  289. {
  290. CTHL_Auto_RunState=CTHL_STATE_FZCL;
  291. CTHL_FZ_MotorStep=20;
  292. CTHL_AutoStep = 11;
  293. CTHL_FZ_MotorDelay = dwTickCount + 0;
  294. }
  295. }
  296. break;
  297. case 11:
  298. if(CTHL_FZ_MotorStep==0 && !X_DRV && !Y_DRV)
  299. {
  300. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  301. {
  302. CTHL_Auto_RunState=CTHL_STATE_CXCR;
  303. CTHL_JCBI_VAVLE = 1;
  304. CTHL_SD = 1;
  305. CTHL_AutoStep = 12;
  306. CTHL_AutoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  307. }
  308. }
  309. break;
  310. case 12:
  311. if(CTHL_TXC_Limit_IN) //摆臂到位
  312. {
  313. //CTHL_DingDai_VAVLE=1; //暂时不用
  314. CTHL_XCCR_Time=0;
  315. //if(CTHL_PARAM_FZCXC_LENGTH != 0)
  316. // AxisMovePosAccDec(Y_AXIS,2*CTHL_PARAM_XCCR_SPEED,CTHL_PARAM_FZCXC_LENGTH,800,800,15,15,0);//辅助小插插入
  317. CTHL_AutoStep = 13;
  318. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_XCIN_DELAY;//小插到位延时拖带
  319. }
  320. else if(dwTickCount >= CTHL_AutoDelay)
  321. {
  322. bCxcAuto=1;
  323. //CTHL_AutoStep = 101;
  324. //CTHL_JCBI_VAVLE = 0;
  325. //AxisMovePosAccDec(X_AXIS,1000,-50,1000,1000,15,15,0);//前轮布放松一点
  326. CTHL_SetAlarmCode(CTHL_XCBI_Limit_ALARM,bRunning);//小插摆臂到位异常
  327. }
  328. break;
  329. case 13:
  330. if(dwTickCount >= CTHL_AutoDelay && !Y_DRV)
  331. {
  332. SetPos(X_AXIS, 0);
  333. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  334. {
  335. CTHL_AutoDelay = dwTickCount + 0;//CTHL_PARAM_YDC_DELAY;
  336. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_XCCR_SPEED,CTHL_PARAM_XCCR_LENGTH,800,800,15,15,50);
  337. if(CTHL_SD)
  338. {
  339. CTHL_SD = 0;
  340. AxisMovePosAccDec(Y_AXIS,CTHL_PARAM_XCCR_SPEED+100,CTHL_PARAM_XCCR_LENGTH+CTHL_PARAM_FZCXC_LENGTH,800,800,15,15,0);
  341. }
  342. CTHL_DingDai_VAVLE=1;
  343. CTHL_AutoStep = 14;
  344. }
  345. CTHL_XSavePosBuff3=dwXRealPos;
  346. }
  347. break;
  348. case 14:
  349. if(CTHL_XCDW_Limit_IN)//||(dwXRealPos>=CTHL_XSavePosBuff3+CTHL_PARAM_XCCRBH_LENGTH))
  350. {
  351. XCCR_LENGTH=dwXRealPos-CTHL_XSavePosBuff3;
  352. CTHL_XSavePosBuff3 = dwXRealPos;
  353. CTHL_AutoStep = 15;
  354. CTHL_XCDW_VAVLE=0;
  355. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_TXCDW_DELAY;
  356. }
  357. //else if((dwTickCount >= (CTHL_AutoDelay+1000)) && (!CTHL_bHandWork_MODE))
  358. else if((dwTickCount >= (CTHL_AutoDelay+1200)||(dwXRealPos>=CTHL_XSavePosBuff3+CTHL_PARAM_XCCRBH_LENGTH)) && (!CTHL_bHandWork_MODE))
  359. {
  360. bCxcAuto=0;
  361. CTHL_DingDai_VAVLE=0;
  362. CTHL_XSavePosBuff3 = dwXRealPos;
  363. AxisEgmStop(X_AXIS);
  364. AxisEgmStop(Y_AXIS);
  365. //CTHL_AutoStep = 100;
  366. //CTHL_JCBI_VAVLE = 0; //Y16小插摆臂电磁阀
  367. //AxisMovePosAccDec(X_AXIS,800,-100,800,800,15,15,0);//前轮布放松一点
  368. CTHL_SetAlarmCode(CTHL_XCDW_Limit_ALARM,bRunning);//小插定位针异常
  369. }
  370. break;
  371. case 15:
  372. if((dwXRealPos >= (CTHL_XSavePosBuff3 + 50)))
  373. {
  374. AxisEgmStop(X_AXIS);
  375. AxisEgmStop(Y_AXIS);
  376. if(dwTickCount >= CTHL_AutoDelay)
  377. {
  378. CTHL_XCDW_VAVLE=0;
  379. CTHL_TFK_VAVLE = 0;
  380. CTHL_DingDai_VAVLE=0;
  381. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  382. {
  383. cDELAYONE=0;
  384. bZhuangLiaoOkFlg=0;
  385. CTHL_AutoStep = 16;
  386. CTHL_AutoDelay = dwTickCount + 0;
  387. }
  388. }
  389. }
  390. break;
  391. case 16:
  392. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  393. {
  394. if(dwTickCount >= CTHL_AutoDelay)
  395. {
  396. CTHL_AutoDelay = dwTickCount + 0;//CTHL_PARAM_TXCDW_DELAY ;
  397. bZhuangLiaoOkFlg=0;
  398. CTHL_AutoStep = 17;
  399. //AxisMovePosAccDec(X_AXIS,5000,-CTHL_PARAM_CRFZ_LENGTH,1500,800,10,10,0); //前拖带松一点带
  400. CTHL_YXC_VAVLE=0; //Y14压小插电磁阀
  401. CTHL_JCBI_VAVLE=0;
  402. }
  403. }
  404. break;
  405. case 100:
  406. if(CTHL_START_IN_UP)
  407. {
  408. SetEn(X_AXIS, MOTOR_DISEN);
  409. SetEn(Y_AXIS, MOTOR_DISEN);
  410. CTHL_AutoDelay = dwTickCount + 300 ;
  411. CTHL_AutoStep = 101;
  412. }
  413. break;
  414. case 101:
  415. if(dwTickCount >= CTHL_AutoDelay)
  416. {
  417. CTHL_XCCR_Time++;
  418. if(CTHL_XCCR_Time==1)
  419. {
  420. AxisMovePosAccDec(X_AXIS,800,-CTHL_XSavePosBuff3,800,800,15,15,0);//前轮布放松
  421. AxisMovePosAccDec(Y_AXIS,800,-CTHL_XSavePosBuff3,800,800,15,15,0);//前轮布放松
  422. }
  423. CTHL_AutoStep = 102;
  424. }
  425. break;
  426. case 102:
  427. if(!X_DRV&&!Y_DRV)
  428. {
  429. SetAlarmCode(CTHL_ALARM_ADDR,0);
  430. //AxisMovePosAccDec(X_AXIS,800,-100,800,800,15,15,0);//前轮布放松
  431. CTHL_YFK_VAVLE=1;
  432. CTHL_JCBI_VAVLE = 1; //Y16小插摆臂电磁阀
  433. // CTHL_XCDW_VAVLE=0;
  434. cDELAYONE=1;
  435. cBAOjin=1;
  436. CTHL_cZipCnt=0;
  437. bZhuangLiaoOkFlg=0;
  438. SetEn(X_AXIS, MOTOR_DISEN);
  439. SetEn(Y_AXIS, MOTOR_DISEN);
  440. // if(CTHL_FKGY_IN)
  441. // {
  442. // CTHL_AutoStep = 9;
  443. // CTHL_FZ_MotorStep==0;
  444. // }
  445. // else
  446. // {
  447. CTHL_AutoStep = 103;
  448. // }
  449. CTHL_AutoDelay = dwTickCount + 300 ;
  450. // if((GetAlarm(X_AXIS)==1 || GetAlarm(Y_AXIS)==1) && !CTHL_PARAM_DBSF_MODE)
  451. // {
  452. SetClr(X_AXIS, MOTOR_NOALARM);
  453. SetClr(Y_AXIS, MOTOR_NOALARM);
  454. CTHL_bSFBBAOJIN_Delay= dwTickCount + 200;
  455. // }
  456. if(CTHL_PARAM_DBSF_MODE)
  457. {
  458. if(!CTHL_SF_ALR_IN)
  459. {
  460. CTHL_SF_ALR_CLR=1;
  461. CTHL_bSFBBAOJIN_Delay= dwTickCount + 200;
  462. }
  463. }
  464. }
  465. break;
  466. case 103:
  467. if(dwTickCount >= CTHL_AutoDelay)
  468. {
  469. CTHL_AutoStep = 104;
  470. CTHL_AutoDelay = dwTickCount + 100 ;
  471. }
  472. break;
  473. case 104:
  474. if(dwTickCount >= CTHL_AutoDelay && !Y_DRV)
  475. {
  476. CTHL_AutoDelay = dwTickCount + 0;//CTHL_PARAM_YDC_DELAY;
  477. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_XCCR_SPEED,CTHL_PARAM_XCCR_LENGTH,800,800,15,15,50);
  478. CTHL_AutoStep = 105;
  479. CTHL_XSavePosBuff3=dwXRealPos;
  480. }
  481. break;
  482. case 105:
  483. if(CTHL_XCDW_Limit_IN)//||(dwXRealPos>=CTHL_XSavePosBuff3+CTHL_PARAM_XCCRBH_LENGTH))
  484. {
  485. XCCR_LENGTH=dwXRealPos-CTHL_XSavePosBuff3;
  486. CTHL_XSavePosBuff3 = dwXRealPos;
  487. CTHL_AutoStep = 15;
  488. CTHL_XCDW_VAVLE=0;
  489. CTHL_AutoDelay = dwTickCount + CTHL_PARAM_TXCDW_DELAY;
  490. }
  491. else if((dwTickCount >= (CTHL_AutoDelay+1200)||(dwXRealPos>=CTHL_XSavePosBuff3+CTHL_PARAM_XCCRBH_LENGTH+300)) && (!CTHL_bHandWork_MODE))
  492. {
  493. CTHL_XSavePosBuff3 = dwXRealPos;
  494. AxisEgmStop(X_AXIS);
  495. AxisEgmStop(Y_AXIS);
  496. if(CTHL_XCCR_Time>=2)
  497. {
  498. bCxcAuto=1;
  499. CTHL_SetAlarmCode(CTHL_XCDW_Limit_ALARM,bRunning);//小插定位针异常
  500. }
  501. else
  502. {
  503. CTHL_AutoStep = 100;
  504. CTHL_JCBI_VAVLE = 0; //Y16小插摆臂电磁阀
  505. }
  506. }
  507. break;
  508. case 17:
  509. if(dwTickCount >= CTHL_AutoDelay)
  510. {
  511. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  512. {
  513. CTHL_Auto_RunState=CTHL_STATE_TD;
  514. cDELAYONE=0;
  515. CTHL_TFK_VAVLE=0;
  516. CTHL_TD_MotorStep =10;
  517. CTHL_TD_MotorDelay = dwTickCount+ CTHL_PARAM_XCLD_DELAY;
  518. CTHL_AutoStep = 18;
  519. }
  520. }
  521. break;
  522. case 18:
  523. //if(!CTHL_CTM_Limit_IN)
  524. {
  525. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  526. {
  527. CTHL_JLTou_VAVLE = 0;
  528. //CTHL_CTXMSSStep=1;
  529. CTHL_AutoStep = 19;
  530. }
  531. }
  532. break;
  533. case 19:
  534. if((CTHL_TD_MotorStep == 0))
  535. {
  536. CTHL_Auto_RunState=CTHL_STATE_TD;
  537. if(!CTHL_bDANBU_MODE || CTHL_START_IN_UP)
  538. {
  539. CTHL_AutoStep = 1;
  540. if(bSingOneFlg)
  541. {
  542. CTHL_CTXM_VAVLE =0;
  543. CTHL_CTXMSSStep=0;
  544. CTHL_AutoStep = 0;
  545. bRunning = 0;
  546. bSingOneFlg = 0;
  547. }
  548. AddToTal(CTHL_TOTAL_ADDR);
  549. AddToTal(CTHL_TRUST_ALARM_ADDR);
  550. CalProSP(CTHL_SPEED_ADDR);
  551. //公分节那条也不加
  552. if((CTHL_cZipCnt<3) && !CTHL_GF_Change)
  553. CTHL_cZipCnt++;
  554. if((CTHL_NoLaLian_IN))
  555. CTHL_cZipCnt = 0;
  556. CTHL_GF_Change = 0;
  557. CTHL_AutoDelay = dwTickCount+0;
  558. }
  559. }
  560. break;
  561. }
  562. }
  563. }
  564. //下模上升处理
  565. void CTHL_CTXMSS_Proc(void)
  566. {
  567. static unsigned char hemoflag1=0,hemoflag2=0;
  568. if(bRunning)
  569. {
  570. switch(CTHL_CTXMSSStep)
  571. {
  572. case 1:
  573. if(!CTHL_CTM_Limit_IN)
  574. {
  575. CTHL_JXM_VAVLE=0;
  576. PRV_CTXM_DOWN_TIME= dwTickCount;
  577. if(CTXM_DOWN_TIME)HSLIAO_OUT_DELAY=dwTickCount+CTXM_DOWN_TIME*7/8;
  578. hemoflag1=1;
  579. hemoflag2=1;
  580. CTHL_CTXMSSStep = 2;
  581. CTHL_AutoDelay1 = dwTickCount+ 3000;
  582. }
  583. break;
  584. case 2: //测量时间
  585. if(CTHL_CTM_Origin_IN&&hemoflag1)
  586. {
  587. hemoflag1=0;
  588. PRV_CTXM_DOWN_TIME=dwTickCount-PRV_CTXM_DOWN_TIME;
  589. CTXM_DOWN_TIME=PRV_CTXM_DOWN_TIME;
  590. }
  591. //
  592. /*if(CTXM_DOWN_TIME&&(CTHL_cZipCnt > 1))//测量时间后的动作
  593. {
  594. if(dwTickCount>=HSLIAO_OUT_DELAY&&hemoflag2)
  595. {
  596. hemoflag2=0;
  597. CTHL_ZhuangLiaoStep = 1;
  598. CTHL_TryCnt = 0;
  599. bZhuangLiaoOkFlg=0;
  600. CTHL_ZhuangLiaoDelay = dwTickCount;
  601. }
  602. if(CTHL_CTM_Origin_IN)
  603. {
  604. CTHL_CTXMSSStep = 0;
  605. CTHL_MGuo_VAVLE = 0;
  606. CTHL_JLTou_VAVLE = 0;
  607. }
  608. else if(dwTickCount >= CTHL_AutoDelay1)
  609. {
  610. //穿头模和一次穿入回位异常
  611. if(!CTHL_CTM_Origin_IN)
  612. CTHL_SetAlarmCode(CTHL_CTM_Origin_ALARM,bRunning);
  613. }
  614. }
  615. else //测量时间前的动作*/
  616. {
  617. if(CTHL_CTM_Origin_IN)
  618. {
  619. CTHL_ZhuangLiaoStep = 1;
  620. CTHL_TryCnt = 0;
  621. bZhuangLiaoOkFlg=0;
  622. CTHL_ZhuangLiaoDelay = dwTickCount;
  623. CTHL_CTXMSSStep = 20;
  624. CTHL_MGuo_VAVLE = 0;
  625. CTHL_JLTou_VAVLE = 0;
  626. CTHL_GDLT_VAVLE=1;
  627. }
  628. else if(dwTickCount >= CTHL_AutoDelay1)
  629. {
  630. //穿头模和一次穿入回位异常
  631. if(!CTHL_CTM_Origin_IN)
  632. CTHL_SetAlarmCode(CTHL_CTM_Origin_ALARM,bRunning);
  633. }
  634. }
  635. break;
  636. case 20:
  637. if(bZhuangLiaoOkFlg && (CTHL_ZhuangLiaoStep == 0)&&CTHL_CTXMSS_FLAG)
  638. {
  639. CTHL_CTXMSS_FLAG=0;
  640. if(!CTHL_LTou_Check && !CTHL_TXM_Limit_IN)//有拉头,推斜码到位不能亮
  641. {
  642. if(!bSingOneFlg)
  643. {
  644. CTHL_CTXM_VAVLE=1;
  645. CTHL_JXM_VAVLE=1;
  646. CTHL_CTXMSSStep = 21;
  647. }
  648. else
  649. {
  650. CTHL_CTXMSSStep = 0;
  651. }
  652. }
  653. else
  654. {
  655. CTHL_wltzi=1;
  656. CTHL_SetAlarmCode(CTHL_ZLT_ALARM,bRunning); // 没有拉头
  657. }
  658. }
  659. break;
  660. case 21:
  661. if(CTHL_CTM_Limit_IN)
  662. {
  663. CTHL_CTXMSSStep = 0;
  664. }
  665. break;
  666. }
  667. }
  668. }
  669. //长按停止处理
  670. void CTHL_STOP_longPress_Proc(void)
  671. {
  672. if(bRunning)//保存停机位置
  673. {
  674. CTHL_Save_AutoStep=CTHL_AutoStep;
  675. CTHL_Save_ZhuangLiaoStep=CTHL_ZhuangLiaoStep;
  676. CTHL_Save_TLiaoStep=CTHL_TLiaoStep;
  677. CTHL_Save_TD_MotorStep=CTHL_TD_MotorStep;
  678. CTHL_Save_FZ_MotorStep=CTHL_FZ_MotorStep;
  679. CTHL_Save_CTXMSSStep=CTHL_CTXMSSStep;
  680. }
  681. CTHL_AutoStep = 0;
  682. CTHL_FZ_MotorStep =0;
  683. CTHL_TD_MotorStep =0;
  684. CTHL_ZhuangLiaoStep=0;
  685. CTHL_TLiaoStep=0;
  686. CTHL_Save_CTXMSSStep=0;
  687. bSingOneFlg=0;
  688. cBAOjin=0;
  689. CTHL_wltzi=0;
  690. CTHL_TLiao_VAVLE=0;
  691. CTHL_HSLiao_VAVLE =0;
  692. CTHL_JLTou_VAVLE =0;
  693. CTHL_TXM_VAVLE=0;
  694. CTHL_CTXM_VAVLE =0;
  695. CTHL_MGuo_VAVLE = 0;
  696. CTHL_JXM_VAVLE =0;
  697. CTHL_QMDW_VAVLE =0;
  698. CTHL_TFK_VAVLE =0;
  699. CTHL_HL_VAVLE =0;
  700. CTHL_YFK_VAVLE =0;
  701. CTHL_YXC_VAVLE =0;
  702. CTHL_XCDW_VAVLE=0;
  703. CTHL_JCBI_VAVLE =0;
  704. CTHL_DingDai_VAVLE=0;
  705. CTHL_LINK_ALARM=0;
  706. AxisEgmStop(X_AXIS);
  707. AxisEgmStop(Y_AXIS);
  708. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  709. SetEn(X_AXIS, MOTOR_EN);
  710. SetEn(Y_AXIS, MOTOR_EN);
  711. if((GetAlarm(X_AXIS)==1 || GetAlarm(Y_AXIS)==1) && !CTHL_PARAM_DBSF_MODE)
  712. {
  713. SetClr(X_AXIS, MOTOR_NOALARM);
  714. SetClr(Y_AXIS, MOTOR_NOALARM);
  715. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  716. }
  717. if(CTHL_PARAM_DBSF_MODE)
  718. {
  719. if(!CTHL_SF_ALR_IN)
  720. {
  721. CTHL_SF_ALR_CLR=1;
  722. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  723. }
  724. }
  725. SetAlarmCode(CTHL_ALARM_ADDR,0);
  726. bRunning=0;
  727. bStop=0;
  728. }
  729. //短按停止处理
  730. void CTHL_STOP_ShortPress_Proc(void)
  731. {
  732. if(bRunning&&!bSingOneFlg)
  733. {
  734. CTHL_Save_AutoStep=CTHL_AutoStep;
  735. CTHL_Save_ZhuangLiaoStep=CTHL_ZhuangLiaoStep;
  736. CTHL_Save_TLiaoStep=CTHL_TLiaoStep;
  737. CTHL_Save_TD_MotorStep=CTHL_TD_MotorStep;
  738. CTHL_Save_FZ_MotorStep=CTHL_FZ_MotorStep;
  739. CTHL_Save_CTXMSSStep=CTHL_CTXMSSStep;
  740. if(CTHL_TD_RunState==CTHL_STATE_TDLL)
  741. {
  742. bRunning=0;
  743. CTHL_AutoStep=0;
  744. CTHL_TD_MotorStep=0;
  745. CTHL_FZ_MotorStep=0;
  746. CTHL_CTXMSSStep=0;
  747. CTHL_CTXM_VAVLE=0;
  748. AxisEgmStop(X_AXIS);
  749. AxisEgmStop(Y_AXIS);
  750. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  751. SetEn(X_AXIS, MOTOR_EN);
  752. SetEn(Y_AXIS, MOTOR_EN);
  753. }
  754. else
  755. {
  756. bSingOneFlg=1;
  757. }
  758. }
  759. else
  760. {
  761. bRunning=0;
  762. bSingOneFlg=0;
  763. CTHL_Save_AutoStep=CTHL_AutoStep;
  764. CTHL_Save_ZhuangLiaoStep=CTHL_ZhuangLiaoStep;
  765. CTHL_Save_TLiaoStep=CTHL_TLiaoStep;
  766. CTHL_Save_TD_MotorStep=CTHL_TD_MotorStep;
  767. CTHL_Save_FZ_MotorStep=CTHL_FZ_MotorStep;
  768. CTHL_Save_CTXMSSStep=CTHL_CTXMSSStep;
  769. CTHL_AutoStep=0;
  770. CTHL_TD_MotorStep=0;
  771. CTHL_CTXMSSStep=0;
  772. CTHL_FZ_MotorStep=0;
  773. /*
  774. CTHL_TLiao_VAVLE=0;
  775. CTHL_HSLiao_VAVLE =0;
  776. CTHL_JLTou_VAVLE =0;
  777. CTHL_TXM_VAVLE=0;
  778. CTHL_CTXM_VAVLE =0;
  779. CTHL_JXM_VAVLE =0;
  780. CTHL_QMDW_VAVLE =0;
  781. CTHL_TFK_VAVLE =0;
  782. CTHL_HL_VAVLE =0;
  783. CTHL_YFK_VAVLE =0;
  784. CTHL_YXC_VAVLE =0;
  785. CTHL_XCDW_VAVLE=0;
  786. CTHL_JCBI_VAVLE =0;
  787. CTHL_DingDai_VAVLE=0;
  788. CTHL_LINK_ALARM=0;
  789. */
  790. AxisEgmStop(X_AXIS);
  791. AxisEgmStop(Y_AXIS);
  792. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  793. SetEn(X_AXIS, MOTOR_EN);
  794. SetEn(Y_AXIS, MOTOR_EN);
  795. if((GetAlarm(X_AXIS)==1 || GetAlarm(Y_AXIS)==1) && !CTHL_PARAM_DBSF_MODE)
  796. {
  797. SetClr(X_AXIS, MOTOR_NOALARM);
  798. SetClr(Y_AXIS, MOTOR_NOALARM);
  799. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  800. }
  801. if(CTHL_PARAM_DBSF_MODE)
  802. {
  803. if(!CTHL_SF_ALR_IN)
  804. {
  805. CTHL_SF_ALR_CLR=1;
  806. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  807. }
  808. }
  809. SetAlarmCode(CTHL_ALARM_ADDR,0);
  810. }
  811. }
  812. //停止出处理
  813. void CTHL_STOP_Proc(void)
  814. {
  815. if((CTHL_STOP_IN||bStop))//长按停止1.5S
  816. {
  817. if(dwTickCount>=CTHL_Stop_PressLongTime)
  818. //长按停止处理
  819. CTHL_STOP_longPress_Proc();
  820. }
  821. else
  822. {
  823. CTHL_Stop_PressLongTime=dwTickCount+1000;
  824. }
  825. if(CTHL_STOP_IN_UP|| bStop)//短按处理
  826. {
  827. //CTHL_Stop_PressTime=dwTickCount+100;
  828. CTHL_STOP_ShortPress_Proc();
  829. }
  830. //if(CTHL_STOP_IN_DW)CTHL_Stop_PressTime = dwTickCount + 80;
  831. }
  832. void CTHL_CheckStart(void)
  833. {
  834. //if(!CTHL_SafeDoor_IN && bRunning)
  835. //{
  836. // CTHL_SetAlarmCode(CTHL_SafeDoor_ALARM,0); // 安全门关上才能启动
  837. //}
  838. if(CTHL_START_IN_UP || bStart)
  839. {
  840. if((GetAlarm(X_AXIS)==1 || GetAlarm(Y_AXIS)==1) && !CTHL_PARAM_DBSF_MODE)
  841. {
  842. SetClr(X_AXIS, MOTOR_NOALARM);
  843. SetClr(Y_AXIS, MOTOR_NOALARM);
  844. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  845. }
  846. if(CTHL_PARAM_DBSF_MODE)
  847. {
  848. if(!CTHL_SF_ALR_IN)
  849. {
  850. CTHL_SF_ALR_CLR=1;
  851. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  852. }
  853. }
  854. SetAlarmCode(CTHL_ALARM_ADDR,0);
  855. }
  856. if(CTHL_wltzi)//无拉头启动
  857. {
  858. if(CTHL_START_IN_UP || bStart)
  859. {
  860. if(bRunning)
  861. {
  862. CTHL_wltzi=0;
  863. CTHL_AutoStep = 1;
  864. CTHL_ZhuangLiaoStep = 1;
  865. bTuiLaTouOkFlg = 1;
  866. bZhuangLiaoOkFlg= 0;
  867. CTHL_MGuo_VAVLE = 1; //判断是否已经有料
  868. CTHL_GDLT_VAVLE=0;
  869. CTHL_ZhuangLiaoDelay = dwTickCount + 150;
  870. if((GetAlarm(X_AXIS)==1 || GetAlarm(Y_AXIS)==1) && !CTHL_PARAM_DBSF_MODE)
  871. {
  872. SetClr(X_AXIS, MOTOR_NOALARM);
  873. SetClr(Y_AXIS, MOTOR_NOALARM);
  874. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  875. }
  876. if(CTHL_PARAM_DBSF_MODE)
  877. {
  878. if(!CTHL_SF_ALR_IN)
  879. {
  880. CTHL_SF_ALR_CLR=1;
  881. CTHL_bSFBBAOJIN_Delay= dwTickCount + 2000;
  882. }
  883. }
  884. }
  885. else
  886. {
  887. CTHL_wltzi=0;
  888. }
  889. }
  890. }
  891. #if 1
  892. //启动 自动启动 单一自动
  893. if((CTHL_START_IN_UP || bStart ) && !CTHL_wltzi)
  894. {
  895. if(!bRunning)
  896. {
  897. bRunning = 1;
  898. SetEn(X_AXIS, MOTOR_DISEN);
  899. SetEn(Y_AXIS, MOTOR_DISEN);
  900. CTHL_AutoStep = 1;
  901. CTHL_AutoDelay = dwTickCount + 100;
  902. if(CTHL_QMDW_VAVLE)CTHL_TD_MotorStep=0;
  903. else CTHL_TD_MotorStep = 1;
  904. CTHL_FZ_MotorStep = 0;
  905. CTHL_CTXMSSStep=0;
  906. CTHL_CTXMSS_FLAG=0;
  907. CTHL_ZhuangLiaoDelay = dwTickCount + 350;
  908. CTHL_ZhuangLiaoStep=1;
  909. bTuiLaTouOkFlg = 1;
  910. bZhuangLiaoOkFlg= 0;
  911. CTHL_cZipCnt = 0;
  912. CTHL_TryCnt = 0;
  913. bCxcAuto=0;
  914. CTHL_TLiao_VAVLE =0;
  915. CTHL_HSLiao_VAVLE =0;
  916. CTHL_JLTou_VAVLE =0;
  917. CTHL_CTXM_VAVLE =0;
  918. CTHL_JXM_VAVLE =0;
  919. CTHL_TXM_VAVLE = 0 ;
  920. CTHL_TFK_VAVLE =0;
  921. CTHL_HL_VAVLE =0;
  922. CTHL_YFK_VAVLE =0;
  923. CTHL_YXC_VAVLE =0;
  924. CTHL_XCDW_VAVLE =0;
  925. CTHL_JCBI_VAVLE =0;
  926. CTHL_DingDai_VAVLE=0;
  927. CTHL_MGuo_VAVLE = 1; //判断是否已经有料
  928. CTHL_GDLT_VAVLE=0;
  929. SetAlarmCode(CTHL_ALARM_ADDR,0);
  930. CTHL_Auto_RunState=0;
  931. CTHL_TD_RunState=0;
  932. bFZ_LengthOK = 0;
  933. CTHL_LianLengthCheck = 0;
  934. CTHL_LianLengthCheckOld = 0;
  935. }
  936. bStart = 0;
  937. }
  938. //停止
  939. CTHL_STOP_Proc();
  940. if(bAlarmStop)
  941. {
  942. bRunning = 0;
  943. bAlarmStop=0;
  944. CTHL_cStopMode=0;
  945. CTHL_Save_AutoStep=CTHL_AutoStep;
  946. CTHL_Save_ZhuangLiaoStep=CTHL_ZhuangLiaoStep;
  947. CTHL_Save_TLiaoStep=CTHL_TLiaoStep;
  948. CTHL_Save_TD_MotorStep=CTHL_TD_MotorStep;
  949. CTHL_Save_FZ_MotorStep=CTHL_FZ_MotorStep;
  950. CTHL_Save_CTXMSSStep=CTHL_CTXMSSStep;
  951. AxisEgmStop(X_AXIS);
  952. AxisEgmStop(Y_AXIS);
  953. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  954. CTHL_XCDW_VAVLE=0;
  955. CTHL_AutoStep = 0;
  956. CTHL_FZ_MotorStep =0;
  957. CTHL_TD_MotorStep =0;
  958. CTHL_CTXMSSStep=0;
  959. }
  960. #endif
  961. }
  962. void CTHL_NoLaLian_Speed_Proc(void)
  963. {
  964. if(CTHL_NoLaLian_IN_UP)
  965. {
  966. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,200,
  967. 1000,CTHL_PARAM_FKDWMAN_Speed/2,25,15,0); //YWX_CTHL_PARAM_TD_RunSpeed
  968. AxisContinueMoveAcc(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed,DIR_P,1500,800,15,15);
  969. }
  970. }
  971. void CTHL_TDLength_BH_Proc(unsigned short local)//拖带长度保护
  972. {
  973. if(local==0)//为感应到开关前
  974. {
  975. if(CTHL_cZipCnt < 2)
  976. {
  977. if((dwXRealPos >= CTHL_PARAM_first_CL_MAX_Length) && (!CTHL_bHandWork_MODE))
  978. {
  979. AxisEgmStop(X_AXIS);
  980. AxisEgmStop(Y_AXIS);
  981. user_datas[128]=CTHL_TD_MotorStep;
  982. CTHL_SetAlarmCode(CTHL_WLZDTJ_ALARM,bRunning); //无拉链自动停机
  983. }
  984. }
  985. else
  986. {
  987. if((dwXRealPos >=(CTHL_PARAM_WLCDSHEZHI_LENTH + CTHL_LianLengthCheck)) && (!CTHL_bHandWork_MODE))
  988. {
  989. AxisEgmStop(X_AXIS);
  990. AxisEgmStop(Y_AXIS);
  991. user_datas[128]=CTHL_TD_MotorStep;
  992. CTHL_SetAlarmCode(CTHL_WLZDTJ_ALARM,bRunning); //无拉链自动停机
  993. }
  994. }
  995. }
  996. else//感应到开关后
  997. {
  998. if(CTHL_cZipCnt < 2)
  999. {
  1000. if((dwXRealPos >= CTHL_PARAM_first_CL_MAX_Length+CTHL_LianLengthAutoFZCRcheck) && (!CTHL_bHandWork_MODE))
  1001. {
  1002. AxisEgmStop(X_AXIS);
  1003. AxisEgmStop(Y_AXIS);
  1004. user_datas[128]=CTHL_TD_MotorStep;
  1005. CTHL_SetAlarmCode(CTHL_WLZDTJ_ALARM,bRunning); //无拉链自动停机
  1006. }
  1007. }
  1008. else
  1009. {
  1010. if((dwXRealPos >=(CTHL_PARAM_WLCDSHEZHI_LENTH + CTHL_LianLengthCheck+CTHL_LianLengthCheckOld)) && (!CTHL_bHandWork_MODE))
  1011. {
  1012. AxisEgmStop(X_AXIS);
  1013. AxisEgmStop(Y_AXIS);
  1014. user_datas[128]=CTHL_TD_MotorStep;
  1015. CTHL_SetAlarmCode(CTHL_WLZDTJ_ALARM,bRunning); //无拉链自动停机
  1016. }
  1017. }
  1018. }
  1019. }
  1020. //拖带合链
  1021. void CTHL_TDHL_Proc(void)
  1022. {
  1023. //合链结束
  1024. if(CTHL_cZipCnt < 2)
  1025. {
  1026. //合链
  1027. if(dwXRealPos >= (CTHL_PARAM_SMG_LENGTH + CTHL_XSavePosBuff1)&&!CTHL_bHandWork_MODE)
  1028. {
  1029. //CTHL_XSavePosBuff2=dwXRealPos;
  1030. CTHL_HL_VAVLE=1;
  1031. }
  1032. if((dwXRealPos>(CTHL_LianLengthAutoFZCRcheck)))
  1033. {
  1034. CTHL_HL_VAVLE=0;
  1035. }
  1036. }
  1037. else
  1038. {
  1039. if(dwXRealPos >= CTHL_PARAM_HL_LENGTH)
  1040. {
  1041. CTHL_HL_VAVLE=1;
  1042. }
  1043. if((dwXRealPos>(CTHL_PARAM_HLWZ_LENGTH+CTHL_LianLengthAutoFZCRcheck-CTHL_PARAM_HELIAN_LENGTH)))
  1044. {
  1045. CTHL_HL_VAVLE=0;
  1046. }
  1047. }
  1048. }
  1049. //无方块处理
  1050. void CTHL_TDWFK_Proc(void)
  1051. {
  1052. }
  1053. //拖带电机控制动作 X轴
  1054. void CTHL_TD_Motor(void) //
  1055. {
  1056. if(dwTickCount >= CTHL_bSFBBAOJIN_Delay)
  1057. {
  1058. CTHL_SF_ALR_CLR=0;
  1059. SetClr(X_AXIS,MOTOR_ALARM);
  1060. SetClr(Y_AXIS,MOTOR_ALARM);
  1061. }
  1062. if(CTHL_PARAM_DBSF_MODE)
  1063. {
  1064. if(!CTHL_SF_ALR_IN)
  1065. {
  1066. bCxcAuto=1;
  1067. CTHL_AutoStep = 201;
  1068. CTHL_FZ_MotorStep =0;
  1069. CTHL_XCDW_VAVLE=0;
  1070. CTHL_TD_MotorStep =0;
  1071. AxisEgmStop(X_AXIS);
  1072. AxisEgmStop(Y_AXIS);
  1073. CTHL_SetAlarmCode(CTHL_SF_ALR_ALARM,bRunning); //无拉链自动停机
  1074. CTHL_JCBI_VAVLE = 0;
  1075. }
  1076. }
  1077. if((GetAlarm(Y_AXIS)==1 || GetAlarm(X_AXIS)==1) && !CTHL_PARAM_DBSF_MODE && !cBAOjin)
  1078. {
  1079. bCxcAuto=1;
  1080. cBAOjin=1;
  1081. AxisEgmStop(X_AXIS);
  1082. AxisEgmStop(Y_AXIS);
  1083. CTHL_AutoStep = 201;
  1084. CTHL_SetAlarmCode(CTHL_SF_ALR_ALARM,bRunning); //无拉链自动停机
  1085. CTHL_JCBI_VAVLE = 0;
  1086. // CTHL_TFK_VAVLE=0;
  1087. }
  1088. #if 1
  1089. switch(CTHL_TD_MotorStep)
  1090. {
  1091. //1步开始,纯定位, 没有穿入
  1092. case 1:
  1093. if(dwTickCount >= CTHL_TD_MotorDelay) //给锁轴时间
  1094. {
  1095. CTHL_TD_RunState=CTHL_STATE_TDLL;
  1096. //CTHL_FKDW_VAVLE=0;
  1097. if(CTHL_PARAM_Test)
  1098. CTHL_TXM_VAVLE = 0 ;
  1099. else
  1100. CTHL_TXM_VAVLE = 1; //因推斜码和固定方块一起,要避开
  1101. CTHL_TD_MotorStep = 2;
  1102. SetPos(X_AXIS, 0);
  1103. AxisContinueMoveAcc(X_AXIS,CTHL_PARAM_First_SPEED,DIR_P,1000,600,50,15);
  1104. AxisContinueMoveAcc(Y_AXIS,CTHL_PARAM_First_SPEED * 4/5,DIR_P,1000,600,50,15);
  1105. }
  1106. break;
  1107. case 2://检测到过链
  1108. if(dwXRealPos >= CTHL_PARAM_first_CL_MAX_Length)
  1109. {
  1110. CTHL_SetAlarmCode(CTHL_WLZDTJ_ALARM,bRunning); //无拉链自动停机
  1111. }
  1112. if(CTHL_FK_Check_UP)
  1113. {
  1114. CTHL_TD_RunState=CTHL_STATE_FKGY;
  1115. CTHL_XSavePosBuff = dwXRealPos;
  1116. AxisContinueMoveChangeSpeed(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,1000,50,20);
  1117. AxisContinueMoveChangeSpeed(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed,1000,50,20);
  1118. //AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_TDDW_LENGTH,
  1119. // 1000,1000,30,100,50);
  1120. //AxisMovePosAccDecNotStop(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed*4/5,CTHL_PARAM_TDDW_LENGTH,
  1121. // 1000,1000,30,100,50);
  1122. CTHL_TD_MotorStep = 3;
  1123. }
  1124. break;
  1125. case 3:
  1126. if(dwXRealPos>=CTHL_XSavePosBuff+200)
  1127. {
  1128. //CTHL_FKDW_VAVLE=1;
  1129. CTHL_TXM_VAVLE=0;
  1130. CTHL_TD_MotorStep = 4;
  1131. //CTHL_TD_MotorDelay = dwTickCount+ 1500;
  1132. }
  1133. break;
  1134. case 4:
  1135. //定位感应亮时、位置到达时,或X轴停止时,停止X轴
  1136. //if(dwTickCount >= CTHL_TD_MotorDelay)//3S为检测到停机
  1137. //{
  1138. // bCxcAuto=1;
  1139. // CTHL_SetAlarmCode(CTHL_FXDW_ALARM,bRunning);//方块钩针定位异常
  1140. //}
  1141. if(CTHL_FKDW_IN_UP)
  1142. {
  1143. CTHL_TD_RunState=CTHL_STATE_FKDW;
  1144. CTHL_TD_MotorStep = 5;
  1145. CTHL_TD_MotorDelay = dwTickCount+ 0;
  1146. AxisMovePosAccDec(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_XMCR_YJDW_LENGTH,
  1147. 1000,1000,30,100,50);
  1148. AxisMovePosAccDec(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_XMCR_YJDW_LENGTH,
  1149. 1000,1000,30,100,50);
  1150. }
  1151. break;
  1152. case 5:
  1153. if(!X_DRV&&!Y_DRV)
  1154. {
  1155. CTHL_TD_MotorStep = 0;
  1156. }
  1157. break;
  1158. //穿合拉头定位
  1159. case 10:
  1160. if(dwTickCount >= CTHL_TD_MotorDelay)
  1161. {
  1162. CTHL_TD_RunState=CTHL_STATE_TDHL;
  1163. CTHL_JCBI_VAVLE=0;
  1164. CTHL_DingDai_VAVLE=0;
  1165. CTHL_YXC_VAVLE=0;
  1166. CTHL_YFK_VAVLE=0;
  1167. CTHL_TXM_VAVLE=0;
  1168. CTHL_TD_MotorStep = 11;
  1169. SetPos(X_AXIS, 0); //启动位置设为0点
  1170. if(CTHL_cZipCnt == 0)CTHL_LianLengthCheckOld = 0;
  1171. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_HLT_SPEED_Speed,CTHL_PARAM_HL_LENGTH,
  1172. 1000,CTHL_PARAM_HLT_SPEED_Speed,250,25,00);
  1173. if(!CTHL_bHandWork_MODE)//在手动穿链模式下不用动电机同步
  1174. AxisMovePosAccDecNotStop(Y_AXIS,CTHL_PARAM_HLT_SPEED_Speed,CTHL_PARAM_HL_LENGTH,
  1175. 1000,CTHL_PARAM_HLT_SPEED_Speed,250,25,00);
  1176. CTHL_XSavePosBuff = dwXRealPos;
  1177. bFKCheck_Flag = 0;
  1178. CTHL_XSavePosBuff3 = 0;
  1179. }
  1180. break;
  1181. case 11:
  1182. CTHL_NoLaLian_Speed_Proc(); //最后拉链慢速的处理
  1183. //慢速合链长度,移动方块检测,躲避方块
  1184. if(dwXRealPos >= CTHL_PARAM_HL_LENGTH+200)
  1185. {
  1186. if(CTHL_PARAM_Test)
  1187. CTHL_TXM_VAVLE = 0 ;
  1188. else
  1189. CTHL_TXM_VAVLE = 1;
  1190. }
  1191. //第一方块信号检测
  1192. if(CTHL_FK_Check_UP && !bFKCheck_Flag)
  1193. {
  1194. bFKCheck_Flag = 1;
  1195. CTHL_XSavePosBuff3= dwXRealPos;
  1196. }
  1197. //慢速合链长度 如果已经到达下一条的方块也必须开模 ,CTHL_NoLaLian_IN最后几条慢速时感应才退下模
  1198. if(((dwXRealPos >= CTHL_PARAM_HL_LENGTH) && (!CTHL_bHandWork_MODE) && !CTHL_NoLaLian_IN) || (bFKCheck_Flag))
  1199. {
  1200. //码勾先打开15MS再退下模
  1201. if(CTHL_MGuo_VAVLE)
  1202. {
  1203. CTHL_MGuo_VAVLE=0;
  1204. CTHL_GDLT_VAVLE=1;
  1205. CTHL_TD_MotorDelay = dwTickCount + CTHL_PARAM_TMG_TXM_DELAY;;
  1206. }
  1207. else if(dwTickCount >= CTHL_TD_MotorDelay)
  1208. {
  1209. CTHL_XSavePosBuff1= dwXRealPos;
  1210. CTHL_CTXM_VAVLE=0;//推下模
  1211. CTHL_CTXMSSStep=1;
  1212. CTHL_TD_MotorStep = 12;
  1213. }
  1214. }
  1215. break;
  1216. case 12://退下模加速
  1217. CTHL_TDLength_BH_Proc(0);
  1218. CTHL_NoLaLian_Speed_Proc();
  1219. if(CTHL_FK_Check_UP && !bFKCheck_Flag)
  1220. {
  1221. bFKCheck_Flag = 1;
  1222. CTHL_XSavePosBuff3= dwXRealPos;
  1223. cGFJAUTO=0;
  1224. }
  1225. if(CTHL_CTM_Limit_IN)
  1226. {
  1227. CTHL_TD_MotorDelay = dwTickCount + CTHL_PARAM_TuiXiaMo_DELAY;
  1228. }
  1229. else if(dwTickCount >= CTHL_TD_MotorDelay) //下模离开后延时加速
  1230. {
  1231. if(!CTHL_bHandWork_MODE)
  1232. {
  1233. bHeLaTouOK = 1;
  1234. if((CTHL_cZipCnt > 1) && (!CTHL_NoLaLian_IN))
  1235. {
  1236. if(CTHL_LianLengthCheckOld == 0)
  1237. {
  1238. CTHL_DataBuff = 6000;
  1239. CTHL_LENTH=CTHL_LianLengthCheck - CTHL_PARAM_HL_LENGTH;
  1240. }
  1241. else if((CTHL_LianLengthCheck < 4000) && (CTHL_LianLengthCheckOld <4000))
  1242. {
  1243. CTHL_DataBuff = CTHL_PARAM_CLsudu_SPEED*3/4;
  1244. CTHL_LENTH=CTHL_LianLengthCheck + CTHL_LianLengthCheckOld- dwXRealPos;
  1245. }
  1246. else if((CTHL_LianLengthCheck < 5000) && (CTHL_LianLengthCheckOld <5000))
  1247. {
  1248. CTHL_DataBuff = CTHL_PARAM_CLsudu_SPEED*4/5;
  1249. CTHL_LENTH=CTHL_LianLengthCheck + CTHL_LianLengthCheckOld- dwXRealPos;
  1250. }
  1251. else
  1252. {
  1253. CTHL_DataBuff = CTHL_PARAM_CLsudu_SPEED;
  1254. CTHL_LENTH=CTHL_LianLengthCheck + CTHL_LianLengthCheckOld- dwXRealPos;
  1255. }
  1256. AxisMovePosAccDecNotStop(X_AXIS,CTHL_DataBuff,CTHL_LENTH,
  1257. 1000,CTHL_PARAM_FKDW_Speed,250,250,300);
  1258. }
  1259. else
  1260. {
  1261. if(CTHL_NoLaLian_IN)
  1262. CTHL_DataBuff = CTHL_PARAM_FKDWMAN_Speed/2;
  1263. else
  1264. CTHL_DataBuff = CTHL_PARAM_First_SPEED;
  1265. AxisContinueMoveAcc(X_AXIS,CTHL_DataBuff,DIR_P,1000,800,15,15);
  1266. }
  1267. AxisContinueMoveAcc(Y_AXIS,CTHL_DataBuff,DIR_P,1000,800,15,15);
  1268. CTHL_TD_MotorStep = 13;
  1269. }
  1270. }
  1271. break;
  1272. case 13:
  1273. CTHL_TDLength_BH_Proc(0);
  1274. CTHL_NoLaLian_Speed_Proc();
  1275. CTHL_TDHL_Proc();
  1276. //已经开完模具
  1277. if(CTHL_FK_Check_UP&& !bFKCheck_Flag)
  1278. {
  1279. bFKCheck_Flag = 1;
  1280. CTHL_XSavePosBuff3= dwXRealPos;
  1281. }
  1282. else if(bFKCheck_Flag) //说明第一个方块已经检测到
  1283. {
  1284. CTHL_TD_RunState=CTHL_STATE_TDLL;
  1285. CTHL_TD_MotorStep = 14;
  1286. }
  1287. break;
  1288. case 14:
  1289. CTHL_TDLength_BH_Proc(1);
  1290. CTHL_NoLaLian_Speed_Proc();
  1291. CTHL_TDHL_Proc();
  1292. //无链运行15公分
  1293. if(!CTHL_FK_Check && (dwXRealPos >= (CTHL_XSavePosBuff3 + 1500)))
  1294. {
  1295. CTHL_TD_MotorStep = 15;
  1296. if(CTHL_cZipCnt > 1)CTHL_CTXMSS_FLAG=1;
  1297. }
  1298. break;
  1299. case 15:
  1300. CTHL_TDLength_BH_Proc(1);
  1301. CTHL_NoLaLian_Speed_Proc();
  1302. CTHL_TDHL_Proc();
  1303. CTHL_TD_RunState=CTHL_STATE_TDLL;
  1304. //第二次感应方块, 要做定位
  1305. if(CTHL_FK_Check_UP && (dwXRealPos >= (CTHL_XSavePosBuff3 + 1800)))
  1306. {
  1307. CTHL_TD_RunState=CTHL_STATE_FKGY;
  1308. if(!CTHL_bHandWork_MODE)
  1309. {
  1310. if(!CTHL_NoLaLian_IN)
  1311. {
  1312. CTHL_XSavePosBuff = dwXRealPos;
  1313. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,300,
  1314. 1000,CTHL_PARAM_FKDWMAN_Speed,30,80,50);
  1315. AxisMovePosAccDecNotStop(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed,300,
  1316. 1000,CTHL_PARAM_FKDWMAN_Speed,30,80,50);
  1317. }
  1318. //长度测量
  1319. bFZ_LengthOK = 1;
  1320. if(CTHL_cZipCnt)
  1321. {
  1322. CTHL_LianLengthCheckOld = CTHL_LianLengthCheck;
  1323. }
  1324. CTHL_LianLengthCheck = dwXRealPos - CTHL_XSavePosBuff3;
  1325. //公分节处理
  1326. if((CTHL_LianLengthCheck <= CTHL_PARAM_GFJ_LENGTH) && (CTHL_cZipCnt>1))
  1327. {
  1328. CTHL_TD_MotorStep=50;
  1329. AxisContinueMoveAcc(X_AXIS,2000,DIR_P,1000,600,15,15);
  1330. AxisContinueMoveAcc(Y_AXIS,2000,DIR_P,1000,600,15,15);
  1331. CTHL_TD_MotorDelay = dwTickCount + 200;
  1332. bFZ_LengthOK= 0;
  1333. CTHL_cZipCnt = 0;
  1334. }
  1335. else
  1336. {
  1337. CTHL_TD_MotorStep = 16;
  1338. CTHL_AutoDelay=dwTickCount;
  1339. if(CTHL_cZipCnt<2)CTHL_CTXMSS_FLAG=1;
  1340. }
  1341. }
  1342. CTHL_XSavePosBuff = dwXRealPos;
  1343. }
  1344. CTHL_TDWFK_Proc();
  1345. break;
  1346. case 16:
  1347. if(dwXRealPos>=CTHL_XSavePosBuff+200)
  1348. {
  1349. //CTHL_FKDW_VAVLE=1;
  1350. CTHL_TD_MotorStep = 17;
  1351. //CTHL_TD_MotorDelay = dwTickCount+ 1500;
  1352. }
  1353. break;
  1354. case 17:
  1355. //定位感应亮时、位置到达时,或X轴停止时,停止X轴
  1356. //if(dwTickCount >= CTHL_TD_MotorDelay)//3S为检测到停机
  1357. //{
  1358. // bCxcAuto=1;
  1359. // CTHL_SetAlarmCode(CTHL_FXDW_ALARM,bRunning);//方块钩针定位异常
  1360. //}
  1361. if(CTHL_FKDW_IN)
  1362. {
  1363. CTHL_TD_RunState=CTHL_STATE_FKDW;
  1364. if(CTHL_cZipCnt > 1&&!CTHL_NoLaLian_IN_UP)
  1365. {
  1366. AxisMovePosAccDec(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_TDDW_LENGTH,
  1367. 1000,1000,30,100,50);
  1368. AxisMovePosAccDec(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_TDDW_LENGTH,
  1369. 1000,1000,30,100,50);
  1370. }
  1371. else
  1372. {
  1373. AxisMovePosAccDec(X_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_XMCR_YJDW_LENGTH,
  1374. 1000,1000,30,100,50);
  1375. AxisMovePosAccDec(Y_AXIS,CTHL_PARAM_FKDWMAN_Speed,CTHL_PARAM_XMCR_YJDW_LENGTH,
  1376. 1000,1000,30,100,50);
  1377. }
  1378. CTHL_TD_MotorStep = 18;
  1379. CTHL_TD_MotorDelay = dwTickCount+ 0;
  1380. bFZ_LengthOK = 1;
  1381. }
  1382. break;
  1383. case 18:
  1384. if(!X_DRV&&!Y_DRV)
  1385. {
  1386. CTHL_TD_MotorStep = 0;
  1387. }
  1388. break;
  1389. //由公分节调转
  1390. case 50:
  1391. if(CTHL_FK_Check_DW)
  1392. {
  1393. CTHL_TD_MotorStep = 51;
  1394. CTHL_TD_MotorDelay = dwTickCount + 100;
  1395. bFZ_LengthOK = 0;
  1396. CTHL_GF_Change = 1;
  1397. SetPos(X_AXIS, 0);
  1398. CTHL_CTXM_VAVLE=0;
  1399. CTHL_XSavePosBuff3=0;
  1400. }
  1401. break;
  1402. case 51:
  1403. if(dwTickCount >= CTHL_TD_MotorDelay&&!CTHL_FK_Check)
  1404. {
  1405. CTHL_TD_MotorStep = 52;
  1406. }
  1407. break;
  1408. case 52:
  1409. if(dwXRealPos>=CTHL_PARAM_GFJ_LENGTH)
  1410. {
  1411. CTHL_TryCnt = 0;
  1412. CTHL_LianLengthCheck = 0;
  1413. CTHL_LianLengthCheckOld = 0;
  1414. CTHL_TD_MotorStep = 15;
  1415. }
  1416. break;
  1417. }
  1418. #endif
  1419. }
  1420. //穿入电机动作,Y轴
  1421. void CTHL_FZ_Motor(void) //
  1422. {
  1423. #if 1
  1424. //1步开始, 穿链反转长度开始
  1425. //20步开始 插销定位开始
  1426. switch(CTHL_FZ_MotorStep)
  1427. {
  1428. //穿入长度位置
  1429. case 1:
  1430. if(dwTickCount >= CTHL_FZ_MotorDelay)
  1431. {
  1432. SetPos(X_AXIS, 0); //启动位置设为0点
  1433. SetPos(Y_AXIS, 0); //启动位置设为0点
  1434. FZ_ALARM_FLG=0;
  1435. //Set_Ctrlmode_trans(Y_AXIS,TARR_MODE);
  1436. if(CTHL_cZipCnt<1)//前两次走
  1437. {
  1438. AxisContinueMoveAcc(X_AXIS,CTHL_PARAM_JXM_SPEED,DIR_N,1000,1000,30,50);
  1439. AxisContinueMoveAcc(Y_AXIS,CTHL_PARAM_JXM_SPEED+500,DIR_N,1500,1000,30,50);
  1440. }
  1441. else
  1442. {
  1443. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_JXM_SPEED,-CTHL_PARAM_XMCR_SLOW_LENGTH,
  1444. 1000,CTHL_PARAM_JXM_SPEED,50,100,0);
  1445. AxisMovePosAccDecNotStop(Y_AXIS,CTHL_PARAM_JXM_SPEED+500,-CTHL_PARAM_XMCR_SLOW_LENGTH,
  1446. 1000,CTHL_PARAM_JXM_SPEED,50,100,0);
  1447. }
  1448. CTHL_FZ_MotorStep = 2;
  1449. }
  1450. break;
  1451. case 2:
  1452. if(abs(dwXRealPos) >=CTHL_PARAM_XMCR_SLOW_LENGTH-100){//提前转换模式
  1453. Set_Ctrlmode_trans(Y_AXIS,TARR_MODE);
  1454. }
  1455. if(abs(dwXRealPos) >= CTHL_PARAM_XMCR_SLOW_LENGTH)//穿链结束,开始走链加速
  1456. {
  1457. CTHL_FZ_MotorDelay = dwTickCount+0;
  1458. if(CTHL_cZipCnt<1||CTHL_NoLaLian_IN)
  1459. {
  1460. AxisContinueMoveChangeSpeed(X_AXIS,CTHL_PARAM_FZFirst_SPEED,1000,20,100);
  1461. AxisContinueMoveChangeSpeed(Y_AXIS,CTHL_PARAM_FZFirst_SPEED,1000,20,100);
  1462. }
  1463. else
  1464. {
  1465. //长度=反转长度-慢速长度-减速长度-修正长度;
  1466. CTHL_LENTH = CTHL_LianLengthAutoFZCRcheck-abs(dwXRealPos)-CTHL_PARAM_FZJS_LENGTH;
  1467. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_FZ_Speed,-CTHL_LENTH,
  1468. 1000,CTHL_PARAM_FZDS_Speed,250,150,0);
  1469. AxisMovePosAccDecNotStop(Y_AXIS,CTHL_PARAM_FZ_Speed+120,-CTHL_LENTH,
  1470. 1000,CTHL_PARAM_FZDS_Speed,120,100,0);
  1471. }
  1472. CTHL_FZ_MotorStep++;
  1473. }
  1474. //电机速度差太大
  1475. if(CTHL_cZipCnt<1)
  1476. {
  1477. if(abs(dwXRealPos)>dwYRealPos_com+1500)
  1478. {
  1479. //CTHL_FZ_MotorStep=100;
  1480. bCxcAuto=0;//停轴
  1481. SetEn(Y_AXIS, MOTOR_DISEN);
  1482. //SetAlarmCode(CTHL_ALARM_ADDR,CTHL_FZTD_KZ_ALARM);
  1483. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机卡滞
  1484. }
  1485. }
  1486. else
  1487. {
  1488. if(abs(dwXRealPos)>dwYRealPos_com+3000)
  1489. {
  1490. //CTHL_FZ_MotorStep=100;
  1491. bCxcAuto=0;//停轴
  1492. SetEn(Y_AXIS, MOTOR_DISEN);
  1493. //SetAlarmCode(CTHL_ALARM_ADDR,CTHL_FZTD_KZ_ALARM);
  1494. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机卡滞
  1495. }
  1496. }
  1497. break;
  1498. case 3:
  1499. if(dwTickCount> CTHL_FZ_MotorDelay+CTHL_PARAM_TJXM_LENGTH*10)CTHL_TXM_VAVLE=0; //到达可推出侧推布带时
  1500. //if((dwTickCount>CTHL_FZ_MotorDelay+CTHL_PARAM_TJXM_LENGTH*10 ) && !CTHL_TXM_VAVLE && !CTHL_TXM_Limit_IN)CTHL_JXM_VAVLE=0;
  1501. if(CTHL_cZipCnt<1||CTHL_NoLaLian_IN)
  1502. {
  1503. CTHL_FZ_MotorStep++;
  1504. }
  1505. else
  1506. {
  1507. if(abs(dwXRealPos)>=CTHL_LENTH+CTHL_PARAM_XMCR_SLOW_LENGTH)
  1508. {
  1509. AxisMovePosAccDecNotStop(X_AXIS,CTHL_PARAM_FZDS_Speed,-CTHL_PARAM_FZJS_LENGTH,
  1510. 1000,1000,120,80,CTHL_PARAM_FZJSDS_LENGTH);
  1511. AxisMovePosAccDecNotStop(Y_AXIS,CTHL_PARAM_FZDS_Speed,-CTHL_PARAM_FZJS_LENGTH,
  1512. 1000,1000,120,80,CTHL_PARAM_FZJSDS_LENGTH);
  1513. CTHL_FZ_MotorStep++;
  1514. }
  1515. }
  1516. //长度超出报警
  1517. if(CTHL_cZipCnt>=1)
  1518. {
  1519. if(abs(dwXRealPos)>= (CTHL_PARAM_WLCDSHEZHI_LENTH+ CTHL_LianLengthAutoFZCRcheck)) //拉带报警长度
  1520. {
  1521. bCxcAuto=0;//停轴
  1522. SetEn(Y_AXIS, MOTOR_DISEN);
  1523. CTHL_SetAlarmCode(CTHL_CRFK_ALARM,bRunning); //穿入方块超出预设长度
  1524. }
  1525. //方块检测异常(光纤)
  1526. if(abs(dwXRealPos) >= (CTHL_LianLengthAutoFZCRcheck + 300))
  1527. {
  1528. bCxcAuto=0;//停轴
  1529. SetEn(Y_AXIS, MOTOR_DISEN);
  1530. CTHL_SetAlarmCode(CTHL_FK_Check_ALARM,bRunning);
  1531. }
  1532. }
  1533. else
  1534. {
  1535. if(abs(dwXRealPos) >= CTHL_PARAM_first_CL_MAX_Length){ //位置大于第一条拉链长度
  1536. bCxcAuto=0;//停轴
  1537. SetEn(Y_AXIS, MOTOR_DISEN);
  1538. CTHL_SetAlarmCode(CTHL_CRFK_ALARM,bRunning); //穿入方块超出预设长度
  1539. }
  1540. }
  1541. //电机速度差太大
  1542. if(CTHL_cZipCnt<1)
  1543. {
  1544. if(abs(dwXRealPos)>dwYRealPos_com+1500)
  1545. {
  1546. //CTHL_FZ_MotorStep=100;
  1547. bCxcAuto=0;//停轴
  1548. SetEn(Y_AXIS, MOTOR_DISEN);
  1549. //SetAlarmCode(CTHL_ALARM_ADDR,CTHL_FZTD_KZ_ALARM);
  1550. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机
  1551. }
  1552. }
  1553. else
  1554. {
  1555. if(abs(dwXRealPos)>dwYRealPos_com+3000)
  1556. {
  1557. //CTHL_FZ_MotorStep=100;
  1558. bCxcAuto=0;//停轴
  1559. SetEn(Y_AXIS, MOTOR_DISEN);
  1560. SetAlarmCode(CTHL_ALARM_ADDR,CTHL_FZTD_KZ_ALARM);
  1561. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机
  1562. }
  1563. }
  1564. break;
  1565. case 4:
  1566. if(dwTickCount> CTHL_FZ_MotorDelay+CTHL_PARAM_TJXM_LENGTH*10)CTHL_TXM_VAVLE=0; //到达可推出侧推布带时
  1567. //if((dwTickCount>CTHL_FZ_MotorDelay+CTHL_PARAM_TJXM_LENGTH*10) && !CTHL_TXM_VAVLE && !CTHL_TXM_Limit_IN)CTHL_JXM_VAVLE=0;
  1568. if((abs(dwXRealPos) > 500) && CTHL_FKGY_IN_UP)//位置大于100,且方块感应上升沿
  1569. {
  1570. CTHL_XSavePosBuff1 = abs(dwXRealPos);
  1571. if(CTHL_cZipCnt<1||CTHL_NoLaLian_IN){//记录前两条的方块感应长度;
  1572. //停机距离调整
  1573. CTHL_LENTH=10;//CTHL_PARAM_FZSTOP_LENGTH;
  1574. AxisMovePosAccDec(X_AXIS,800,-CTHL_LENTH,
  1575. 800,800,15,25,0);
  1576. AxisMovePosAccDec(Y_AXIS,600,-CTHL_LENTH,
  1577. 800,800,15,25,0);
  1578. }
  1579. else {
  1580. //停机距离调整
  1581. CTHL_LENTH=CTHL_PARAM_FZSTOP_LENGTH;
  1582. AxisMovePosAccDec(X_AXIS,1000,-CTHL_LENTH,
  1583. 800,800,15,25,0);
  1584. AxisMovePosAccDec(Y_AXIS,600,-CTHL_LENTH,
  1585. 800,800,15,25,0);
  1586. }
  1587. CTHL_FZ_MotorStep++;
  1588. }
  1589. //长度超出报警
  1590. if(CTHL_cZipCnt>=1)
  1591. {
  1592. if(abs(dwXRealPos)>= (CTHL_PARAM_WLCDSHEZHI_LENTH+ CTHL_LianLengthAutoFZCRcheck)) //拉带报警长度
  1593. {
  1594. bCxcAuto=0;//停轴
  1595. SetEn(Y_AXIS, MOTOR_DISEN);
  1596. CTHL_SetAlarmCode(CTHL_CRFK_ALARM,bRunning); //穿入方块超出预设长度
  1597. }
  1598. //方块检测异常(光纤)
  1599. if(abs(dwXRealPos) >= (CTHL_LianLengthAutoFZCRcheck + 300))
  1600. {
  1601. bCxcAuto=0;//停轴
  1602. SetEn(Y_AXIS, MOTOR_DISEN);
  1603. CTHL_SetAlarmCode(CTHL_FK_Check_ALARM,bRunning);
  1604. }
  1605. }
  1606. else
  1607. {
  1608. if(abs(dwXRealPos) >= CTHL_PARAM_first_CL_MAX_Length){ //位置大于第一条拉链长度
  1609. bCxcAuto=0;//停轴
  1610. CTHL_SetAlarmCode(CTHL_CRFK_ALARM,bRunning); //穿入方块超出预设长度
  1611. }
  1612. }
  1613. //电机速度差太大
  1614. if(CTHL_cZipCnt<1)
  1615. {
  1616. if(abs(dwXRealPos)>dwYRealPos_com+1500)
  1617. {
  1618. //CTHL_FZ_MotorStep=100;
  1619. bCxcAuto=0;//停轴
  1620. SetEn(Y_AXIS, MOTOR_DISEN);
  1621. //SetAlarmCode(CTHL_ALARM_ADDR,CTHL_FZTD_KZ_ALARM);
  1622. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机
  1623. }
  1624. }
  1625. else
  1626. {
  1627. if(abs(dwXRealPos)>dwYRealPos_com+3000)
  1628. {
  1629. //CTHL_FZ_MotorStep=100;
  1630. bCxcAuto=0;//停轴
  1631. SetEn(Y_AXIS, MOTOR_DISEN);
  1632. SetAlarmCode(CTHL_ALARM_ADDR,CTHL_FZTD_KZ_ALARM);
  1633. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机
  1634. }
  1635. }
  1636. break;
  1637. case 5:
  1638. if(!Y_DRV && !X_DRV)
  1639. {
  1640. if((CTHL_cZipCnt <= 1))
  1641. {
  1642. CTHL_LianLengthCheck = abs(dwXRealPos); //为第一条长度给值
  1643. CTHL_LianLengthAutoFZCRcheck = abs(dwXRealPos);
  1644. CTHL_LianLengthAutoFZcheck=abs(dwXRealPos);
  1645. }
  1646. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  1647. CTHL_FZ_MotorStep = 0;
  1648. }
  1649. break;
  1650. //20步开始小插定位
  1651. case 20: //此处最好算好定位长度相减
  1652. if(dwTickCount >= CTHL_FZ_MotorDelay)
  1653. {
  1654. CTHL_FZ_MotorStep = 21;
  1655. SetPos(Y_AXIS, 0); //启动位置设为0点
  1656. SetPos(X_AXIS, 0); //启动位置设为0点
  1657. }
  1658. break;
  1659. case 21:
  1660. if(CTHL_PARAM_CXDW_Length)
  1661. {
  1662. CTHL_FZ_MotorStep = 22;
  1663. AxisMovePosAccDec(Y_AXIS,2*CTHL_PARAM_XCCR_SPEED,-CTHL_PARAM_CXDW_Length,1000,1000,20,20,0);
  1664. AxisMovePosAccDec(X_AXIS,2*CTHL_PARAM_XCCR_SPEED,-CTHL_PARAM_CXDW_Length,1000,1000,20,20,0);
  1665. }
  1666. break;
  1667. case 22:
  1668. if(!Y_DRV && !X_AXIS )
  1669. {
  1670. CTHL_FZ_MotorStep = 0;
  1671. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  1672. }
  1673. break;
  1674. case 100:
  1675. if(dwYRealPos_com>=CTHL_PARAM_XMCR_SLOW_LENGTH+100&&dwYRealPos_com<=CTHL_LianLengthAutoFZCRcheck-500)//穿过慢速长度
  1676. {
  1677. SetPos(Y_AXIS, 0);
  1678. CTHL_FZ_MotorStep = 101;
  1679. CTHL_XSavePosBuff1=dwYRealPos_com;
  1680. }
  1681. else
  1682. {
  1683. bCxcAuto=0;//停机
  1684. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机卡滞
  1685. }
  1686. break;
  1687. case 101:
  1688. CTHL_FZ_MotorStep = 102;
  1689. Set_Ctrlmode_trans(Y_AXIS,POS_MODE);
  1690. CTHL_FZ_MotorDelay=dwTickCount+50;
  1691. break;
  1692. case 102:
  1693. CTHL_FZ_MotorStep = 103;
  1694. AxisMovePosAccDec(Y_AXIS,1500,-500,1500,1500,20,20,0);
  1695. break;
  1696. case 103:
  1697. if(!Y_DRV)
  1698. {
  1699. if(dwYRealPos_com>=CTHL_XSavePosBuff1+500)
  1700. {
  1701. Set_Ctrlmode_trans(Y_AXIS,TARR_MODE);
  1702. SetAlarmCode(CTHL_ALARM_ADDR,0);
  1703. CTHL_FZ_MotorStep = 4;
  1704. FZ_ALARM_FLG=1;
  1705. }
  1706. else
  1707. {
  1708. bCxcAuto=0;//停机
  1709. CTHL_SetAlarmCode(CTHL_FZTD_KZ_ALARM,bRunning); //反转电机卡滞
  1710. }
  1711. }
  1712. break;
  1713. }
  1714. #endif
  1715. }
  1716. //装拉头动作
  1717. void CTHL_ZLT_Step(void)
  1718. {
  1719. switch(CTHL_ZhuangLiaoStep)
  1720. {
  1721. case 1:
  1722. if(bZhuangLiaoOkFlg)
  1723. {
  1724. CTHL_ZhuangLiaoStep = 0;
  1725. }
  1726. else
  1727. {
  1728. if(((CTHL_MGuo_VAVLE && CTHL_LTou_Check) || (!CTHL_MGuo_VAVLE))&&CTHL_GDLT_VAVLE )//说明没有拉头
  1729. {
  1730. /*if(bRunning&&CTXM_DOWN_TIME&&CTHL_cZipCnt>1)
  1731. {
  1732. if(CTHL_TLiaoStep == 0)
  1733. {
  1734. CTHL_TLiaoStep = 1;
  1735. CTHL_ZhuangLiaoStep = 40;
  1736. }
  1737. }
  1738. else*/
  1739. {
  1740. //穿头模和一次穿入必须在原位,接料不能有输出
  1741. if(CTHL_CTM_Origin_IN && !CTHL_CTXM_VAVLE)
  1742. {
  1743. CTHL_JLTou_VAVLE = 0;
  1744. CTHL_GDLT_VAVLE=1;
  1745. CTHL_MGuo_VAVLE = 0;
  1746. if(CTHL_TLiaoStep == 0)
  1747. {
  1748. CTHL_TLiaoStep = 1;
  1749. CTHL_ZhuangLiaoStep = 2;
  1750. }
  1751. }
  1752. else if(dwTickCount >= CTHL_ZhuangLiaoDelay + 1000) //警告横送拉必须保证穿头模和一次穿入在原位,接料不能有输出
  1753. {
  1754. CTHL_wltzi=1;
  1755. CTHL_SetAlarmCode(CTHL_CTM_Origin_ALARM,bRunning);
  1756. }
  1757. }
  1758. }
  1759. else if(dwTickCount >= CTHL_ZhuangLiaoDelay)//已经有拉头直接跳到结束
  1760. {
  1761. CTHL_ZhuangLiaoDelay = dwTickCount + 40;
  1762. CTHL_ZhuangLiaoStep = 9;
  1763. }
  1764. }
  1765. break;
  1766. /* case 40:
  1767. if(CTHL_TLiaoStep == 0) //推料已经完成
  1768. {
  1769. CTHL_HSLiao_VAVLE = 1;
  1770. CTHL_ZhuangLiaoStep = 41;
  1771. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  1772. }
  1773. break;
  1774. case 41:
  1775. if(!CTHL_HSLiao_Origin_IN&&!CTHL_CTM_Minid_IN)//离开原点
  1776. {
  1777. CTHL_ZhuangLiaoStep = 42;
  1778. CTHL_ZhuangLiaoDelay=dwTickCount+HSLIAO_CHECK_TIME+1;//横送过程检测
  1779. }
  1780. break;
  1781. case 42:
  1782. if(dwTickCount>=CTHL_ZhuangLiaoDelay)//兼容没有做缓冲的情况
  1783. {
  1784. if(CTHL_CTM_Origin_IN )//穿头模和第一次合链在原位
  1785. {
  1786. CTHL_ZhuangLiaoStep = 3;
  1787. }
  1788. else
  1789. {
  1790. CTHL_ZhuangLiaoStep = 43;
  1791. CTHL_HSLiao_VAVLE = 0;
  1792. CTHL_ZhuangLiaoDelay = dwTickCount + 20;
  1793. }
  1794. }
  1795. break;
  1796. case 43:
  1797. if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1798. {
  1799. if(CTHL_CTM_Origin_IN )//穿头模和第一次合链在原位
  1800. {
  1801. CTHL_ZhuangLiaoStep = 3;
  1802. CTHL_HSLiao_VAVLE = 1;
  1803. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  1804. }
  1805. }
  1806. break;*/
  1807. case 2:
  1808. if(CTHL_TLiaoStep == 0) //推料已经完成
  1809. {
  1810. CTHL_ZhuangLiaoDelay = dwTickCount+ 500;
  1811. CTHL_GDLT_VAVLE = 1;
  1812. CTHL_MGuo_VAVLE = 0;
  1813. if(!CTHL_JLTou_VAVLE)
  1814. {
  1815. CTHL_ZhuangLiaoStep = 3;
  1816. CTHL_HSLiao_VAVLE = 1;
  1817. PRV_HSLIAO_OUT_DELAY=dwTickCount;
  1818. }
  1819. }
  1820. break;
  1821. case 3:
  1822. //横送到位
  1823. if(CTHL_HSLiao_Limit_IN && !CTHL_HSLiao_Origin_IN)
  1824. {
  1825. HSLIAO_OUT_DELAY=dwTickCount-PRV_HSLIAO_OUT_DELAY;
  1826. CTHL_ZhuangLiaoStep = 4;
  1827. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_PARAM_H_JLiao_DELAY;
  1828. }
  1829. else if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1830. {
  1831. CTHL_ZhuangLiaoStep = 30;
  1832. }
  1833. break;
  1834. case 4:
  1835. if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1836. {
  1837. CTHL_ZhuangLiaoStep = 5;
  1838. CTHL_JLTou_VAVLE = 1; //接拉头输出,不需要时间
  1839. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_PARAM_JLTOU_DELAY;
  1840. }
  1841. break;
  1842. case 5:
  1843. if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1844. {
  1845. CTHL_ZhuangLiaoStep = 6;
  1846. CTHL_GDLT_VAVLE = 0; //接拉头输出,不需要时间
  1847. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_PARAM_GDLT_DELAY;
  1848. }
  1849. break;
  1850. case 6:
  1851. if(dwTickCount >= CTHL_ZhuangLiaoDelay) //延时码勾
  1852. {
  1853. CTHL_MGuo_VAVLE = 1; //码勾输出
  1854. CTHL_ZhuangLiaoStep = 7;
  1855. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_PARAM_HSLiaoOff_DELAY;
  1856. bTuiLaTouOkFlg = 0; //认为拉头没法带出
  1857. }
  1858. break;
  1859. case 7:
  1860. if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1861. {
  1862. CTHL_HSLiao_VAVLE = 0;
  1863. CTHL_ZhuangLiaoStep = 8;
  1864. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  1865. }
  1866. break;
  1867. case 8:
  1868. if(!CTHL_HSLiao_Limit_IN) //
  1869. {
  1870. CTHL_ZhuangLiaoStep = 9;
  1871. //CTHL_TLiaoStep = 1; //推拉头
  1872. CTHL_ZhuangLiaoDelay = dwTickCount +CTHL_PARAM_CheckLT_DELAY; //也是给下模能上升的时间
  1873. }
  1874. else if (CTHL_LTou_Check) //时间内信号这说明没有拉头
  1875. {
  1876. //重送3次
  1877. CTHL_TryCnt++;
  1878. CTHL_JLTou_VAVLE = 0; //接拉头关
  1879. CTHL_MGuo_VAVLE = 0; //码勾打开
  1880. CTHL_GDLT_VAVLE = 1;
  1881. if(CTHL_TryCnt == 1)//重新横送一次
  1882. {
  1883. CTHL_ZhuangLiaoStep = 21; //重新送3次
  1884. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  1885. }
  1886. else if(CTHL_TryCnt == 2||CTHL_TryCnt == 3)//重新装料2次
  1887. {
  1888. CTHL_ZhuangLiaoStep = 20; //重新送3次
  1889. CTHL_ZhuangLiaoDelay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  1890. }
  1891. else if(CTHL_TryCnt == 4)
  1892. {
  1893. CTHL_TryCnt=0;
  1894. bZhuangLiaoOkFlg = 0;
  1895. CTHL_ZhuangLiaoStep = 0;
  1896. CTHL_wltzi=1;
  1897. user_datas[127]=5;
  1898. CTHL_SetAlarmCode(CTHL_ZLT_ALARM,bRunning);
  1899. }
  1900. }
  1901. else if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1902. {
  1903. CTHL_wltzi=1;
  1904. CTHL_SetAlarmCode(CTHL_HSLiao_Limit_ALARM,bRunning);
  1905. if(bRunning)
  1906. {
  1907. CTHL_ZhuangLiaoStep = 0 ;
  1908. }
  1909. }
  1910. break;
  1911. case 9:
  1912. if(CTHL_LTou_Check) //时间内信号这说明没有拉头
  1913. {
  1914. CTHL_TryCnt++;
  1915. CTHL_JLTou_VAVLE = 0; //接拉头关
  1916. CTHL_MGuo_VAVLE = 0; //码勾打开
  1917. CTHL_GDLT_VAVLE = 1;
  1918. if(CTHL_TryCnt == 1)//重新横送一次
  1919. {
  1920. CTHL_ZhuangLiaoStep = 21; //重新送3次
  1921. CTHL_ZhuangLiaoDelay = dwTickCount + QDCT_VAVLE_ERROR_TIME;
  1922. }
  1923. else if(CTHL_TryCnt == 2||CTHL_TryCnt == 3)//重新装料2次
  1924. {
  1925. CTHL_ZhuangLiaoStep = 20; //重新送3次
  1926. CTHL_ZhuangLiaoDelay = dwTickCount + QDCT_VAVLE_ERROR_TIME;
  1927. }
  1928. else if(CTHL_TryCnt == 4)
  1929. {
  1930. CTHL_TryCnt=0;
  1931. bZhuangLiaoOkFlg = 0;
  1932. CTHL_ZhuangLiaoStep = 0;
  1933. CTHL_wltzi=1;
  1934. user_datas[127]=5;
  1935. CTHL_SetAlarmCode(CTHL_ZLT_ALARM,bRunning);
  1936. }
  1937. }
  1938. else if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1939. {
  1940. bZhuangLiaoOkFlg = 1;
  1941. if(CTHL_TLiaoStep==0)CTHL_TLiaoStep = 1; //推拉头
  1942. CTHL_ZhuangLiaoStep = 0;
  1943. }
  1944. break;
  1945. //装拉头2次
  1946. case 20:
  1947. if(CTHL_HSLiao_Origin_IN)
  1948. {
  1949. CTHL_JLTou_VAVLE = 0; //接拉头关
  1950. CTHL_MGuo_VAVLE = 0; //码勾打开
  1951. CTHL_GDLT_VAVLE = 1;
  1952. CTHL_ZhuangLiaoStep = 1;
  1953. CTHL_ZhuangLiaoDelay = dwTickCount + 10;
  1954. }
  1955. else if(dwTickCount >=CTHL_ZhuangLiaoDelay)
  1956. {
  1957. CTHL_wltzi=1;
  1958. CTHL_SetAlarmCode(CTHL_HSLiao_Origin_ALARM,bRunning);
  1959. }
  1960. break;
  1961. case 21: //重新横送一次
  1962. if(CTHL_HSLiao_Origin_IN)
  1963. {
  1964. CTHL_JLTou_VAVLE = 0; //接拉头关
  1965. CTHL_MGuo_VAVLE = 0; //码勾打开
  1966. CTHL_GDLT_VAVLE = 1;
  1967. CTHL_ZhuangLiaoStep = 2;
  1968. CTHL_ZhuangLiaoDelay = dwTickCount + 10;
  1969. }
  1970. else if(dwTickCount >=CTHL_ZhuangLiaoDelay)
  1971. {
  1972. CTHL_wltzi=1;
  1973. CTHL_SetAlarmCode(CTHL_HSLiao_Origin_ALARM,bRunning);
  1974. }
  1975. break;
  1976. case 30:
  1977. CTHL_HSLiao_VAVLE=0;
  1978. CTHL_ZhuangLiaoStep = 31;
  1979. CTHL_ZhuangLiaoDelay = dwTickCount + 200;
  1980. break;
  1981. case 31:
  1982. if(dwTickCount >=CTHL_ZhuangLiaoDelay)
  1983. {
  1984. CTHL_HSLiao_VAVLE=1;
  1985. CTHL_ZhuangLiaoStep = 32;
  1986. CTHL_ZhuangLiaoDelay = dwTickCount + 3000;
  1987. }
  1988. break;
  1989. case 32:
  1990. if(CTHL_HSLiao_Limit_IN && !CTHL_HSLiao_Origin_IN)
  1991. {
  1992. CTHL_ZhuangLiaoStep = 4;
  1993. CTHL_ZhuangLiaoDelay = dwTickCount + 10;
  1994. }
  1995. else if(dwTickCount >= CTHL_ZhuangLiaoDelay)
  1996. {
  1997. CTHL_wltzi=1;
  1998. CTHL_SetAlarmCode(CTHL_HSLiao_Limit_ALARM,bRunning);
  1999. CTHL_ZhuangLiaoStep = 0;
  2000. CTHL_HSLiao_VAVLE = 0;
  2001. }
  2002. }
  2003. }
  2004. void CTHL_TLiao_Step(void)
  2005. {
  2006. switch(CTHL_TLiaoStep)
  2007. {
  2008. case 1:
  2009. if(bTuiLaTouOkFlg)
  2010. {
  2011. CTHL_TLiaoStep = 0;
  2012. }
  2013. else
  2014. {
  2015. CTHL_TLiao_Delay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  2016. CTHL_TLiaoStep = 2;
  2017. }
  2018. break;
  2019. case 2: //横送料在原位
  2020. if(CTHL_HSLiao_Origin_IN && !CTHL_HSLiao_Limit_IN && !CTHL_HSLiao_VAVLE)
  2021. {
  2022. CTHL_TLiao_VAVLE = 1; //推料(推拉头)输出
  2023. CTHL_TLiao_Delay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  2024. CTHL_TLiaoStep = 3;
  2025. }
  2026. else if(dwTickCount >= CTHL_TLiao_Delay)
  2027. {
  2028. CTHL_wltzi=1;
  2029. CTHL_SetAlarmCode(CTHL_HSLiao_Origin_ALARM,1);
  2030. }
  2031. break;
  2032. case 3: //推拉头到位
  2033. if(CTHL_TLiao_Limit_IN)
  2034. {
  2035. CTHL_TLiao_Delay = dwTickCount + CTHL_PARAM_TLiao_BACKDELAY;
  2036. CTHL_TLiaoStep = 4;
  2037. }
  2038. else if(dwTickCount >= CTHL_TLiao_Delay)
  2039. {
  2040. CTHL_wltzi=1;
  2041. CTHL_SetAlarmCode(CTHL_TLiao_Limit_ALARM,1);
  2042. }
  2043. break;
  2044. case 4:
  2045. if(dwTickCount >= CTHL_TLiao_Delay)
  2046. {
  2047. CTHL_TLiao_VAVLE = 0;
  2048. CTHL_TLiao_Delay = dwTickCount + CTHL_VAVLE_ERROR_TIME;
  2049. CTHL_TLiaoStep = 5;
  2050. }
  2051. break;
  2052. case 5:
  2053. if(!CTHL_TLiao_Limit_IN)
  2054. {
  2055. CTHL_TLiaoStep = 0;
  2056. CTHL_TLiao_Delay = dwTickCount;
  2057. bTuiLaTouOkFlg = 1;
  2058. }
  2059. else if(dwTickCount >= CTHL_TLiao_Delay)
  2060. {
  2061. CTHL_wltzi=1;
  2062. CTHL_SetAlarmCode(CTHL_TLiao_Limit_ALARM,0);
  2063. }
  2064. break;
  2065. }
  2066. }
  2067. //振动盘控制
  2068. void CTHL_ZhenDongAction(void)
  2069. {
  2070. #if 0
  2071. // if(bRunning)
  2072. // {
  2073. if(!CTHL_PARAM_ZDP_AUTO)
  2074. {
  2075. if(CTHL_ZhenDongPian_OUT == 0)
  2076. {
  2077. if(!CTHL_ZDP_IN)
  2078. {
  2079. if(dwTickCount >= CTHL_ZDP_Delay)
  2080. {
  2081. CTHL_ZhenDongPian_OUT = 1;
  2082. CTHL_ZDP_Delay = dwTickCount + CTHL_PARAM_ZDP_Stop_TIME;//CTHL_PARAM_ZDP_Stop_TIME + 50;
  2083. }
  2084. }
  2085. else
  2086. {
  2087. CTHL_ZDP_Delay = dwTickCount + CTHL_PARAM_ZDP_Start_TIME;//CTHL_PARAM_ZDP_Start_TIME;
  2088. }
  2089. }
  2090. else
  2091. {
  2092. if(CTHL_ZDP_IN)
  2093. {
  2094. if(dwTickCount >= CTHL_ZDP_Delay)
  2095. {
  2096. CTHL_ZhenDongPian_OUT = 0;
  2097. CTHL_ZDP_Delay = dwTickCount + CTHL_PARAM_ZDP_Start_TIME;//CTHL_PARAM_ZDP_Start_TIME
  2098. }
  2099. }
  2100. else
  2101. CTHL_ZDP_Delay = dwTickCount + CTHL_PARAM_ZDP_Stop_TIME;//CTHL_PARAM_ZDP_Stop_TIME+ 50;
  2102. }
  2103. }
  2104. else if (CTHL_PARAM_ZDP_AUTO ==1 )
  2105. {
  2106. CTHL_ZhenDongPian_OUT=0;
  2107. CTHL_ZDP_Delay = dwTickCount + 0;
  2108. }
  2109. else if(CTHL_PARAM_ZDP_AUTO == 2)
  2110. {
  2111. CTHL_ZhenDongPian_OUT=1;
  2112. CTHL_ZDP_Delay = dwTickCount + 0;
  2113. }
  2114. #endif
  2115. }
  2116. unsigned char Manu_HSL_STEP;
  2117. unsigned long Manu_HSL_DELAY;
  2118. void CTHL_Manu_HSongLiao(void)
  2119. {
  2120. switch(Manu_HSL_STEP)
  2121. {
  2122. case 1:
  2123. if(dwTickCount>=Manu_HSL_DELAY)
  2124. {
  2125. CTHL_MGuo_VAVLE=1;
  2126. Manu_HSL_STEP=2;
  2127. Manu_HSL_DELAY=dwTickCount+1000;
  2128. }
  2129. break;
  2130. case 2:
  2131. if(CTHL_MGuo_VAVLE&&CTHL_LTou_Check)//无拉头
  2132. {
  2133. CTHL_GDLT_VAVLE=1;
  2134. CTHL_MGuo_VAVLE=0;
  2135. Manu_HSL_DELAY=dwTickCount+CTHL_VAVLE_ERROR_TIME;
  2136. Manu_HSL_STEP=3;
  2137. }
  2138. else if(dwTickCount>=Manu_HSL_DELAY)
  2139. {
  2140. Manu_HSL_STEP=0;
  2141. CTHL_SetAlarmCode(CTHL_YLT_CHECK_ALARM,0);//夹拉头异常
  2142. }
  2143. break;
  2144. case 3:
  2145. if(CTHL_CTM_Origin_IN &&!CTHL_TLiao_Limit_IN)//下模在原位
  2146. {
  2147. CTHL_HSLiao_VAVLE = 1;
  2148. Manu_HSL_STEP=0;
  2149. }
  2150. else if(dwTickCount>=Manu_HSL_DELAY)
  2151. {
  2152. Manu_HSL_STEP=0;
  2153. if(!CTHL_CTM_Origin_IN)CTHL_SetAlarmCode(CTHL_CTM_Origin_ALARM,0);
  2154. if(CTHL_TLiao_Limit_IN)CTHL_SetAlarmCode(CTHL_TLiao_Limit_ALARM,0);
  2155. }
  2156. break;
  2157. }
  2158. }
  2159. //手动动作
  2160. void CTHL_ManualAction(void)
  2161. {
  2162. if(CTHL_bBaoJin) //报警清除加松轴
  2163. {
  2164. CTHL_bBaoJin=0;
  2165. SetEn(Y_AXIS, MOTOR_EN);
  2166. SetEn(X_AXIS, MOTOR_EN);
  2167. SetAlarmCode(CTHL_ALARM_ADDR,0);
  2168. if((GetAlarm(X_AXIS)==1 || GetAlarm(Y_AXIS)==1) && !CTHL_PARAM_DBSF_MODE)
  2169. {
  2170. SetClr(X_AXIS, MOTOR_NOALARM);
  2171. SetClr(Y_AXIS, MOTOR_NOALARM);
  2172. CTHL_bSFBBAOJIN_Delay= dwTickCount + 500;
  2173. }
  2174. if(CTHL_PARAM_DBSF_MODE)
  2175. {
  2176. if(!CTHL_SF_ALR_IN)
  2177. {
  2178. CTHL_SF_ALR_CLR=1;
  2179. CTHL_bSFBBAOJIN_Delay= dwTickCount + 500;
  2180. }
  2181. }
  2182. }
  2183. if(bRunning == 0)
  2184. {
  2185. CTHL_Manu_HSongLiao();
  2186. if(bClearTotal) //切断计数清零
  2187. {
  2188. bClearTotal = 0;
  2189. ClrcToTal(QDCT_TOTAL_ADDR);
  2190. }
  2191. if(CTHL_bHSL) //手动横送料
  2192. {
  2193. CTHL_bHSL= 0;
  2194. if(CTHL_HSLiao_VAVLE)CTHL_HSLiao_VAVLE = 0;//~XY_CTHL_HSLiao_VAVLE;
  2195. else
  2196. {
  2197. CTHL_CTXM_VAVLE=0;
  2198. CTHL_TLiao_VAVLE=0;
  2199. CTHL_JLTou_VAVLE=0;
  2200. CTHL_GDLT_VAVLE=0;
  2201. if(Manu_HSL_STEP==0)Manu_HSL_STEP=1;
  2202. Manu_HSL_DELAY=dwTickCount+20;
  2203. }
  2204. }
  2205. if(CTHL_bTLiao ) //手动推料(推拉头)
  2206. {
  2207. CTHL_bTLiao = 0;
  2208. if(CTHL_TLiao_VAVLE)CTHL_TLiao_VAVLE = 0;
  2209. else if(!CTHL_HSLiao_VAVLE && CTHL_HSLiao_Origin_IN)CTHL_TLiao_VAVLE = 1;
  2210. else CTHL_SetAlarmCode(CTHL_HSLiao_Origin_ALARM,0); // 横送料不能输出//条件警告
  2211. }
  2212. if(CTHL_bJLT)//接拉头
  2213. {
  2214. CTHL_bJLT = 0;
  2215. if(CTHL_JLTou_VAVLE)CTHL_JLTou_VAVLE = 0;
  2216. else if( !CTHL_CTXM_VAVLE && CTHL_CTM_Origin_IN)
  2217. {
  2218. CTHL_MGuo_VAVLE = 0;
  2219. CTHL_JLTou_VAVLE = 1;
  2220. }
  2221. else//条件警告
  2222. {
  2223. CTHL_SetAlarmCode(CTHL_CTM_Origin_ALARM,0);
  2224. }
  2225. }
  2226. if(CTHL_bMG) //码勾
  2227. {
  2228. CTHL_bMG = 0;
  2229. CTHL_MGuo_VAVLE = !CTHL_MGuo_VAVLE;
  2230. }
  2231. if(CTHL_bGDLT)//夹拉头
  2232. {
  2233. CTHL_bGDLT = 0;
  2234. if(!CTHL_GDLT_VAVLE)CTHL_MGuo_VAVLE = 0;
  2235. CTHL_GDLT_VAVLE = !CTHL_GDLT_VAVLE;
  2236. }
  2237. if(CTHL_bJXM) //夹前码
  2238. {
  2239. CTHL_bJXM = 0;
  2240. CTHL_JXM_VAVLE = !CTHL_JXM_VAVLE;
  2241. }
  2242. if(CTHL_bTXM) //推斜码
  2243. {
  2244. CTHL_bTXM = 0;
  2245. if((CTHL_JXM_VAVLE || !CTHL_CTXM_VAVLE) && !CTHL_TXM_VAVLE && !CTHL_TFK_VAVLE)
  2246. {
  2247. CTHL_TXM_VAVLE=1;
  2248. }
  2249. else if(CTHL_TXM_VAVLE)
  2250. {
  2251. CTHL_TXM_VAVLE=0;
  2252. }
  2253. else
  2254. CTHL_SetAlarmCode(CTHL_JXM_Limit_ALARM,0); //夹前码要输出
  2255. }
  2256. if(CTHL_bQMDW) //前码定位
  2257. {
  2258. CTHL_bQMDW = 0;
  2259. CTHL_QMDW_VAVLE = !CTHL_QMDW_VAVLE;
  2260. }
  2261. if(CTHL_bTFK) //推方块
  2262. {
  2263. CTHL_bTFK = 0;
  2264. if(!CTHL_TFK_VAVLE && !CTHL_TXM_VAVLE)
  2265. CTHL_TFK_VAVLE = 1;
  2266. else if(CTHL_TFK_VAVLE)
  2267. CTHL_TFK_VAVLE = 0;
  2268. }
  2269. if(CTHL_bFKDW) //方块检测
  2270. {
  2271. CTHL_bFKDW = 0;
  2272. //CTHL_FKDW_VAVLE = !CTHL_FKDW_VAVLE;
  2273. }
  2274. if(CTHL_bHL) //合链
  2275. {
  2276. CTHL_bHL = 0;
  2277. CTHL_HL_VAVLE = !CTHL_HL_VAVLE;
  2278. }
  2279. if(CTHL_bYFK) //压方块
  2280. {
  2281. CTHL_bYFK = 0;
  2282. CTHL_YFK_VAVLE = !CTHL_YFK_VAVLE;
  2283. }
  2284. if(CTHL_bYCX) //压小插
  2285. {
  2286. CTHL_bYCX = 0;
  2287. CTHL_YXC_VAVLE = !CTHL_YXC_VAVLE;
  2288. }
  2289. if(CTHL_bXCDW) //插销定位
  2290. {
  2291. CTHL_bXCDW = 0;
  2292. CTHL_XCDW_VAVLE = !CTHL_XCDW_VAVLE;
  2293. }
  2294. if(CTHL_bXCBI) //小插摆臂
  2295. {
  2296. SetEn(X_AXIS, MOTOR_EN);
  2297. SetEn(Y_AXIS, MOTOR_EN);
  2298. CTHL_bXCBI = 0;
  2299. CTHL_JCBI_VAVLE = !CTHL_JCBI_VAVLE;
  2300. }
  2301. if(CTHL_bCXDD) //小插摆臂
  2302. {
  2303. CTHL_bCXDD = 0;
  2304. CTHL_DingDai_VAVLE = !CTHL_DingDai_VAVLE;
  2305. }
  2306. if(CTHL_bCTXM) //下模
  2307. {
  2308. CTHL_bCTXM = 0;
  2309. CTHL_TXM_VAVLE=0;
  2310. if(CTHL_CTXM_VAVLE)
  2311. {
  2312. CTHL_CTXM_VAVLE = 0;
  2313. CTHL_JLTou_VAVLE = 0;
  2314. CTHL_JXM_VAVLE=0;
  2315. }
  2316. else if(!CTHL_HSLiao_VAVLE && CTHL_HSLiao_Origin_IN && (CTHL_JXM_VAVLE || !CTHL_TXM_VAVLE))
  2317. {
  2318. CTHL_CTXM_VAVLE = 1;
  2319. CTHL_JLTou_VAVLE=0;
  2320. CTHL_JXM_VAVLE=1;
  2321. }
  2322. }
  2323. //自动装料
  2324. if(CTHL_bAutoZhuangLiao)
  2325. {
  2326. CTHL_bAutoZhuangLiao = 0;
  2327. if(CTHL_ZhuangLiaoStep == 0)
  2328. {
  2329. bTuiLaTouOkFlg = 1;
  2330. bZhuangLiaoOkFlg = 0;
  2331. CTHL_ZhuangLiaoStep = 1;
  2332. CTHL_MGuo_VAVLE = 1; //判断是否已经有料
  2333. CTHL_GDLT_VAVLE=0;
  2334. CTHL_TryCnt = 0;
  2335. CTHL_ZhuangLiaoDelay = dwTickCount + 500;
  2336. }
  2337. }
  2338. if(CTHL_bYJDW) //一键定位
  2339. {
  2340. CTHL_bYJDW=0;
  2341. //CTHL_FKDW_VAVLE = 0;
  2342. CTHL_YFK_VAVLE=0;
  2343. CTHL_YXC_VAVLE=0;
  2344. CTHL_HL_VAVLE=0;
  2345. CTHL_CTXM_VAVLE=0;
  2346. CTHL_TXM_VAVLE=0;
  2347. CTHL_JCBI_VAVLE=0;
  2348. CTHL_QMDW_VAVLE=0;
  2349. CTHL_TD_MotorDelay = dwTickCount + 100;
  2350. if(CTHL_TD_MotorStep==0)
  2351. {
  2352. CTHL_CTXM_VAVLE =0;
  2353. if(GetEn(X_AXIS) == MOTOR_EN)
  2354. {
  2355. SetEn(X_AXIS, MOTOR_DISEN);
  2356. SetEn(Y_AXIS, MOTOR_DISEN);
  2357. CTHL_TD_MotorDelay = dwTickCount + 200;
  2358. }
  2359. else
  2360. CTHL_TD_MotorDelay = dwTickCount + 100;
  2361. CTHL_TD_MotorStep=1;
  2362. }
  2363. }
  2364. //X轴Y轴电机测试
  2365. if(CTHL_bCLMotor_P)
  2366. {
  2367. SetEn(Y_AXIS, MOTOR_DISEN);
  2368. SetEn(X_AXIS, MOTOR_DISEN);
  2369. //CTHL_FKDW_VAVLE=0;
  2370. if(CTHL_FK_Check_UP)
  2371. {
  2372. SetPos(X_AXIS, 0);
  2373. SetPos(Y_AXIS, 0);
  2374. }
  2375. if(!X_DRV)
  2376. {
  2377. // Y轴 运行速度 启动速度 加速度 减速度
  2378. AxisContinueMoveAcc(X_AXIS,600 ,DIR_P,600,600,15,15);
  2379. AxisContinueMoveAcc(Y_AXIS,580,DIR_P,580,580,15,15);
  2380. }
  2381. }
  2382. //在压方块电磁阀输出情况下,方块感应后电机要自动停止
  2383. if(CTHL_FKGY_IN && CTHL_YFK_VAVLE && CTHL_bCLMotor_P)
  2384. {
  2385. CTHL_bCLMotor_P=0;
  2386. AxisEgmStop(Y_AXIS);
  2387. AxisEgmStop(X_AXIS);
  2388. }
  2389. if(CTHL_bCLMotor_N) //后退限位已经取消
  2390. {
  2391. SetEn(Y_AXIS, MOTOR_DISEN);
  2392. SetEn(X_AXIS, MOTOR_DISEN);
  2393. //CTHL_FKDW_VAVLE=0;
  2394. if(CTHL_FK_Check_UP)
  2395. {
  2396. SetPos(X_AXIS, 0);
  2397. SetPos(Y_AXIS, 0);
  2398. }
  2399. //压方块电磁阀没有输出时,方块感应信号不限制
  2400. if(!CTHL_FKGY_IN || !CTHL_YFK_VAVLE)
  2401. {
  2402. if(!X_DRV && (!CTHL_QMDW_IN ||!CTHL_QMDW_VAVLE))
  2403. {
  2404. // Y轴 运行速度 启动速度 加速度 减速度
  2405. AxisContinueMoveAcc(Y_AXIS,630,DIR_N,630,630,15,15);
  2406. AxisContinueMoveAcc(X_AXIS,600,DIR_N,600,600,15,15);
  2407. }
  2408. if(CTHL_FKGY_IN && CTHL_YFK_VAVLE)
  2409. {
  2410. CTHL_bCLMotor_P=0;
  2411. AxisEgmStop(Y_AXIS);
  2412. AxisEgmStop(X_AXIS);
  2413. }
  2414. }
  2415. if(CTHL_QMDW_IN && CTHL_QMDW_VAVLE)
  2416. {
  2417. AxisEgmStop(Y_AXIS);
  2418. AxisEgmStop(X_AXIS);
  2419. }
  2420. }
  2421. if(!CTHL_bCLMotor_P && !CTHL_bCLMotor_N && (CTHL_TD_MotorStep == 0))
  2422. {
  2423. AxisEgmStop(Y_AXIS);
  2424. AxisEgmStop(X_AXIS);
  2425. }
  2426. }
  2427. }
  2428. #endif