明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3191|回复: 6

[提问] 求修改个程序-批量标注坐标!!

[复制链接]
发表于 2013-10-6 18:03 | 显示全部楼层 |阅读模式
本帖最后由 spp_wall 于 2013-10-6 18:05 编辑

      现在的问题是  这个批量标注  出的图不够美观  希望高手修改下

    1:在直线段还是没有问题的  就是有角度的情况下就不美观了   是否能做到 每个坐标都垂直于多段线

如下图中   蓝色的就是程序出来的效果    白色的就是最终要达到的效果

本帖子中包含更多资源

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

x
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2013-10-7 12:50 | 显示全部楼层
  1. (defun c:smer
  2.        (/ ang ang2 i long ps_cmdecho ps_luprec ps_osmode pt pt1 pts radius somode sunmer words)
  3.   (setq        ps_cmdecho (getvar "cmdecho")
  4.         ps_osmode  (getvar "osmode")
  5.         ps_luprec  (getvar "luprec")
  6.   )
  7.   (setvar "cmdecho" 0)
  8.   (setvar "osmode" 0)
  9.   (setvar "luprec" 0)
  10.   (command "-layer" "n" "桩号标注" "c" "4" "桩号标注" "")

  11.   (initvar 'words "输入文字大小(2~6)" 2.0)
  12.   (initvar 'radius "输入引线起点圆的半径(建议1mm)" 1.0)
  13.   (initvar 'long "输入引线长度" (* words 14))

  14.   (setq        sunmer (ssget '((0 . "*POLYLINE")))
  15.         i      0
  16.   )
  17.   (while (< i (sslength sunmer))
  18.     (setq pts (massoc (entget (ssname sunmer i)) 10))
  19.     (repeat (length pts)
  20.       (command "layer" "s" "桩号标注" "")
  21.       (setq pt (cdar pts))
  22.       (if (not (null (cdr pts)))
  23.         (setq ang (angle pt (cdadr pts)))
  24.       )
  25.       (setq
  26.         ang2 (- ang (* 0.5 pi))
  27.         pt1  (polar pt ang2 long)
  28.       )
  29.       (command "circle" pt radius)
  30.       (command "line" pt pt1 "")

  31.       (command "text"
  32.                (polar (polar pt ang2 2) (+ ang2 (* pi 0.5)) (* 0.5 words))
  33.                words
  34.                (radtodeg ang2)
  35.                (strcat "X=" (rtos (car pt) 2 4))
  36.       )
  37.       (command "text"
  38.                (polar (polar pt ang2 2) (- ang2 (* pi 0.5)) (* 1.5 words))
  39.                words
  40.                (radtodeg ang2)
  41.                (strcat "Y=" (rtos (cadr pt) 2 4))
  42.       )

  43.       (setq pts (cdr pts))
  44.     )
  45.     (setq i (1+ i))
  46.   )
  47.   (setvar "cmdecho" ps_cmdecho)
  48.   (setvar "osmode" ps_osmode)
  49.   (setvar "luprec" ps_luprec)
  50. )

  51. (defun initvar (symbol msg default / r)
  52.   (if (null (vl-symbol-value symbol))
  53.     (set symbol default)
  54.   )
  55.   (setq r (getdist (strcat msg "<" (rtos (vl-symbol-value symbol) 2) ">:")))
  56.   (if (not (null r))
  57.     (set symbol r)
  58.   )
  59. )
  60. (defun radtodeg        (rad)
  61.   (* 180.0 (/ rad pi))
  62. )
  63. (defun massoc (lst key)
  64.   (vl-remove-if '(lambda (x) (/= key (car x))) lst)
  65. )


 楼主| 发表于 2013-10-7 13:17 | 显示全部楼层
vectra 发表于 2013-10-7 12:50

谢谢  还能再完善么  
1:XY坐标的文字离多段线的距离是否能调整   那个代码是?
2:是否能选择坐标的位置  比如多段线的左侧或者右侧
发表于 2013-10-9 13:11 | 显示全部楼层

本帖子中包含更多资源

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

x
 楼主| 发表于 2013-10-9 14:49 | 显示全部楼层
xyp1964 发表于 2013-10-9 13:11

这个是逐点标注吧!

还有 不知道 我怎么无法使用 院长你的工具箱  都是按你要求的安装办法  但是输入XCAD没反应
发表于 2017-12-27 12:02 | 显示全部楼层
先下载学习一下
发表于 2021-4-14 08:26 | 显示全部楼层

大师
这段源码标注的文字是水平的  
怎么修改为增加可选项 ,

有水平或垂直标注的选择?
多谢了



源码如下:
多谢

  • (defun c:zbbz (/ LC:TEXTLENGTH TEXTSTYLE-BAK TEXTSIZE-BAK TEXTHIGH XSWS PT1 PT2 STRLST TEXTLENGTH PT3 LST)
  •   (defun LC:TextLength (String / Tbox)
  •     (setq Tbox (textbox (list (cons 1 String))))
  •     (distance (car Tbox) (cadr Tbox))
  •   )
  •   (setq TEXTSTYLE-bak(getvar "TEXTSTYLE"))
  •   (setvar "TEXTSTYLE" "Standard")
  •   (setq textsize-bak (Getvar "textsize")) ;字高系统变量
  •   (setq texthigh (getreal "\n  请输入文字高度<1.5>: "))
  •   (if (null texthigh) (setq texthigh 1.5))
  •   (Setvar "textsize" texthigh)
  •   (setq xsws (getint "\n 请输入小数位数<3>: "))
  •   (if (null xsws) (setq xsws 3))
  •   (while (setq pt1 (getpoint "\n 指定注记点: "))
  •     (setq pt2 (getpoint "注记位置: "))  
  •     (setq strlst (mapcar'strcat'("Y= " "X= " "H= ")(mapcar '(lambda (x) (rtos x 2 xsws)) pt1)))
  •     (setq textlength (apply 'MAX (mapcar '(lambda (x) (LC:TextLength x)) strlst)));文字最大长度
  •     (setq pt3 (if (> (car pt2) (car pt1))
  •                   (polar pt2 0 (+ textlength 1))
  •                   (polar pt2 pi (+ textlength 1))
  •               )
  •     )
  •     (setq lst (list pt1 pt2 pt3))
  •     (entmake (list '(0 . "TEXT")'(41 . 1.0)(cons 1 (cadr strlst)) (cons 10 (polar (polar (IF (>= (car pt2) (car pt1)) pt2 pt3) 0 0.5) (* 0.5 pi) (* texthigh 0.2))) (cons 40 texthigh)))
  •     (entmake (list '(0 . "TEXT")'(41 . 1.0) (cons 1 (car strlst)) (cons 10 (polar (polar (IF (>= (car pt2) (car pt1)) pt2 pt3) 0 0.5) (* 1.5 pi) (+ (* texthigh 0.2) texthigh))) (cons 40 texthigh)))
  •     (entmake (list '(0 . "TEXT") '(41 . 1.0)(cons 1 (last strlst)) (cons 10 (polar (polar (IF (>= (car pt2) (car pt1)) pt2 pt3) 0 0.5) (* 1.5 pi) (+ (* texthigh 0.4) (* texthigh 2.0)))) (cons 40 texthigh)))
  •     (entmake (append (list '(0 . "LWPOLYLINE")'(100 . "AcDbEntity")'(100 . "AcDbPolyline")(cons 90 (length lst)))(mapcar '(lambda (pt) (cons 10 pt)) lst)))
  •   )
  •   (Setvar "textsize" textsize-bak) ;还原字高系统变量
  •   (setvar "TEXTSTYLE" TEXTSTYLE-bak) ;还原字体系统变量
  • )














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

本版积分规则

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

GMT+8, 2024-4-24 04:11 , Processed in 0.286080 second(s), 31 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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