明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 4962|回复: 13

[已解答] 多义线边长标注

[复制链接]
发表于 2014-1-18 08:16:05 | 显示全部楼层 |阅读模式
有人编过多义线边长标注,程序如下,标注单个多义线是没问题,可惜不能批量标注,如何修改,使之能够批量标注多义线。

;;;;多义线边长标注
(defun c:bcbz (/ obj pianju sHandle  pt np gx bj np xc  rr  cp n ang1 zjp ms AddText)
;;;构造text
(command "layer" "M" "边长标注" "C" "3" "" "LT" "CONTINUOUS" "" "");设置一个标注图层
(command "style" "tukou" "宋体" "0" "" "0" "" "")
  (defun AddText (obj TextString  InsertionPoint  Height xz kb qx Alignment style / obj1 err)
  (setq obj1 (vla-addtext obj TextString  (vlax-3d-point InsertionPoint)  Height))
  (vla-put-Rotation obj1 xz)
  (vla-put-ScaleFactor obj1 kb)
  (vla-put-ObliqueAngle obj1 qx)
  (vla-put-alignment obj1 Alignment)
  (if (/= Alignment acAlignmentLeft)
    (vla-put-TextAlignmentPoint obj1 (vlax-3d-point InsertionPoint))
    (vla-put-InsertionPoint obj1 (vlax-3d-point InsertionPoint))
   )
   (VL-CATCH-ALL-APPLY 'vla-put-StyleName (list obj1 style))
  obj1
  )
(setq pi2 (/ pi 2))
  (setq ms (vla-get-ModelSpace (vla-get-ActiveDocument (vlax-get-acad-object))))
(setq  bcHeight (getdist "\n输入标注文字高度:");文字高度
        kgb         0.8 ; 宽高比
       Style         "BG_ST" ; 字体
        ZJWS         2 ;_ 注记位数
       DimScale 1 ; 边长尺度,若单位为mm,该值为1000
        flag         nil ;标注在多段线走向的右侧,T 左侧
) ;_ setq
(while  (setq pen (car (entsel "\n选择多段线:")))
  (setq pianju (* bcHeight 0.7)) ;边长离线距离
  (setq obj (vlax-ename->vla-object pen)
        n 0)
  (while (and (setq pt (vlax-curve-getPointAtParam obj n))
              (setq np (vlax-curve-getPointAtParam obj (1+ n)))
         ) ;_ 结束and
    (if        (/= 0.0 (setq bugle (vla-GetBulge obj n)))
      (progn
        (setq midpt (vlax-curve-getPointAtParam obj (+ 0.5 n))
             bj (* (atan (abs bugle)) 4)
            xc (* 0.5 (distance Pt np))
            gg (abs (* bugle xc))
            rr (/ (+ (* xc xc) (* gg gg)) (* 2 gg))
            ang1 (angle pt np)
            cp (polar Pt ang1 xc)
            cp (polar midpt (angle midpt cp) rr)
            bc (rtos (/ (- (vlax-curve-getDistAtParam obj (1+ n)) (vlax-curve-getDistAtParam obj n)) DimScale) 2 ZJWS)
              )
       (if flag
            (setq zjp (polar midpt (cond ((> bugle 0)(angle midpt cp))(t (angle  cp midpt))) pianju))
            (setq zjp  (polar midpt (cond ((> bugle 0)(angle  cp midpt))(t (angle midpt cp))) pianju))
     )
        (if (not (or (and (>= ang1 0) (< ang1 (* 0.666666 pi))) (and (> ang1 (* 1.666666 pi)) (< ang1 (* 2.0 pi)))))
         (setq ang1 (- ang1 pi))
          )
        (AddText ms bc  zjp  bcHeight ang1 kgb 0 acAlignmentMiddle Style)
     );progn
      (progn
        (setq midpt (vlax-curve-getPointAtParam obj (+ 0.5 n))
              ang1 (angle pt np)
              bc (rtos (/ (- (vlax-curve-getDistAtParam obj (1+ n)) (vlax-curve-getDistAtParam obj n)) DimScale)  2 ZJWS)
              )
        (if flag
            (setq zjp (polar midpt (+ pi2 ang1) pianju))
          (setq zjp (polar midpt (- ang1 pi2) pianju))
               )
        (if (not (or (and (>= ang1 0) (< ang1 (* 0.666666 pi))) (and (> ang1 (* 1.666666 pi)) (<= ang1 (* 2.0 pi)))))
          (setq ang1 (- ang1 pi))
          )
        (AddText ms bc  zjp  bcHeight ang1 kgb 0 acAlignmentMiddle Style)
      );progn
    ) ;结束if
    (setq n (1+ n))
  ) ; 结束while
)
  (princ)
  )
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2014-1-18 09:09:35 | 显示全部楼层
也看过一些楼主发的帖子,我想这应该不能难倒楼主啊,如下是帮你改了以后的程序,试试看看是否是你想要的结果。
  1. ;;;多义线边长标注
  2. (defun c:bcbz (/ obj pianju sHandle  pt np gx bj np xc  rr  cp n ang1 zjp ms AddText pen-n pen-all)
  3. ;;;构造text
  4. (command "layer" "M" "边长标注" "C" "3" "" "LT" "CONTINUOUS" "" "");设置一个标注图层
  5. (command "style" "tukou" "宋体" "0" "" "0" "" "")
  6.   (defun AddText (obj TextString  InsertionPoint  Height xz kb qx Alignment style / obj1 err)
  7.   (setq obj1 (vla-addtext obj TextString  (vlax-3d-point InsertionPoint)  Height))
  8.   (vla-put-Rotation obj1 xz)
  9.   (vla-put-ScaleFactor obj1 kb)
  10.   (vla-put-ObliqueAngle obj1 qx)
  11.   (vla-put-alignment obj1 Alignment)
  12.   (if (/= Alignment acAlignmentLeft)
  13.     (vla-put-TextAlignmentPoint obj1 (vlax-3d-point InsertionPoint))
  14.     (vla-put-InsertionPoint obj1 (vlax-3d-point InsertionPoint))
  15.    )
  16.    (VL-CATCH-ALL-APPLY 'vla-put-StyleName (list obj1 style))
  17.   obj1
  18.   )
  19. (setq pi2 (/ pi 2))
  20.   (setq ms (vla-get-ModelSpace (vla-get-ActiveDocument (vlax-get-acad-object))))
  21. (setq  bcHeight (getdist "\n输入标注文字高度:");文字高度
  22.         kgb         0.8 ; 宽高比
  23.        Style         "BG_ST" ; 字体
  24.         ZJWS         2 ;_ 注记位数
  25.        DimScale 1 ; 边长尺度,若单位为mm,该值为1000
  26.         flag         nil ;标注在多段线走向的右侧,T 左侧
  27. ) ;_ setq
  28. (setq pen-n 0)
  29. (if (setq pen-all (ssget '((0 . "*polyline"))))
  30.     (repeat (sslength pen-all)
  31.             (setq pianju (* bcHeight 0.7)) ;边长离线距离
  32.             (setq pen-en (ssname pen-all pen-n))
  33.             (setq obj (vlax-ename->vla-object pen-en)
  34.                   n 0)
  35.               (while (and (setq pt (vlax-curve-getPointAtParam obj n))
  36.               (setq np (vlax-curve-getPointAtParam obj (1+ n)))
  37.          ) ;_ 结束and
  38.     (if        (/= 0.0 (setq bugle (vla-GetBulge obj n)))
  39.       (progn
  40.         (setq midpt (vlax-curve-getPointAtParam obj (+ 0.5 n))
  41.              bj (* (atan (abs bugle)) 4)
  42.             xc (* 0.5 (distance Pt np))
  43.             gg (abs (* bugle xc))
  44.             rr (/ (+ (* xc xc) (* gg gg)) (* 2 gg))
  45.             ang1 (angle pt np)
  46.             cp (polar Pt ang1 xc)
  47.             cp (polar midpt (angle midpt cp) rr)
  48.             bc (rtos (/ (- (vlax-curve-getDistAtParam obj (1+ n)) (vlax-curve-getDistAtParam obj n)) DimScale) 2 ZJWS)
  49.               )
  50.        (if flag
  51.             (setq zjp (polar midpt (cond ((> bugle 0)(angle midpt cp))(t (angle  cp midpt))) pianju))
  52.             (setq zjp  (polar midpt (cond ((> bugle 0)(angle  cp midpt))(t (angle midpt cp))) pianju))
  53.      )
  54.         (if (not (or (and (>= ang1 0) (< ang1 (* 0.666666 pi))) (and (> ang1 (* 1.666666 pi)) (< ang1 (* 2.0 pi)))))
  55.          (setq ang1 (- ang1 pi))
  56.           )
  57.         (AddText ms bc  zjp  bcHeight ang1 kgb 0 acAlignmentMiddle Style)
  58.      );progn
  59.       (progn
  60.         (setq midpt (vlax-curve-getPointAtParam obj (+ 0.5 n))
  61.               ang1 (angle pt np)
  62.               bc (rtos (/ (- (vlax-curve-getDistAtParam obj (1+ n)) (vlax-curve-getDistAtParam obj n)) DimScale)  2 ZJWS)
  63.               )
  64.         (if flag
  65.             (setq zjp (polar midpt (+ pi2 ang1) pianju))
  66.           (setq zjp (polar midpt (- ang1 pi2) pianju))
  67.                )
  68.         (if (not (or (and (>= ang1 0) (< ang1 (* 0.666666 pi))) (and (> ang1 (* 1.666666 pi)) (<= ang1 (* 2.0 pi)))))
  69.           (setq ang1 (- ang1 pi))
  70.           )
  71.         (AddText ms bc  zjp  bcHeight ang1 kgb 0 acAlignmentMiddle Style)
  72.       );progn
  73.     ) ;结束if
  74.     (setq n (1+ n))
  75.   ) ; 结束while
  76.   (setq pen-n (1+ pen-n)))
  77. )
  78.   (princ)
  79.   )
发表于 2014-1-18 11:33:01 | 显示全部楼层
@2006
(command "style" "tukou" "宋体" "0" "" "0" "" "")
==>
(command "style" "tukou" "宋体" "0" "" "0" "" "" "")
 楼主| 发表于 2014-1-18 14:48:40 | 显示全部楼层
zyhandw 发表于 2014-1-18 09:09
也看过一些楼主发的帖子,我想这应该不能难倒楼主啊,如下是帮你改了以后的程序,试试看看是否是你想要的结 ...

很好!谢谢您!满足我的要求。
发表于 2014-3-21 14:24:11 | 显示全部楼层
测试过,如果线里有相同坐标的重点就出现错误~求修改

本帖子中包含更多资源

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

x
 楼主| 发表于 2014-3-21 20:52:46 | 显示全部楼层
陈亚娣 发表于 2014-3-21 14:24
测试过,如果线里有相同坐标的重点就出现错误~求修改

请阁下把图上传。
发表于 2014-3-22 08:40:42 | 显示全部楼层
香田里浪人 发表于 2014-3-21 20:52
请阁下把图上传。

老师,不用上图也行吧!就是复合线有重点就会有错误~老师你可以试试处理有重点的多段线
发表于 2014-3-22 08:45:05 | 显示全部楼层
香田里浪人 发表于 2014-3-21 20:52
请阁下把图上传。

;;164.9 [功能] 去除多段线重点(没写作者名所以没法说出出处)
;;示例(HH:Remove (car (entsel)))
(defun HH:Remove (en / NEWDATA)
  (foreach e (entget en)
    (if (and (member e newdata) (= 10 (car e)))
      nil
      (setq newdata (cons e newdata))
    )
  )
  (entmod (reverse newdata))
)
我加了这个去除多段线重点函数
 楼主| 发表于 2014-3-22 19:06:22 | 显示全部楼层
有重点也是可以标注,只是距离为0.00
 楼主| 发表于 2014-3-22 19:16:41 | 显示全部楼层
有重点也是可以标注,只是距离为0.00

本帖子中包含更多资源

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

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

本版积分规则

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

GMT+8, 2025-5-24 05:52 , Processed in 0.176672 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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