明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 5824|回复: 22

[源码] 刚刚随手编的一个相同文字连线的小程序

[复制链接]
发表于 2015-1-20 23:14:34 | 显示全部楼层 |阅读模式
刚刚随手编的一个相同文字连线的小程序
对某些同学或许有点用


现在的设备、工艺专业人员都挺偷懒
按规矩应该在设备编号旁边注明电功率等内容
现在是啥也不标就给个设备表
核对起来很费时
这个程序就是点设备表的文字
自动在所有相同的文字之间连上直线
程序很简单扩展空间很大

(setq *ent2obj*     vlax-Ename->Vla-Object)

(defun c:tt()
  (if (setq ss (ssget ":e:s" '((0 . "TEXT"))))
  (progn
   (setq ttent (ssname ss 0))
   (command "layer" "m" "f_temp_文字连线" "c" "6" "" "")
   (setq str (cdr (assoc 1 (entget ttent))))
   (setq po (getmidpo (entbox ttent)))
   (setq ss (ssget "x" (list '(0 . "TEXT")(cons 1 str))))
   (if (< 1 (sslength ss))
    (progn
     (setq oldliness (ssget "x" '((0 . "line")(8 . "f_temp_文字连线"))))
     (if oldliness (command "erase" oldliness ""))
     
     (setq ss (vl-remove ttent (ss2list ss)))
     (foreach x ss
      (setq px (getmidpo (entbox x)))
      (command "line" "non" po "non" px "")
     )
    )
    (command "change" ttent "" "p" "co" "2" "")
   )
  )
)
(princ)
)

;;单个物体的最小(正交)包围框
(defun entbox ( ent / ll ur )
(vla-getboundingbox (*ent2obj* ent) 'll 'ur)
(mapcar 'vlax-safearray->list (list ll ur))
)

;;求两点中点
(defun getmidpo( pts / P1 P2 X Y )
(setq p1 (car pts) p2 (cadr pts))
(if (= (length p1) (length p2))
  nil
  (setq p1 (list (car p1) (cadr p1))
    p2 (list (car p2) (cadr p2))
  )
)
(mapcar '(lambda (X Y) (/ (+ X Y) 2.0)) P1 P2)
)

;;选择集转为图元列表
(defun ss2list( ss )
(if (= 'PICKSET (type ss))
  (reverse (vl-remove-if-not '(lambda (x) (= (type x) 'ENAME)) (mapcar 'cadr (ssnamex ss))))
)
)
"觉得好,就打赏"
还没有人打赏,支持一下
发表于 2024-9-20 14:07:03 | 显示全部楼层
本帖最后由 xyp1964 于 2024-9-20 14:08 编辑


  1. (defun c:tt ()
  2.   "相同文字连线"
  3.   (defun Ep5 (e / p1 p9 p)
  4.     (vla-getboundingbox (vlax-Ename->Vla-Object e) 'p1 'p9)
  5.     (setq p(mapcar 'vlax-safearray->list (list p1 p9)))
  6.     (mapcar '(lambda (x y) (/ (+ x y) 2.0))(car p)(cadr p))
  7.   )
  8.   (defun ss2list (ss)
  9.     (vl-remove-if'(lambda (x) (/= (type x) 'ENAME))(mapcar 'cadr (ssnamex ss)))
  10.   )
  11.   (if (and (setq ss1 (ssget ":e:s" '((0 . "TEXT"))))
  12.            (setq s1 (ssname ss1 0))
  13.            (setq tx (cdr (assoc 1 (entget s1))))
  14.            (setq ss (ssget (list '(0 . "TEXT") (cons 1 tx))))
  15.       )
  16.     (progn
  17.       (command "-layer" "m" "文字连线" "c" "6" "" "")
  18.       (setq p0  (Ep5 s1)
  19.             lst (vl-remove s1 (ss2list ss))
  20.       )
  21.       (foreach x lst (command "line" "non" p0 "non" (Ep5 x) ""))
  22.       (princ "\n相同文本数量 = ")
  23.       (princ (length lst))
  24.       (alert (strcat "\n相同文本数量 = "(itoa (length lst))))
  25.     )
  26.   )
  27.   (princ)
  28. )

本帖子中包含更多资源

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

x
回复 支持 1 反对 0

使用道具 举报

发表于 2022-10-26 09:36:34 | 显示全部楼层
up                       
发表于 2015-1-21 08:32:01 | 显示全部楼层
发表于 2015-1-21 09:48:33 | 显示全部楼层
这个挺好的
发表于 2015-1-21 12:30:47 | 显示全部楼层
这个还挺实用
发表于 2015-1-21 13:02:10 | 显示全部楼层
谢谢龙前辈,这个挺好,以前找不到,都是用查找的,用这个就方便多了
发表于 2015-1-21 19:02:00 | 显示全部楼层
好工具。如果在连线前可以选择范围就更好啦。
发表于 2015-1-21 19:48:54 | 显示全部楼层
学习了!!!!!
发表于 2015-1-21 22:41:07 | 显示全部楼层
我是用遍历zoom的方式,检查某个编号构件跟表格的是否一致
发表于 2015-1-22 10:54:05 | 显示全部楼层
能不能加个连线的框选范围啊
发表于 2015-1-23 00:29:50 | 显示全部楼层
能不能连块啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-12-23 22:13 , Processed in 0.298939 second(s), 32 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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