明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: king、

[提问] 求一个 两点中心线 小程序

[复制链接]
发表于 2022-10-14 14:26:19 | 显示全部楼层
本帖最后由 229096767 于 2022-10-14 15:08 编辑

不知道是不是如图所示:


  1. (defun c:tt()
  2.   (prompt "\n请选择两条直线:")
  3.   (setq ss (ssget))
  4.   (if (>= (sslength ss) 2)
  5.     (progn
  6.       (setq ent1 (entget (ssname ss 0)))
  7.       (setq ent2 (entget (ssname ss 1)))
  8.       
  9.       (setq pt11 (cdr (assoc 10 ent1)))
  10.       (setq pt12 (cdr (assoc 11 ent1)))
  11.       
  12.       (setq pt21 (cdr (assoc 10 ent2)))
  13.       (setq pt22 (cdr (assoc 11 ent2)))
  14.       
  15.       (setq pt13 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt11 pt12));中点
  16.       (setq pt23 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt21 pt22));中点
  17.       
  18.       (command "line" pt13 pt23 "");中点连线
  19.       
  20.       (setq pt33 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt13 pt23));中点连线的中点
  21.       (setq ang1 (angle pt13 pt23));中点连线的角度
  22.       
  23.       (setq L (/ (distance pt13 pt23) 2.0))
  24.       
  25.       (setq pt31 (polar pt33 (- ang1 (/ pi 2)) L))
  26.       (command "line" pt33 pt31 "")
  27.       
  28.       (setq pt32 (polar pt33 (+ ang1 (/ pi 2)) L))
  29.       (command "line" pt33 pt32 "")
  30.       
  31.     )
  32.   )
  33. )


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
 楼主| 发表于 2022-10-14 15:28:38 | 显示全部楼层
229096767 发表于 2022-10-14 14:26
不知道是不是如图所示:

可能我表述不清楚,图片现在应该清晰些

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
发表于 2022-10-14 15:49:54 | 显示全部楼层
感觉坑有点深!
 楼主| 发表于 2022-10-14 15:51:54 | 显示全部楼层
xj6019 发表于 2022-10-14 15:49
感觉坑有点深!

还好吧,只是想点两个点生成一个十字线
发表于 2022-10-14 16:02:28 | 显示全部楼层
king、 发表于 2022-10-14 15:28
可能我表述不清楚,图片现在应该清晰些
  1. (defun c:tt()
  2.   (prompt "\n请选择两条直线:")
  3.   (setq ss (ssget))
  4.   (if (>= (sslength ss) 2)
  5.     (progn
  6.       (setq ent1 (entget (ssname ss 0)))
  7.       (setq ent2 (entget (ssname ss 1)))
  8.       
  9.       (setq pt11 (cdr (assoc 10 ent1)))
  10.       (setq pt12 (cdr (assoc 11 ent1)))
  11.       
  12.       (setq pt21 (cdr (assoc 10 ent2)))
  13.       (setq pt22 (cdr (assoc 11 ent2)))
  14.       
  15.       (setq pt13 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt11 pt12));中点
  16.       (setq pt23 (mapcar '(lambda(x y)(/ (+ x y) 2.0)) pt21 pt22));中点
  17.       
  18.       
  19.       (setq pt31 (list (car pt23) (cadr pt13)))
  20.       (setq pt32 (list (car pt13) (cadr pt23)))
  21.       
  22.       (setq H 100)
  23.       
  24.       (setq ang1 (angle pt13 pt31))
  25.       (setq pt41 (polar pt31 ang1 (- H)))
  26.       (setq pt42 (polar pt31 ang1 H))
  27.       
  28.       (entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt41) (cons 11 pt42)))
  29.       
  30.       (setq ang2 (angle pt23 pt31))
  31.       (setq pt51 (polar pt31 ang2 (- H)))
  32.       (setq pt52 (polar pt31 ang2 H))
  33.       
  34.       (entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt51) (cons 11 pt52)))

  35.     )
  36.   )
  37. )

点评

对如此神问也能给出准确回答,太历害得不行  发表于 2022-10-15 13:11
发表于 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)
  )


本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?注册

x
 楼主| 发表于 2022-10-14 16:21:26 | 显示全部楼层

非常感谢百忙中帮我些的程序,现在这个程序功能是只能选直线,能否改成用鼠标在两条直线上分别点一下,生成十字线,因为这两个直线有可能是多段线或者面域上的线条
发表于 2022-10-14 16:28:56 | 显示全部楼层
king、 发表于 2022-10-14 16:21
非常感谢百忙中帮我些的程序,现在这个程序功能是只能选直线,能否改成用鼠标在两条直线上分别 ...
  1. (defun c:tt2 (/ h pt1 pt2 pt3 ang1 pt41 pt42 ang2 pt51 pt52)
  2.   (setq H 100)
  3.   (setq pt1 (getpoint "\n请选择第一个点:"))
  4.   (setq pt2 (getpoint pt1 "\n请选择第二个点:"))

  5.   (setq pt3 (list (car pt2) (cadr pt1)))

  6.   (setq ang1 (angle pt1 pt3))
  7.   (setq pt41 (polar pt3 ang1 (- H)))
  8.   (setq pt42 (polar pt3 ang1 H))

  9.   (entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt41) (cons 11 pt42)))

  10.   (setq ang2 (angle pt2 pt3))
  11.   (setq pt51 (polar pt3 ang2 (- H)))
  12.   (setq pt52 (polar pt3 ang2 H))

  13.   (entmake (list '(0 . "LINE") '(62 . 1) (cons 10 pt51) (cons 11 pt52)))
  14.   (princ)
  15. )
 楼主| 发表于 2022-10-14 16:30:22 | 显示全部楼层
飞的鱼儿 发表于 2022-10-14 16:20
(defun c:jjbb()
  (setq p1 (getpoint"\n线A左端点")
        p2 (getpoint"\n线A右端点")

  可以用耶,就是鼠标点的多了点
 楼主| 发表于 2022-10-14 16:34:29 | 显示全部楼层

大佬请收下我的膝盖,此程序正是想要的,非常感谢!
您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|CAD论坛|CAD教程|CAD下载|联系我们|关于明经|明经通道 ( 粤ICP备05003914号 )  
©2000-2023 明经通道 版权所有 本站代码,在未取得本站及作者授权的情况下,不得用于商业用途

GMT+8, 2024-11-16 01:26 , Processed in 0.185283 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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