明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 720|回复: 2

[提问] 尺寸界线程序,无法运行,请求帮助

[复制链接]
发表于 2017-8-24 10:24:00 | 显示全部楼层 |阅读模式
本帖最后由 尘缘一生 于 2017-8-24 10:25 编辑

如题,写了个这个,无法运行,请求改动。其中:实体交点函数,取自本坛作品

  1. ;;; -------------------------------------------------------------------------
  2. (defun c:ccjx (/ ang1 pt1 pt3 pt4 pt5 pt7 pt8 ang e p n spname)
  3.   (setq spname (car (entsel "\n请选择标注尺寸线:")))
  4.   (if (= "LINE" (cdr (assoc 0 (entget spname))))
  5.     (progn
  6.       (setq pt1 (entget spname))
  7.       (setq pt3 (cdr (assoc 10 pt1)))
  8.       (setq pt4 (cdr (assoc 11 pt1)))
  9.       (setq ang (angle pt3 pt4))
  10.     )
  11.   )
  12.   
  13.   (if (= "lwpolyline" (cdr (assoc 0 (entget spname))))
  14.     (progn
  15.       (setq pt3 (vlax-curve-getstartpoint spname)) ; 对象的起点
  16.       (setq pt4 (vlax-curve-getendpoint spname)) ; 对象的终点
  17.       (setq ang (angle pt3 pt4))
  18.     )
  19.   )
  20.   (princ "\n 请选择所有尺寸定界线: ")
  21.   (setq e (ssget))
  22.   (setq p (sslength e))
  23.   (setq n 0)
  24.   (while (< n p)  
  25.     (setq pt1 (obj_int spname (ssname e n)))  
  26.     (setq pt7 (polar pt1 (+ (/ pi 4) ang) 0.71))
  27.     (setq pt8 (polar pt1 (+ (+ (/ pi 4) ang) pi) 0.71))
  28.     (command "_.PLINE" "non" pt7 "W" 0.45 0.45 "non" pt8 "")         
  29.     (setq n (+ n 1))
  30.   )
  31. )

  32. ;~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  33. ;功能:返回两个对象的所有交点
  34. ;参数: ent1、ent2 均为ename对象
  35. (defun obj_int (ent1 ent2 / ax_ent_1 ax_ent_2 intpoints points i)
  36.   (setq ax_ent_1 (vlax-ename->vla-object ent1)
  37.     ax_ent_2 (vlax-ename->vla-object ent2)
  38.   )
  39.   (setq intpoints (vla-intersectwith ax_ent_1 ax_ent_2 acextendnone))
  40.   (setq intpoints (vlax-variant-value intpoints))
  41.   (setq i 0)
  42.   (if (> (vlax-safearray-get-u-bound intpoints 1) 0)
  43.     (repeat (/ (+ 1
  44.                  (- (vlax-safearray-get-u-bound intpoints 1)
  45.                    (vlax-safearray-get-l-bound intpoints 1)
  46.                  )
  47.                )
  48.               3
  49.             )
  50.       (setq points (append points (list (list
  51.                                           (vlax-safearray-get-element intpoints i)
  52.                                           (vlax-safearray-get-element intpoints (+ i 1))
  53.                                           (vlax-safearray-get-element intpoints (+ i 2))
  54.                                         )))
  55.       )
  56.       (setq i (+ 3 i))
  57.     )
  58.   )
  59.   points
  60. )





本帖子中包含更多资源

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

x
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2017-8-24 11:13:33 | 显示全部楼层
函数obj_int 返回的是个点表
改成(setq pt1 (car (obj_int spname (ssname e n))))
 楼主| 发表于 2017-8-24 15:01:28 | 显示全部楼层
修改调试成功
  1. ;;; ------------------------------------------------------------------------
  2. (defun c:ccjx (/ pt1 pt3 pt4 ang e p n spname)
  3.   (setq spname (car (entsel "\n请选择标注尺寸线:")))
  4.   (if (= "LINE" (cdr (assoc 0 (entget spname))))
  5.     (progn
  6.       (setq pt1 (entget spname))
  7.       (setq pt3 (cdr (assoc 10 pt1)))
  8.       (setq pt4 (cdr (assoc 11 pt1)))
  9.       (setq ang (/ (* 180 (angle pt3 pt4)) pi))
  10.     )
  11.   )

  12.   (if (= "LWPOLYLINE" (cdr (assoc 0 (entget spname))))
  13.     (progn
  14.       (setq pt3 (vlax-curve-getstartpoint spname)) ; 对象的起点
  15.       (setq pt4 (vlax-curve-getendpoint spname)) ; 对象的终点
  16.       (setq ang (/ (* 180 (angle pt3 pt4)) pi))
  17.     )
  18.   )
  19.   (princ "\n 请选择所有尺寸定界线: ")
  20.   (setq e (ssget))
  21.   (setq p (sslength e))
  22.   (setq n 0)
  23.   (while (< n p)
  24.     (setq pt1 (car (obj_int spname (ssname e n))))
  25.     (command "-insert" "_archtick" pt1 1 1 ang)
  26.     (setq n (+ n 1))
  27.   )
  28. )

  29. ;;; ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  30. ;;; 功能:返回两个对象的所有交点
  31. ;;; 参数: ent1、ent2 均为ename对象
  32. (defun obj_int (ent1 ent2 / ax_ent_1 ax_ent_2 intpoints points i)
  33.   (setq ax_ent_1 (vlax-ename->vla-object ent1)
  34.   ax_ent_2 (vlax-ename->vla-object ent2)
  35.   )
  36.   (setq intpoints (vla-intersectwith ax_ent_1 ax_ent_2 acextendnone))
  37.   (setq intpoints (vlax-variant-value intpoints))
  38.   (setq i 0)
  39.   (if (> (vlax-safearray-get-u-bound intpoints 1) 0)
  40.     (repeat (/ (+ 1 (- (vlax-safearray-get-u-bound intpoints 1)
  41.            (vlax-safearray-get-l-bound intpoints 1)
  42.         )
  43.          ) 3
  44.       )
  45.       (setq points (append
  46.          points
  47.          (list (list (vlax-safearray-get-element intpoints i)
  48.          (vlax-safearray-get-element intpoints
  49.                    (+ i 1)
  50.          ) (vlax-safearray-get-element intpoints
  51.                      (+ i 2)
  52.            )
  53.          )
  54.          )
  55.        )
  56.       )
  57.       (setq i (+ 3 i))
  58.     )
  59.   )
  60.   points
  61. )

您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2025-5-20 01:40 , Processed in 0.185954 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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