乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 87|回复: 1

[编程交流] 绘制动态文本和线条。

[复制链接]

22

主题

100

帖子

78

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
112
发表于 2022-7-6 10:15:42 | 显示全部楼层 |阅读模式
大家好
以下代码用于绘制动态文字和线条。
如图所示。

                               
登录/注册后可看大图

 
但错误总是发生。调试之后。
我发现这些代码中存在代码。
  1. (setq text (vla-addtext mSpace fh (vlax-3d-point nextPt)))

 
 
整个计划。感谢您抽出时间阅读本文。
  1. (defun c:tt(/)
  2.         (vl-load-com)
  3. (defun *error* (msg)
  4.         (setvar "osmod" osmode_old)
  5. )
  6. (defun text_length (Text / textent ang sinrot cosrot t1 t2 p0 p1 p2 p3 p4)
  7.         (setq         textent (entget (vlax-vla-object->ename Text)))
  8.         (setq         p0  (cdr (assoc 10 textent))
  9.                         ang  (cdr (assoc 50 textent))
  10.                         sinrot (sin ang)
  11.                         cosrot (cos ang)
  12.                         t1  (car (textbox textent))
  13.                         t2  (cadr (textbox textent))
  14.                         p1  (list (+ (car p0) (- (* (car t1) cosrot) (* (cadr t1) sinrot)))
  15.                                 (+ (cadr p0)
  16.                                 (+ (* (car t1) sinrot) (* (cadr t1) cosrot))
  17.                                 )
  18.                                 )
  19.                         p2  (list
  20.                                 (+ (car p0)
  21.                                 (- (* (car t2) cosrot) (* (cadr t1) sinrot))
  22.                                 )
  23.                                 (+ (cadr p0)
  24.                                 (+ (* (car t2) sinrot) (* (cadr t1) cosrot))
  25.                                 )
  26.                                 )
  27.         )
  28.                         (distance p1 p2)
  29. )
  30. (setq mSpace (vla-get-ModelSpace(vla-get-ActiveDocument (vlax-get-acad-object))))
  31.         (setq entbak (ssadd))
  32.         (setq osmode_old (getvar "osmode"))
  33.         (setvar "osmode" 0)
  34.         (setq pt (getpoint "\nget the center point."))
  35.         (command "_.circle" pt)
  36.           (princ (strcat "\ninput the radius of circle"))
  37.         (command pause)
  38.         (setq cir (vlax-ename->vla-object (entlast)))
  39.         (ssadd (entlast) entbak)
  40.         ;start to input the makr.
  41.         (setq hasMore T)
  42.         (while hasMore
  43.           (setq nextPt (grread T 4 0)
  44.                      readtype (car nextPt)
  45.                      readvale (cadr nextPt)
  46.         )
  47.     (cond ((= readtype 5)
  48.                                 (setq nextPt (cadr nextPt))
  49.                                 (setq nextPt (trans nextPt 1 0))
  50.                                 (setq basePt (vlax-curve-getclosestpointto cir nextPt))
  51.                                 (if (not line)
  52.                                         (progn
  53.                                                 (if (not fh)
  54.                                                         (setq fh "A")
  55.                                                 )
  56.                                                 (setq text (vla-addtext mSpace fh (vlax-3d-point nextPt)))
  57.                                                 (ssadd (entlast) entbak)
  58.                                                 (setq txtlen (text_length text))
  59.                                                 (setq l2end (vla-addline mSpace (vlax-3d-point nextPt) (vlax-3d-point l2end)))
  60.                                         )
  61.                                         (progn
  62.                                                 (vla-put-startpoint line (vlax-3d-point basePt))
  63.                                                 (vla-put-endpoint line (vlax-3d-point nextPt))
  64.                                                 (vla-update line)
  65.                                                 (setq ptt (car nextPt))
  66.                                                 (if (> ptt pt)
  67.                                                         (progn
  68.                                                                 (setq textleft (+ (car nextPt) (getvar "dimgap")))
  69.                                                                 (setq l2left (+ (car nextPt) txtlen (getvar "dimgap")))
  70.                                                         )
  71.                                                         (progn
  72.                                                                 (setq textleft (- (car nextPt) (getvar "dimgap") txtlen))
  73.                                                                 (setq l2left textleft)
  74.                                                         )
  75.                                                 )
  76.                                                 (vla-put-insertionpoint text (vlax-3d-point list textleft (+ (cadr nextPt) (getvar "dimgap")) 0))
  77.                                                 (vla-update text)
  78.                                                 (vla-put-startpoint l2 (vlax-3d-point nextPt))
  79.                                                 (setq l2end (list l2left (cadr nextPt) 0))
  80.                                                 (vla-put-endpoint l2 (vlax-3d-point l2end))
  81.                                                 (vla-update l2)
  82.                                         )
  83.                                 )       
  84.                    )
  85.                    ((= readtype 3)
  86.                                 (setq i nil)
  87.                    )
  88.                    ((or (= 25 readtype) (= 13 readtype))
  89.                                 ;(
  90.                    )
  91.         )
  92. )
  93. )
回复

使用道具 举报

22

主题

100

帖子

78

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
112
发表于 2022-7-6 11:20:46 | 显示全部楼层
找出原因。应该是:
  1. (setq text (vla-addtext mSpace fh (vlax-3d-point nextPt) (getvar "dimtxt")))

 
更新的代码:
  1. (defun c:tt(/ line fh text)
  2.         (vl-load-com)
  3. (defun *error* (msg)
  4.         (setvar "osmod" osmode_old)
  5. )
  6. (defun text_length (Text / textent ang sinrot cosrot t1 t2 p0 p1 p2 p3 p4)
  7.         (setq         textent (entget (vlax-vla-object->ename Text)))
  8.         (setq         p0  (cdr (assoc 10 textent))
  9.                         ang  (cdr (assoc 50 textent))
  10.                         sinrot (sin ang)
  11.                         cosrot (cos ang)
  12.                         t1  (car (textbox textent))
  13.                         t2  (cadr (textbox textent))
  14.                         p1  (list (+ (car p0) (- (* (car t1) cosrot) (* (cadr t1) sinrot)))
  15.                                 (+ (cadr p0)
  16.                                 (+ (* (car t1) sinrot) (* (cadr t1) cosrot))
  17.                                 )
  18.                                 )
  19.                         p2  (list
  20.                                 (+ (car p0)
  21.                                 (- (* (car t2) cosrot) (* (cadr t1) sinrot))
  22.                                 )
  23.                                 (+ (cadr p0)
  24.                                 (+ (* (car t2) sinrot) (* (cadr t1) cosrot))
  25.                                 )
  26.                                 )
  27.         )
  28.                         (distance p1 p2)
  29. )
  30. (setq mSpace (vla-get-ModelSpace(vla-get-ActiveDocument (vlax-get-acad-object))))
  31.         (setq entbak (ssadd))
  32.         (setq osmode_old (getvar "osmode"))
  33.         (setvar "osmode" 0)
  34.         (setq pt (getpoint "\nget the center point."))
  35.         (command "_.circle" pt)
  36.           (princ (strcat "\ninput the radius of circle"))
  37.         (command pause)
  38.         (setq cir (vlax-ename->vla-object (entlast)))
  39.         (ssadd (entlast) entbak)
  40.         ;start to input the makr.
  41.         (setq hasMore T)
  42.         (while hasMore
  43.           (setq nextPt (grread T 4 0)
  44.                      readtype (car nextPt)
  45.                      readvale (cadr nextPt)
  46.         )
  47.     (cond ((= readtype 5)
  48.                                 (setq nextPt (cadr nextPt))
  49.                                 (setq nextPt (trans nextPt 1 0))
  50.                                 (setq basePt (vlax-curve-getclosestpointto cir nextPt))
  51.                                 (if (not line)
  52.                                         (progn
  53.                                                 (if (not fh)
  54.                                                         (setq fh "A")
  55.                                                 )
  56.                                                 (setq text (vla-addtext mSpace fh (vlax-3d-point nextPt) (getvar "dimtxt")))
  57.                                                 (ssadd (entlast) entbak)
  58.                                                 ;(setq txtlen (text_length text))
  59.                                                 (setq line (vla-addline mSpace (vlax-3d-point basePt) (vlax-3d-point nextPt)))
  60.                                                 (ssadd (entlast) entbak)
  61.                                                 (setq txtlen (text_length text))
  62.                                                 (setq l2end (list (+ (car nextPt) txtlen) (cadr nextPt) 0))
  63.                                                 (setq l2 (vla-addline mspace (vlax-3d-point nextPt) (vlax-3d-point l2end)))
  64.                                                 (ssadd (entlast) entbak)
  65.                                         )
  66.                                         (progn
  67.                                                 (vla-put-startpoint line (vlax-3d-point basePt))
  68.                                                 (vla-put-endpoint line (vlax-3d-point nextPt))
  69.                                                 (vla-update line)
  70.                                                 (setq ptt (car nextPt))
  71.                                                 (setq ptx (car pt))
  72.                                                 (if (> ptt ptx)
  73.                                                         (progn
  74.                                                                 (setq textleft (+ (car nextPt) (getvar "dimgap")))
  75.                                                                 (setq l2left (+ (car nextPt) txtlen (getvar "dimgap")))
  76.                                                         )
  77.                                                         (progn
  78.                                                                 (setq textleft (- (car nextPt) (getvar "dimgap") txtlen))
  79.                                                                 (setq l2left textleft)
  80.                                                         )
  81.                                                 )
  82.                                                 (vla-put-insertionpoint text (vlax-3d-point (list textleft (+ (cadr nextPt) (getvar "dimgap")) 0)))
  83.                                                 (vla-update text)
  84.                                                 (vla-put-startpoint l2 (vlax-3d-point nextPt))
  85.                                                 (setq l2end (list l2left (cadr nextPt) 0))
  86.                                                 (vla-put-endpoint l2 (vlax-3d-point l2end))
  87.                                                 (vla-update l2)
  88.                                         )
  89.                                 )       
  90.                    )
  91.                    ((= readtype 3)
  92.                                 (setq hasMore nil)
  93.                    )
  94.                    ((or (= 25 readtype) (= 13 readtype))
  95.                                 ;(
  96.                    )
  97.         )
  98. )
  99. )
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-3-6 21:16 , Processed in 0.419744 second(s), 60 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表