Cad_Cae 板


LINE

以下的 AUTOCAD AUTOLISP 程式, 可以自动的做出 三度空间的 一组歪斜线的 公垂线。 这条公垂线的 3D长度,就是这组歪斜线的 最短距离。 使用的方法是,将以下的程式, 存成一个文字档案, FILE NAME: LSQ.LSP 在 AUTOCAD 指令列输入 (LOAD "LSQ.LSP") 就可以帮 AUTOCAD 增加一个指令 LSQ 执行这个指令,点选这组歪斜线的两条线, 即会 自动的做出 公垂线 ; FILE BEGIN HERE ; LSQ.LSP - "LINE SKEW" Connects SKEW lines with the shortest connector ; From original code (c)1992, Mitchell A. Wawzonek ; Mitchell A. Wawzonek, P.Eng., Professor ; School of Engineering Technology ; Conestoga College ; 299 Doon Valley Drive ; Kitchener, ON N2G 4M4 ; Canada ; ; FINDS THE COMMON PERPENDICULAR ; BETWEEN 2 SKEW LINES ; ; 5-26-06 Added error handling and useability in any UCS. ; Also declared local variables. ; (defun lsq_error (msg) (setq *error* sys_error) (command "UCS" "R" "SYSUCS") (command "UCS" "D" "SYSUCS") (setvar "OSMODE" OLDSNAP) (setvar "CMDECHO" 1) (redraw) (princ) ) (defun C:LSQ (/ E1 E2 P1 P2 P3 P4 X1 X2 X3 X4 Y1 Y2 Y3 Y4 Z1 Z2 Z3 Z4 A D B C F CA SA ANG R1 R P5 P6 DS ) (setq sys_error *error*) (setq *error* lsq_error) (setvar "CMDECHO" 0) (setq OLDSNAP (getvar "OSMODE")) (setvar "OSMODE" 0) (command "UCS" "S" "SYSUCS") (command "UCS" "") (setq E1 nil E2 nil) (while (null E1) (setq E1 (entsel "\nLine 1:")) (if E1 (progn (setq E1 (car E1)) (redraw E1 3) (if (/= (cdr (assoc 0 (entget E1))) "LINE") (progn (prompt "\nEntity is a ") (princ (cdr (assoc 0 (entget E1)))) (princ ". Select a LINE") (setq E1 nil) ) ) ) ) ) ;endwhile (while (null E2) (setq E2 (entsel "\nLine 2:")) (if E2 (progn (setq E2 (car E2)) (if (/= (cdr (assoc 0 (entget E2))) "LINE") (progn (prompt "\nEntity is a ") (princ (cdr (assoc 0 (entget E2)))) (princ ". Select a LINE") (setq E2 nil) ) ) ) ) ) ;endwhile (setq P1 (cdr (assoc 10 (entget E1)))) ; start point line 1 (setq P2 (cdr (assoc 11 (entget E1)))) ; end point line 1 (setq P3 (cdr (assoc 10 (entget E2)))) ; start point line 2 (setq P4 (cdr (assoc 11 (entget E2)))) ; end point line 2 (setq X1 (car P1) Y1 (cadr P1) Z1 (caddr P1)) ; components of P1 (setq X2 (car P2) Y2 (cadr P2) Z2 (caddr P2)) ; " " " P2 (setq X3 (car P3) Y3 (cadr P3) Z3 (caddr P3)) ; " " " P3 (setq X4 (car P4) Y4 (cadr P4) Z4 (caddr P4)) ; " " " P4 (setq A (+ (* (- X2 X1)(- X1 X3)) (* (- Y2 Y1)(- Y1 Y3)) (* (- Z2 Z1)(- Z1 Z3)))) (setq D (+ (* (- X4 X3)(- X1 X3)) (* (- Y4 Y3)(- Y1 Y3)) (* (- Z4 Z3)(- Z1 Z3)))) (setq B (+ (* (- X2 X1)(- X2 X1)) (* (- Y2 Y1)(- Y2 Y1)) (* (- Z2 Z1)(- Z2 Z1)))) (setq C (+ (* (- X2 X1)(- X4 X3)) (* (- Y2 Y1)(- Y4 Y3)) (* (- Z2 Z1)(- Z4 Z3)))) (setq F (+ (* (- X4 X3)(- X4 X3)) (* (- Y4 Y3)(- Y4 Y3)) (* (- Z4 Z3)(- Z4 Z3)))) (setq CA (ABS (/ C (* (SQRT B)(SQRT F))))) ;Cosine CA=1 (setq SA (SQRT (ABS (- 1 (* CA CA))))) ;Sine SA=0 (setq ANG (ATAN SA CA)) (princ (strcat "\nAngle = " (angtos ANG 0 4))) (IF (< ANG 0.000005) (princ "\nLines are parallel - No connector\n") (progn (setq R1 (/ (- (* A C) (* B D)) (- (* C C) (* B F)))) (setq R (/ (- (* C R1) A) B)) ; connector end pnts (setq P5 (LIST (+ X1 (* (- X2 X1) R))(+ Y1 (* (- Y2 Y1) R))(+ Z1 (* (- Z2 Z1) R)))) (setq P6 (LIST (+ X3 (* (- X4 X3) R1))(+ Y3 (* (- Y4 Y3) R1))(+ Z3 (* (- Z4 Z3) R1)))) (setq DS (distance P5 P6)) ; connector length (if (or (< 1 R) (< 1 R1)) (princ " * * * CAUTION: Connector past end of Line 1 or 2")) (if (or (< R 0) (< R1 0)) (princ " * * * CAUTION: Connector past end of Line 1 or 2")) (princ (strcat "\nConnector length = " (rtos DS))) (if (> DS 0.00000000001) (command ".LINE" P5 P6 "") (princ "\nLines intersect - no connection") ) );endprogn );endif (setq *error* sys_error) (command "UCS" "R" "SYSUCS") (command "UCS" "D" "SYSUCS") (setvar "OSMODE" OLDSNAP) (setvar "CMDECHO" 1) (princ "\r") (redraw) (princ) ) ; END OF FILE ※ 引述《sjgau (sjgau)》之铭言: : 留言主题:如何作投影 : 留言人:sjgau 回覆 删除 : 首先要确定 UCS 的xy- 平面 : 以经设定到 相交的 两根直线上面 : 接着从第一条直线的两个端点, : 把两个端点,投影到 这个平面上。 : 所谓的投影,是针对当时的UCS : 投影点的 x, y 座标和原来的点相同, : z- 座标的值等於 0 : 2005-10-02 12:23:16 --59.104.49.139-- : 留言主题:要怎麽投影 : 留言人:seapighead 回覆 删除 : 歪斜线作公垂线中 : 要用什麽指令把LINE-1投影到XY平面 : ※ 引述《seapighead (猪头)》之铭言: : : 空间中的一对歪斜线 : : 要怎麽画出两线的公垂线 : : 请高手教一下 : : 急着想知道 : : 帮帮忙 : : 谢谢 --



※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.140.33.205







like.gif 您可能会有兴趣的文章
icon.png[问题/行为] 猫晚上进房间会不会有憋尿问题
icon.pngRe: [闲聊] 选了错误的女孩成为魔法少女 XDDDDDDDDDD
icon.png[正妹] 瑞典 一张
icon.png[心得] EMS高领长版毛衣.墨小楼MC1002
icon.png[分享] 丹龙隔热纸GE55+33+22
icon.png[问题] 清洗洗衣机
icon.png[寻物] 窗台下的空间
icon.png[闲聊] 双极の女神1 木魔爵
icon.png[售车] 新竹 1997 march 1297cc 白色 四门
icon.png[讨论] 能从照片感受到摄影者心情吗
icon.png[狂贺] 贺贺贺贺 贺!岛村卯月!总选举NO.1
icon.png[难过] 羡慕白皮肤的女生
icon.png阅读文章
icon.png[黑特]
icon.png[问题] SBK S1安装於安全帽位置
icon.png[分享] 旧woo100绝版开箱!!
icon.pngRe: [无言] 关於小包卫生纸
icon.png[开箱] E5-2683V3 RX480Strix 快睿C1 简单测试
icon.png[心得] 苍の海贼龙 地狱 执行者16PT
icon.png[售车] 1999年Virage iO 1.8EXi
icon.png[心得] 挑战33 LV10 狮子座pt solo
icon.png[闲聊] 手把手教你不被桶之新手主购教学
icon.png[分享] Civic Type R 量产版官方照无预警流出
icon.png[售车] Golf 4 2.0 银色 自排
icon.png[出售] Graco提篮汽座(有底座)2000元诚可议
icon.png[问题] 请问补牙材质掉了还能再补吗?(台中半年内
icon.png[问题] 44th 单曲 生写竟然都给重复的啊啊!
icon.png[心得] 华南红卡/icash 核卡
icon.png[问题] 拔牙矫正这样正常吗
icon.png[赠送] 老莫高业 初业 102年版
icon.png[情报] 三大行动支付 本季掀战火
icon.png[宝宝] 博客来Amos水蜡笔5/1特价五折
icon.pngRe: [心得] 新鲜人一些面试分享
icon.png[心得] 苍の海贼龙 地狱 麒麟25PT
icon.pngRe: [闲聊] (君の名は。雷慎入) 君名二创漫画翻译
icon.pngRe: [闲聊] OGN中场影片:失踪人口局 (英文字幕)
icon.png[问题] 台湾大哥大4G讯号差
icon.png[出售] [全国]全新千寻侘草LED灯, 水草

请输入看板名称,例如:WOW站内搜寻

TOP