明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 923|回复: 0

[讨论] [G版的图元对齐]请教怎么改成直线跟文字中间对齐,现在是直线和文字底对齐。

[复制链接]
发表于 2015-6-9 22:26 | 显示全部楼层 |阅读模式
1明经币
转了一下G版贴下面的一段,某大侠改过的,不好意思翻不出来名字了。
请教怎么改成直线跟文字中间对齐,现在是直线和文字底对齐。


(defun c:pldq ();;;将物体横向和竖向同时批量对齐
  ;;选择集转表
  (defun gxl-Sel-SS->List        (ss / i s )
  (if ss
  (repeat (setq i (sslength ss))
  (setq s (cons (ssname ss (setq i (1- i))) s))
    )
    )
)
  ;;计算物体中心点
  (defun gxl-getboxCenter (e1 / obj minpoint maxpoint)
  (if (= 'ENAME (type e1))
  (setq obj (vlax-ename->vla-object e1)) ;转换图元名
    (setq obj e1)
    )
  (vla-GetBoundingBox obj 'minpoint 'maxpoint)
                                        ;取得包容图元的最大点和最小点
  (setq minpoint (vlax-safearray->list minpoint)) ;把变体数据转化为表

;; (setq maxpoint (vlax-safearray->list maxpoint)) ;把变体数据转化为表
;; (setq p (mapcar '+ minpoint maxpoint))
;;   (mapcar '(lambda (x) (* 0.5 x)) p)
    minpoint
)
  ;;主程序
  (setq cmdecho (getvar 'cmdecho))
  (setq osmode (getvar 'osmode))
  (setvar 'osmode 0)
  (setvar 'cmdecho 0)
  (princ "\n选择水平基准物体:")
  (setq s1 (ssget))
  (princ "\n选择要对齐物体:")  
  (setq s2 (ssget))
  (setq s1-1 (getpoint "选取竖直对齐点位置:"))
  (setq s1 (GXL-SEL-SS->LIST s1)
        s2 (GXL-SEL-SS->LIST s2)
        )
  (setq s1 (mapcar '(lambda (x) (list x (GXL-GETBOXCENTER x))) s1))
  (setq s1 (vl-sort s1 '(lambda (a b) (> (cadadr a) (cadadr b))) )) ;_ 按Y从大到小排序
  (setq s2 (mapcar '(lambda (x) (list x (GXL-GETBOXCENTER x))) s2))
  (setq s2 (vl-sort s2 '(lambda (a b) (> (cadadr a) (cadadr b))) )) ;_ 按Y从大到小排序
  (setq n 0)
  (repeat (length s1)
    (setq e1 (car (nth n s1))
          p1 (cadr (nth n s1))
          )
    (if (setq e2 (car (nth n s2)))
      (progn
        (setq p2 (cadr (nth n s2)))
        (setq p3 (list (car s1-1) (cadr p1) (caddr p2)))
        (command "move" e2 "" p2 p3)
        )
      )
    (setq n (1+ n))
    )
    (setvar 'osmode osmode)
    (setvar 'cmdecho cmdecho)
(princ)
  )

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

本版积分规则

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

GMT+8, 2024-5-3 21:05 , Processed in 0.625748 second(s), 26 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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