找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1044|回复: 7

[原创]:调整文字行间距

[复制链接]
发表于 2005-3-30 12:33:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

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

×
[PHP]
(defun c:Td (/ TxtSS  L_TxtSS            ct           MY_ALL txt         FY        TH
               MY     MY_ALL ct            index  Y_min  Y_max         key        ct
               num    txtEnt txt    gc72   gc73          U_O         U_FX        U_FY
               U_FZ   W_O    NewFP  txt
              )
  (princ "\n请选择需要排列的文字:")
  (setq        TxtSS        (ssget '((0 . "TEXT")))
        L_TxtSS        (sslength TxtSS)
        ct        0
        MY_ALL        nil
  ) ;_ end of setq
  (while (< ct L_TxtSS)
    (setq txt         (entget (ssname TxtSS ct))
          FY         (cadr (trans (cdr (assoc 10 txt)) 0 1))
          TH         (cdr (assoc 40 txt))
          MY         (+ FY (/ Th 2))
          MY_ALL (append MY_ALL (list MY))
          ct         (1+ ct)
    )
  ) ;_ end of while
  (setq        index (vl-sort-i MY_ALL '<)
        Y_min (nth (nth 0 index) MY_ALL)
        Y_max (nth (nth (1- L_TxtSS) index) MY_ALL)
  )
  (initget 128 "S I")
  (setq
    key        (getkword "\n[输入行间距(I)/根据所选文字确定行间距(S)]<S>: "
        ) ;_ end of getkword
  ) ;_ end of setq
  (if (/= key nil)
    (setq key (strcase key))
  ) ;_ end of if
  (if (or (= key "S") (= key nil)) ;_ end of or
    (setq deta_y (/ (- Y_max Y_min) (1- L_TxtSS)))
    (if        (= key "I")
      (progn (princ "请输入行间距:") (setq deta_y (getdist))) ;_ end of progn
    ) ;_ end of if
  ) ;_ end of if
  (setq ct 1)
  (while (< ct L_TxtSS)
    (setq num         (nth ct index)
          txtEnt (ssname TxtSS num)
          txt         (entget txtEnt)
          gc72         (cdr (assoc 72 txt))
          gc73         (cdr (assoc 73 txt))
    ) ;_ end of setq
    (setq Y_Y (- (nth num MY_ALL) (+ y_min (* ct deta_y))) ;_ end of -
    ) ;_ end of setq
    (if        (and (= 0 gc72) (= 0 gc73))
      (progn (setq U_O         (trans (cdr (assoc 10 txt)) 0 1)
                   U_FX         (car U_O)
                   U_FY         (- (cadr U_O) Y_Y)
                   U_FZ         (caddr U_O)
                   W_O         (trans (list U_FX U_FY U_FZ) 1 0)
                   NewFP (list 10 (car W_O) (cadr W_O) (caddr W_O))
                   txt         (subst NewFP (assoc 10 txt) txt)
             )
             (entmod txt)
             (entupd txtent)
      ) ;_ end of progn
      (progn (setq U_O         (trans (cdr (assoc 11 txt)) 0 1)
                   U_FX         (car U_O)
                   U_FY         (- (cadr U_O) Y_Y)
                   U_FZ         (caddr U_O)
                   W_O         (trans (list U_FX U_FY U_FZ) 1 0)
                   NewFP (list 11 (car W_O) (cadr W_O) (caddr W_O))
                   txt         (subst NewFP (assoc 11 txt) txt)
             )
             (entmod txt)
             (entupd txtent)
      ) ;_ end of progn
    ) ;_ end of if
    (setq ct (1+ ct))
  ) ;_ end of while
  (princ)
) ;_ end of defun
[/PHP]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-3-30 13:47:45 | 显示全部楼层
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2005-3-30 21:42:05 | 显示全部楼层
晓东工具箱有此功能,学习学习楼主的思路!
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

已领礼包: 9个

财富等级: 恭喜发财

发表于 2005-11-9 05:35:10 | 显示全部楼层
楼主这个比小东的好用,对73代码也进行了处理。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-2-11 16:39:41 | 显示全部楼层
谢谢我很需要这个程序
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-2-11 22:50:09 | 显示全部楼层
适合任意实体的自动“等距分布”程序:
http://p4.xdcad.net/forum/showthread.php?s=&threadid=520816
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-2-14 13:38:20 | 显示全部楼层
谢谢,很好用,如果能靠一边对齐就太完美了
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2006-2-15 14:03:56 | 显示全部楼层
我是菜鸟,不知道如何使用这种程序,烦请大家指点下.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-29 09:29 , Processed in 0.406227 second(s), 46 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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