明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 504|回复: 2

[源码] 麻烦大佬帮我看看这段代码错在哪里,每次当数据集增大就会出错,请指教!!!

[复制链接]
发表于 2021-4-2 16:05 | 显示全部楼层 |阅读模式
  • ;此代码主要功能是将文字画下引线,并在引线下中心处输入文字
  • (defun c:xgl()
  •   (vl-load-com)
  •   (setq obj (vlax-get-acad-object));取得CAD母体对象
  • (setq dwgobj (vla-get-ActiveDocument obj));取当前的图形文件对象
  • (setq mspace (vla-get-ModelSpace dwgobj));取模型空间集合对像
  •   (setq ss (ssget '((0 . "text"))))
  •      (setq lst nil)
  •    (setq i 0)
  •     (setq dll (getstring "\n 输入文字"))
  •    (repeat (sslength ss)
  •      (setq pt1 nil)(setq pt2 nil)(setq p2 nil)(setq pt3 nil)
  •      (setq lst (cons (ssname ss i) lst))
  •      (setq i (1+ i))
  •    
  •    (setq vlalst (mapcar 'vlax-ename->vla-object lst))
  •    (setq        boxlst (mapcar '(lambda        (x / cor1 cor2)
  •                            (vla-GetBoundingBox x 'cor1 'cor2)
  •                            (list        (vlax-safearray->list cor1)
  •                                  (vlax-safearray->list cor2)
  •                            )
  •                          )
  •                         vlalst
  •                 )
  •    )
  •   (setq pt1  (list (car (car(car boxlst)))(-(cadr (car(car boxlst)))100)))
  •   (setq pt2 (list (car (cadr(car boxlst)))(cadr (cadr(car boxlst)))))
  •   (setq p2 (list (car (cadr(car boxlst))) (-(cadr (car(car boxlst)))100)))
  •   ;(command "RECTANG" pt1 pt2)
  •   (wztc)
  •     (entmake (list '(0 . "LINE")
  •              (cons 10 pt1)
  •              (cons 11 p2)
  •            )
  •   )
  •   ;确定输入文字位置
  •    (setq  pt3 (list (/ (+ (car pt1) (car p2)) 2)
  •               (-  (/ (+ (cadr pt1) (cadr p2)) 2)  300)
  •               0
  •             )
  •   )
  •   (command "text"  "s" "REALCAD" "J" "M" pt3 "400" "0" dll );采用中心对齐方式
  •      
  •   )
  • )

发表于 2021-4-3 09:22 | 显示全部楼层
1、把(wztc)删了;    2、把 REALCAD替换为你的字体样式即可
发表于 2021-4-4 21:21 | 显示全部楼层
  1. (defun c:tt ()
  2.   (if (setq ss (ssget '((0 . "text"))))
  3.     (progn
  4.       (setq tx (getstring "\n输入文字: ")
  5.             i  -1
  6.       )
  7.       (while (setq s1 (ssname ss (setq i (1+ i))))
  8.         (vla-GetBoundingBox (vlax-ename->vla-object s1) 'p1 'p2)
  9.         (setq p1 (vlax-safearray->list p1)
  10.               p2 (vlax-safearray->list p2)
  11.               p2 (list (car p2) (cadr p1))
  12.               p1 (Polar p1 (* pi 1.5) 100)
  13.               p2 (Polar p2 (* pi 1.5) 100)
  14.               p3 (mapcar '(lambda (x y) (* (+ x y) 0.5)) p1 p2)
  15.               p3 (Polar p3 (* pi 1.5) 200)
  16.         )
  17.         (command "LINE" p1 p2 "")
  18.         (command "text" "J" "M" p3 "400" "0" tx)
  19.       )
  20.     )
  21.   )
  22.   (princ)
  23. )
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-5-5 06:25 , Processed in 0.277017 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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