明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
楼主: 小妹丁

[基础] [求助]很长时间没碰程序,帮忙看下。

    [复制链接]
发表于 2010-5-12 14:00:00 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
 楼主| 发表于 2010-5-12 16:38:00 | 显示全部楼层
xyp1964发表于2010-5-12 13:24:0051773(defun c:tt ()  (prompt \"\选取投影圆: \")  (if (and (setq ss (ssget '((0 . \"CIRCLE\"))))    (setq s1 (car (entsel \"\n选择投影中心线第1条边线: \"))

选取投影圆:
选择对象: 指定对角点: 找到 4 个
选择对象:
选择投影中心线第1条边线:
选择投影中心线第2条边线: ; 错误: no function definition: VLAX-CURVE-GETCLOSESTPOINTTO

 楼主| 发表于 2010-5-12 16:41:00 | 显示全部楼层

(VL-LOAD-COM)

看上去好像捕捉点,还要补全。

本帖子中包含更多资源

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

x
发表于 2010-5-12 16:48:00 | 显示全部楼层
(command "line" "non" p1 "non" p2 "")
 楼主| 发表于 2010-5-12 17:00:00 | 显示全部楼层
liu_kunlun发表于2010-5-12 16:48:00(command \"line\" \"non\" p1 \"non\" p2 \"\")

还是有点问题:

本帖子中包含更多资源

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

x
发表于 2010-5-12 22:52:00 | 显示全部楼层

在xyp1964基础上完善一下:

(defun c:tt ( / ss ea pa1 pa2 aga eb pb1 pb2 agb i e pt p1 p2)
  (prompt "\选取投影圆: ")
  (if (and (setq ss (ssget '((0 . "CIRCLE"))))
           (setq ea (car (entsel "\n选择投影中心线第1条边线: ")))   
    (= "LINE" (cdr (assoc 0 (setq ea (entget ea)))))
    (setq pa1 (cdr (assoc 10 ea))
          pa2 (cdr (assoc 11 ea))
   aga (angle pa1 pa2)
    ) 
           (setq eb (car (entsel "\n选择投影中心线第2条边线: ")))
    (= "LINE" (cdr (assoc 0 (setq eb (entget eb)))))
    (setq pb1 (cdr (assoc 10 eb))
          pb2 (cdr (assoc 11 eb))
   agb (angle pb1 pb2)
    )
      )
      (progn
         (setq i -1)
         (while (setq e (ssname ss (setq i (1+ i))))
            (setq pt (cdr (assoc 10 (entget e)))
                  p1 (inters pa1 pa2 pt (polar pt (+ aga (/ pi 2.)) 1.) nil)
                  p2 (inters pb1 pb2 pt (polar pt (+ agb (/ pi 2.)) 1.) nil)
            )
            (command "line" "non" (polar p1 (angle p2 p1) 3.) "non" (polar p2 (angle p1 p2) 3.) "")
         )
     )
  )
  (princ)
)

 楼主| 发表于 2010-5-13 00:21:00 | 显示全部楼层

你改的很好了,谢谢。

现在这个程序,只在处理同心圆上,还有不足,可以应对绝大多数的情况。

本帖子中包含更多资源

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

x
发表于 2010-5-13 08:43:00 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
 楼主| 发表于 2010-5-15 00:16:00 | 显示全部楼层
此时,如果用equal来排除同心圆,该如何写?
发表于 2010-5-15 09:22:00 | 显示全部楼层
小妹丁发表于2010-5-15 0:16:00此时,如果用equal来排除同心圆,该如何写?
分步骤来,不要急于绘制。
  1. ;;继续完善如下:
  2. (defun c:tt (/ ss ea pa1 pa2 aga eb pb1 pb2 agb i e pt p1 p2)
  3.   (princ "\选取投影圆: ")
  4.   (if (and (setq ss (ssget '((0 . "CIRCLE"))))
  5.     ;;
  6.     (setq en (car (entsel "\n选择第1条边线: ")))
  7.     (setq ent (entget en))
  8.     (setq pt10 (cdr (assoc 10 ent)))
  9.     (setq pt11 (cdr (assoc 11 ent)))
  10.     (setq ang1 (+(angle pt10 pt11)(* 0.5 pi)))
  11.     ;;
  12.     (setq en (car (entsel "\n选择第2条边线: ")))
  13.     (setq ent (entget en))   
  14.     (setq pt20 (cdr (assoc 10 ent)))
  15.     (setq pt21 (cdr (assoc 11 ent)))
  16.     (setq ang2 (+ (angle pt20 pt21)(* 0.5 pi)))
  17.       )
  18.     (progn
  19.       ;;
  20.       (setq lst_pt '()
  21.      i 0
  22.       )
  23.       (repeat (sslength ss)
  24. (setq en (ssname ss i)
  25.        ent (entget en)
  26.        )
  27. (setq pt (cdr (assoc 10 ent)))
  28. (if (member pt lst_pt)
  29.    ()
  30.    (setq lst_pt (cons pt lst_pt))
  31. )
  32. (setq i (1+ i))
  33.       )
  34.       ;;绘制
  35.       (foreach pt lst_pt
  36. (setq
  37.    pt1 (inters pt10 pt11 pt (polar pt ang1 10) nil)
  38.    pt2 (inters pt20 pt21 pt (polar pt ang2 10) nil)
  39. )
  40. (command "line"
  41.    "non"
  42.    (polar pt1 (angle pt2 pt1) 3)
  43.    "non"
  44.    (polar pt2 (angle pt1 pt2) 3)
  45.    ""
  46. )
  47.       )
  48.     )
  49.   )
  50.   (princ)
  51. )
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-2-22 05:17 , Processed in 0.150457 second(s), 19 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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