Autocad下绘制直线对称中心线的方法 AutoCAD是目前国内应用最广范的CAD系统之一, AutoCAD功能强大,是一个通用 的CAD平台,但是如果不根据本专业的需要进行二次开发,使用起来是很不方便的。画对 称中心线是机械设计中经常遇到的一个问题。 笔者用 AutoLISP依据国家标准开发了两个程序,可以很方便地解决直线对称中心线的 问题 第一个程序适用于两条边是连续直线的情况。使用方法是:用LOAD命令装入 GLS LSP, 运行CGSL,依据屏幕提示,分别选择两边,自动绘制出中心线。 GSL LSP ( defun mid(ptl pt2)计算两点之中点的功能函数 ( setq pt(mapcar'+ptl pt2 ) (setq pt(mapcar/pt(222))) (defun c: gsl/m cll cl cl2 e pt ptl pt2 pt3 pt4 a) (SETQ M 1) (WHILE M ( SETQ CLI( ENTSEL"Ⅶ选择第一条直线") ( not cll)( prompt"hn没有发现实体") ((/="LINE"(cdr(assoc 0(setqe(entget(car clD))) ( prompt"n所选不是直线") t( prompt"找到了第一条直线”) ( setq m nil);退出循环 ( setq cl(sget(ntho( cdr cll);取得第一条直线的实体数据 (SETQM 1) (WHILE M ( SETQ CL2( ENTSEL"n选择第二条直线") (if cl2 (if (ssmemb(car cl2)cl ( princ"hn选择重复,重新选择") (setq cl2 nil) ( not cl2)( prompt"没有发现实体或重复") ((/="LINE"(edr(assoc 0(setq e(entget(car cl2))))) ( prompt"n所选不是直线")
AutoCAD 下绘制直线对称中心线的方法 AutoCAD 是目前国内应用最广范的 CAD 系统之一,AutoCAD 功能强大,是一个通用 的 CAD 平台,但是如果不根据本专业的需要进行二次开发,使用起来是很不方便的。画对 称中心线是机械设计中经常遇到的一个问题。 笔者用 AutoLISP 依据国家标准开发了两个程序,可以很方便地解决直线对称中心线的 问题。 第一个程序适用于两条边是连续直线的情况。使用方法是:用LOAD命令装入GLS.LSP, 运行 C:GSL,依据屏幕提示,分别选择两边,自动绘制出中心线。 GSL.LSP: (defun mid(pt1 pt2 ) 计算两点之中点的功能函数 (setq pt (mapcar'+pt1 pt2 )) (setq pt (mapcar'/pt'(2 2 2))) ) (defun c:gsl/m cl1 cl cl2 e pt pt1 pt2 pt3 pt4 a) (SETQ M 1) (WHILE M (SETQ CL1 (ENTSEL"\n 选择第一条直线 ")) (cond ((not cl1 ) (prompt"\n 没有发现实体")) ((/="LINE"(cdr (assoc 0 (setqe(entget (car cl1)))))) (prompt"\n 所选不是直线") ) (t (prompt"找到了第一条直线”) (setq m nil);退出循环 ) ) ) (setq cl (ssget (nth 0 (cdr cl1))));取得第一条直线的实体数据 (SETQ M 1) (WHILE M (SETQ CL2 (ENTSEL"\n 选择第二条直线")) (if cl2 (if (ssmemb (car cl2) cl ) (progn (princ"\n 选择重复,重新选择") (setq cl2 nil) ) ) ) (cond ((not cl2 ) (prompt"没有发现实体或重复")) ((/="LINE"(cdr (assoc 0 (setq e (entget (car cl2)))))) (prompt"\n 所选不是直线")
t( prompt"hn两条直线已经选择完毕") ( setq m nil);退出循环 :取得第一直线两端点的坐标 (setq ptl(edr(assoc 10 e ) pt2(edr(assoc ll e))) ( setae( entget( car cll)};取得第二条直线的实体数据 ;;:取得第二直线两端点的坐标 ( setq pt3(edr(assoc 10e ))pt4 (cdr(assoc 1l e))) ;调整端点 (if (inters ptl pt3 pt2 pt 4 t) (setq pt ptI ;;计算两端中点坐标 tq pt2 ( mid pt2 pt4 ) ( setq a( angle ptl pt2);计算中心线的倾角 ( setq pt2( polar pt2a25);计算中心线的第一个端点 (setq ptl (polar ptl(+pi a )2.5)) ( command" layer"SET"5");设置中心线层 ( command"line" pt l pt2");画出中心线 (princ"\nC: GSL has loaded") Princ"\n for symmetry line") (princ) 第二个程序适用于阶梯轴,阶梯孔等各种情况。使用方法是:用LOAD命令装入 GLS1.LSP,运行CGSL1,依据屏幕提示,分别选择两边的端点,自动绘制出中心线。 GSLI LSP ( defun mid(ptl pt2 (setq pt(mapcar '+ ptl pt2 )) (setq pt(mapcar/pt(2 22))) ( defun c: gsl/plpl p3 p4 a ;保存环境变量 (setq os(getvar"smode")) (setq cm(getvar"cmdecho")) ;设置环境变量 (setvar"smode"33) (setvar"cmdecho"0)
) (t (prompt"\n 两条直线已经选择完毕") (setq m nil);;;退出循环 ) ) ) ;;;取得第一直线两端点的坐标 (setq pt1 (cdr (assoc 10 e )) pt2 (cdr (assoc 11 e ))) (setq e (entget (car cl1)));;取得第二条直线的实体数据 ;;;取得第二直线两端点的坐标 (setq pt3 (cdr (assoc 10 e )) pt4 (cdr (assoc 11 e ))) ;;调整端点 (if (inters pt1 pt3 pt2 pt4 t) (setq pt pt1 pt1 pt2 pt2 pt ) ) ;;;计算两端中点坐标 (setq pt1 (mid pt1 pt3 )) (setq pt2 (mid pt2 pt4 )) (setq a (angle pt1 pt2));计算中心线的倾角 (setq pt2 (polar pt2 a 2.5));;计算中心线的第一个端点 (setq pt1 (polar pt1 (+pi a ) 2.5)) (command"layer""SET"5"");;设置中心线层 (command "line" pt1 pt2 "");;画出中心线 ) (princ "\nC:GSL has loaded") (Princ "\n for symmetry line") (princ) 第二个程序适用于阶梯轴,阶梯孔等各种情况。使用方法是:用 LOAD 命令装入 GLS1.LSP,运行 C:GSL1,依据屏幕提示,分别选择两边的端点,自动绘制出中心线。 GSL1.LSP (defun mid(pt1 pt2 ) (setq pt (mapcar '+ pt1 pt2 )) (setq pt (mapcar '/ pt '(2 2 2))) ) (defun c:gsl1(/ p1 p1 p3 p4 a ) ;;保存环境变量 (setq os (getvar "osmode")) (setq cm (getvar "cmdecho")) ;;设置环境变量 (setvar "osmode" 33) (setvar "cmdecho" 0)
;依次读取两条直线的端点 (initget ( setq pl( setpoint"hn选择第一条直线的第一个点") ( setq p2( setpoint"Ⅶn选择第一条直线的第二个点") ( setq p3( setpoint"Ⅶn选择第二条直线的第一个点") (initget 1) ( setq p4( setpoint"hn选择第二条直线的第二个点") 恢复环境变量 (setvar "smode"os) pl(mid pl p3 ) (setq p2(mid p2 p4 ) (setq a(angle pl p2) ( setq p2(polar p2 a 2.5)) (setq pl(polar pl ( pi a )2.5)) (command"layer""set"5") (command"line"pl p2") (princ"nC: GSLI has loaded") Princ"n for symmetry line Princ
;;依次读取两条直线的端点 (initget 1) (setq p1 (getpoint"\n 选择第一条直线的第一个点")) (initget 1) (setq p2 (getpoint"\n 选择第一条直线的第二个点")) (initget 1) (setq p3 (getpoint"\n 选择第二条直线的第一个点")) (initget 1) (setq p4 (getpoint"\n 选择第二条直线的第二个点")) ;;;;恢复环境变量 (setvar "osmode" os) (setq p1 (mid p1 p3 )) (setq p2 (mid p2 p4 )) (setq a (angle p1 p2)) (setq p2 (polar p2 a 2.5)) (setq p1 (polar p1 (+ pi a ) 2.5)) (command "layer" "set" 5 "") (command "line" p1 p2 "") ) (princ "\nC:GSL1 has loaded") (Princ "\n for symmetry line") Princ