找回密码
 立即注册

QQ登录

只需一步,快速开始

微信扫码登录

搜索
查看: 109|回复: 1

[原创] 手把手教你制作UG四五轴宏联动后处理(二十)

[复制链接]

44

主题

136

回帖

1606

积分

六级士官

积分
1606
发表于 20 小时前 | 显示全部楼层 |阅读模式
  (16).将PB_CMD_detect_tool_path_type行复制到"第一次移动"事件下。
  (17).在"初始移动"事件下的PB_CMD_detect_tool_path_type行下面添加定制命令,
       输入名称PB_CMD_calc_g54,编辑TCL代码如下:
       global dpp_path_type
       global mom_out_angle_pos
       global va vc
       global sa sc
       if {![string compare "3X" $dpp_path_type]} {
         if { $mom_out_angle_pos(0) !=0 } {
           MOM_output_literal "(刀路: 定轴)"
           #****************获取第四轴A旋转角度******************
           set va [expr round($mom_out_angle_pos(0)*10000.0)/10000.0]
           set sa [format "%.4f" $va]
           if {[string index $sa end-0] == "0"} {
             if {[string index $sa end-1] == "0"} {
               if {[string index $sa end-2] == "0"} {
                 if {[string index $sa end-3] == "0"} {
                   set sa [format "%d." [expr round($va)]]
                 } else {
                     set sa [format "%.1f" $va)]
                   }
               } else {
                   set sa [format "%.2f" $va]
                 }
             } else {
                 set sa [format "%.3f" $va]
               }
           }
           #*******************计算3+1定轴加工原点G54***********************
           MOM_output_literal "#130=$sa"
           MOM_output_literal "#24=#5261"
           MOM_output_literal "#25=#102*COS\[#130\]+#103*SIN\[#130\]+#5242"
           MOM_output_literal "#26=-#102*SIN\[#130\]+#103*COS\[#130\]+#5243"
           MOM_output_literal "G90 G10 L2 P1 X\[#24\] Y\[#25\] Z\[#26\]"
        } else {
            MOM_output_literal "(刀路: 三轴)"
            #************计算三轴加工原点G54*********************************
            MOM_output_literal "#130=0."
            MOM_output_literal "#24=#5261"
            MOM_output_literal "#25=#102*COS\[#130\]+#103*SIN\[#130\]+#5242"
            MOM_output_literal "#26=-#102*SIN\[#130\]+#103*COS\[#130\]+#5243"
            MOM_output_literal "G90 G10 L2 P1 X\[#24\] Y\[#25\] Z\[#26\]"
          }
     } elseif {![string compare "5X" $dpp_path_type]} {
         MOM_output_literal "(刀路: 四轴联动)"
         #********计算联动加工原点G54,让加工原点G54与编程原点G56重合*********
         MOM_output_literal "#130=0."
         MOM_output_literal "#24=#5261"
         MOM_output_literal "#25=#102*COS\[#130\]+#103*SIN\[#130\]+#5242"
         MOM_output_literal "#26=-#102*SIN\[#130\]+#103*COS\[#130\]+#5243"
         MOM_output_literal "G90 G10 L2 P1 X\[#24\] Y\[#25\] Z\[#26\]"
      }
      点击确定。
  (18).将PB_CMD_calc_g54行复制到"第一次移动"事件下的PB_CMD_detect_tool_path_type行下面。
  (19).在"初始移动"事件下的PB_CMD_calc_g54行下面添加G0 G90 G(54~59) X Y A S M3行,
       添加输出条件PB__CMD_check_block_initial_move,编辑TCL代码如下:
       global dpp_path_type
       if {![string compare "3X" $dpp_path_type]} {
          return 1
       }
       return 0
       点击确定。
  (20).将"初始移动"事件下的G0 G90 G(54~59) X Y A S M3行复制到"第一次移动"事件下的PB_CMD_calc_g54行下面。
  (21).在"初始移动"事件下的G0 G90 G(54~59) X Y A S M3行下面添加G0 G90 G(54~59) 文本元素1 文本元素2 A S M3行,
       将文本元素1内容改成X$sx,将文本元素2内容改成Y$sy,
       添加输出条件PB__CMD_check_block_initial_move_1,编辑TCL代码如下:
global dpp_path_type
global e1 e2 e3  d1 d2  vx vy vz  rad_a
global wi w2 w4  s  s1 s2  s4  sx sy sz
global mom_out_angle_pos  mom_pos
if {![string compare "4X" $dpp_path_type]} {
  set rad_a [expr $mom_out_angle_pos(0)*0.01745329252]
  #******************计算Xrtcp********************
  set vx [expr round($mom_pos(0)*10000.0)/10000.0]
  set w4 [format "%.4f" $vx]
  if {[string index $w4 end-0] == "0"} {
    if {[string index $w4 end-1] == "0"} {
      if {[string index $w4 end-2] == "0"} {
        if {[string index $w4 end-3] == "0"} {
          set w4 [format "%d." [expr round($vx)]]
        } else {
            set w4 [format "%.1f" $vx]
          }
      } else {
          set w4 [format "%.2f" $vx]
        }
    } else {
        set w4 [format "%.3f" $vx]
      }
  }
  set sx $w4
  #*****************计算Yrtcp******************
  set e1 [expr cos($rad_a)-1.0]
  set e2 [expr sin($rad_a)]
  set d1 [expr round($e1*1000000.0)/1000000.0]
  set d2 [expr round($e2*1000000.0)/1000000.0]
  set vy [expr round($mom_pos(1)*10000.0)/10000.0]
  set w1 [format "%.6f" $d1]
  if {![string compare "-1.000000" $w1]} {
    set s1 "-#102"
  } elseif {![string compare "1.000000" $w1]} {
      set s1 "#102"
    } else {
        if {[string index $w1 end-0] == "0"} {
          if {[string index $w1 end-1] == "0"} {
            if {[string index $w1 end-2] == "0"} {
              if {[string index $w1 end-3] == "0"} {
                if {[string index $w1 end-4] == "0"} {
                  if {[string index $w1 end-5] == "0"} {
                     set w1 [format "%d." [expr round($d1)]]
                   } else {
                       set w1 [format "%.1f" $d1]
                     }
                 } else {
                     set w1 [format "%.2f" $d1]
                   }
               } else {
                   set w1 [format "%.3f" $d1]
                 }
             } else {
                 set w1 [format "%.4f" $d1]
               }
           } else {
               set w1 [format "%.5f" $d1]
             }
        }
        if {$d1 != 0.0} {
          set s1 [format "%s*#102" $w1]
        } else {
            set s1 "NONE"
          }
      }
  set w2 [format "%.6f" $d2]
  if {![string compare "-1.000000" $w2]} {
    set s2 "-#103"
  } elseif {![string compare "1.000000" $w2]} {
      set s2 "+#103"
    } else {
        if {[string index $w2 end-0] == "0"} {
          if {[string index $w2 end-1] == "0"} {
            if {[string index $w2 end-2] == "0"} {
               if {[string index $w2 end-3] == "0"} {
                 if {[string index $w2 end-4] == "0"} {
                   if {[string index $w2 end-5] == "0"} {
                     set w2 [format "%d." [expr round($d2)]]
                   } else {
                       set w2 [format "%.1f" $d2]
                     }
                 } else {
                     set w2 [format "%.2f" $d2]
                   }
               } else {
                   set w2 [format "%.3f" $d2]
                 }
             } else {
                 set w2 [format "%.4f" $d2]
               }
           } else {
               set w2 [format "%.5f" $d2]
             }
        }
        if {$d2 > 0.0} {
          set s2 [format "+%s*#103" $w2]
        } elseif {$d2 < 0.0} {
            set s2 [format "%s*#103" $w2]
          } else {
              set s2 "NONE"
            }
      }
  set w4 [format "%.4f" $vy]
  if {[string index $w4 end-0] == "0"} {
    if {[string index $w4 end-1] == "0"} {
      if {[string index $w4 end-2] == "0"} {
        if {[string index $w4 end-3] == "0"} {
          set w4 [format "%d." [expr round($vy)]]
        } else {
            set w4 [format "%.1f" $vy]
          }
      } else {
          set w4 [format "%.2f" $vy]
        }
    } else {
        set w4 [format "%.3f" $vy]
      }
  }
  if {$vy > 0.0} {
    set s4 [format "+%s" $w4]
  } elseif {$vy < 0.0} {
      set s4 [format "%s" $w4]
    } else {
        set s4 "NONE"
      }
  if {[string compare "NONE" $s1] && ![string compare "NONE" $s2]} {
    set s $s1
  } elseif {![string compare "NONE" $s1] && [string compare "NONE" $s2]} {
      set s $s2
    } elseif {[string compare "NONE" $s1] && [string compare "NONE" $s2]} {
        set s [format "%s%s" $s1 $s2]
      } else {
          set s "NONE"
        }
  if {[string compare "NONE" $s] && [string compare "NONE" $s4]} {
    set sy [format "\[%s%s\]" $s $s4]
  } elseif {![string compare "NONE" $s] && [string compare "NONE" $s4]} {
      set sy $s4
    } elseif {[string compare "NONE" $s] && ![string compare "NONE" $s4]} {
        set sy [format "\[%s\]" $s]
      } else {
          set sy "0."
        }
未完待续。。。。

2

主题

152

回帖

1196

积分

六级士官

积分
1196
发表于 12 小时前 | 显示全部楼层
大神厉害最好出视频的
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

咨询QQ:1359218528|发帖须知!|Archiver|手机版|小黑屋|UG爱好者论坛 ( 京ICP备10217105号-2 )

GMT+8, 2026-1-5 22:46

Powered by Discuz! X3.5 Licensed

© 2001-2025 Discuz! Team.

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