229096767
发表于 2022-10-14 14:26:19
本帖最后由 229096767 于 2022-10-14 15:08 编辑
不知道是不是如图所示:
(defun c:tt()
(prompt "\n请选择两条直线:")
(setq ss (ssget))
(if (>= (sslength ss) 2)
(progn
(setq ent1 (entget (ssname ss 0)))
(setq ent2 (entget (ssname ss 1)))
(setq pt11 (cdr (assoc 10 ent1)))
(setq pt12 (cdr (assoc 11 ent1)))
(setq pt21 (cdr (assoc 10 ent2)))
(setq pt22 (cdr (assoc 11 ent2)))
(setq pt13 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt11 pt12));中点
(setq pt23 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt21 pt22));中点
(command "line" pt13 pt23 "");中点连线
(setq pt33 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt13 pt23));中点连线的中点
(setq ang1 (angle pt13 pt23));中点连线的角度
(setq L (/ (distance pt13 pt23) 2.0))
(setq pt31 (polar pt33 (- ang1 (/ pi 2)) L))
(command "line" pt33 pt31 "")
(setq pt32 (polar pt33 (+ ang1 (/ pi 2)) L))
(command "line" pt33 pt32 "")
)
)
)
king、
发表于 2022-10-14 15:28:38
229096767 发表于 2022-10-14 14:26
不知道是不是如图所示:
可能我表述不清楚,图片现在应该清晰些
xj6019
发表于 2022-10-14 15:49:54
感觉坑有点深!
king、
发表于 2022-10-14 15:51:54
xj6019 发表于 2022-10-14 15:49
感觉坑有点深!
还好吧:lol,只是想点两个点生成一个十字线
229096767
发表于 2022-10-14 16:02:28
king、 发表于 2022-10-14 15:28
可能我表述不清楚,图片现在应该清晰些
(defun c:tt()
(prompt "\n请选择两条直线:")
(setq ss (ssget))
(if (>= (sslength ss) 2)
(progn
(setq ent1 (entget (ssname ss 0)))
(setq ent2 (entget (ssname ss 1)))
(setq pt11 (cdr (assoc 10 ent1)))
(setq pt12 (cdr (assoc 11 ent1)))
(setq pt21 (cdr (assoc 10 ent2)))
(setq pt22 (cdr (assoc 11 ent2)))
(setq pt13 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt11 pt12));中点
(setq pt23 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt21 pt22));中点
(setq pt31 (list (car pt23) (cadr pt13)))
(setq pt32 (list (car pt13) (cadr pt23)))
(setq H 100)
(setq ang1 (angle pt13 pt31))
(setq pt41 (polar pt31 ang1 (- H)))
(setq pt42 (polar pt31 ang1 H))
(entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt41) (cons 11 pt42)))
(setq ang2 (angle pt23 pt31))
(setq pt51 (polar pt31 ang2 (- H)))
(setq pt52 (polar pt31 ang2 H))
(entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt51) (cons 11 pt52)))
)
)
)
飞的鱼儿
发表于 2022-10-14 16:20:55
本帖最后由 飞的鱼儿 于 2022-10-14 16:29 编辑
(defun c:jjbb()
(setq p1 (getpoint"\n线A左端点")
p2 (getpoint"\n线A右端点")
p3 (getpoint"\n线B左端点")
p4 (getpoint"\n线B右端点")
)
(setq x1 (/ (+ (car p1) (car p2))2)
x2 (/ (+ (car p3) (car p4))2)
)
(setq y1 (cadr p1)
y2 (cadr p3)
)
(setq x100 (max x1 x2)
y100 (min y1 y2)
)
(setq os1 (getvar "osmode"))
(setvar "osmode" 0)
(10zz (list x100 y100) 50)
)
(defun 10zz (pt1 le1 / p11 p12 p13 p14)
(setq p11 (polar pt1 (* 0 pi) (*1 le1))
p12 (polar pt1 (* 0 pi) (* -1 le1))
p13 (polar pt1 (* 0.5 pi) (*1 le1))
p14 (polar pt1 (* 0.5 pi) (* -1 le1))
)
(command"line" p11 p12 "")
(command"line" p13 p14 "")
(setvar "osmode" os1)
)
king、
发表于 2022-10-14 16:21:26
229096767 发表于 2022-10-14 16:02
非常感谢百忙中帮我些的程序:handshake,现在这个程序功能是只能选直线,能否改成用鼠标在两条直线上分别点一下,生成十字线,因为这两个直线有可能是多段线或者面域上的线条
229096767
发表于 2022-10-14 16:28:56
king、 发表于 2022-10-14 16:21
非常感谢百忙中帮我些的程序,现在这个程序功能是只能选直线,能否改成用鼠标在两条直线上分别 ...
(defun c:tt2 (/ h pt1 pt2 pt3 ang1 pt41 pt42 ang2 pt51 pt52)
(setq H 100)
(setq pt1 (getpoint "\n请选择第一个点:"))
(setq pt2 (getpoint pt1 "\n请选择第二个点:"))
(setq pt3 (list (car pt2) (cadr pt1)))
(setq ang1 (angle pt1 pt3))
(setq pt41 (polar pt3 ang1 (- H)))
(setq pt42 (polar pt3 ang1 H))
(entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt41) (cons 11 pt42)))
(setq ang2 (angle pt2 pt3))
(setq pt51 (polar pt3 ang2 (- H)))
(setq pt52 (polar pt3 ang2 H))
(entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt51) (cons 11 pt52)))
(princ)
)
king、
发表于 2022-10-14 16:30:22
飞的鱼儿 发表于 2022-10-14 16:20
(defun c:jjbb()
(setq p1 (getpoint"\n线A左端点")
p2 (getpoint"\n线A右端点")
:handshake可以用耶,就是鼠标点的多了点:lol
king、
发表于 2022-10-14 16:34:29
229096767 发表于 2022-10-14 16:28
大佬请收下我的膝盖,此程序正是想要的:handshake,非常感谢!