找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1404|回复: 8

[LISP程序]:对齐标注转线性标注

[复制链接]
发表于 2009-4-13 12:42:59 | 显示全部楼层 |阅读模式

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

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

×
大家好!
最近做了一个“对齐标注转线性标注”的小程序和大家分享一下。
通常对齐标注夹点编辑时很不方便。线型标注却很好用。
希望对大家的工作有一些小小的帮助。谢谢!
;;;  ==================****************===========================
;;;    CHVDim.LSP                             
;;;    Write by : xiagood            
;;;    Email:xiatian3639@sina.com
==========================================================

;;;---------------------对齐标注转线性标注------------------------
(Defun ErrorCHVDim(msg)
    (command "._UNDO" "E")
    (prin1)
)

(Defun C:CHVDim(/ AcadObject AcadDocument mSpace DimSS  L M DimGet DimEle DimLay Dimcon DimStyle pt10 pt13 pt14)
   (vl-load-com)
   (setq *error* ErrorCHVDim)
   (setvar "cmdecho" 0)   
   (setq AcadObject (vlax-get-acad-object)
         AcadDocument (vla-get-ActiveDocument AcadObject)
         mSpace (vla-get-ModelSpace AcadDocument))
   (setq DimSS (ssget '((0 . "DIMENSION")
                        (100 . "AcDbAlignedDimension"))))
   (if (= DimSS nil)
       (progn
          (princ "\n没有对齐标注被选上!")
          (exit)
        )
    )
    (command "._UNDO" "BE")
  
    (setq L (sslength DimSS))
    (setq M 0)
    (while (< M L)
        (setq DimGet (ssname DimSS M))
        (setq DimEle (entget DimGet))
        (if (=  (vl-position (cons 100 "AcDbRotatedDimension") DimEle) nil)
            (progn
               ;;;获取图层、颜色
               (setq DimLay  (cdr (assoc 8  DimEle)))
             
               (setq pt10 (cdr (assoc 10 DimEle)))
               (setq pt13 (cdr (assoc 13 DimEle)))
               (setq pt14 (cdr (assoc 14 DimEle)))
               (setq Dimcon   (cdr (assoc 1 DimEle)))
               (setq DimStyle (cdr (assoc 3 DimEle)))
                            
               (GnHdg_AddDimAlign pt13 pt14 pt10 Dimcon DimStyle)

               (command "._CHANGE" (entlast) "" "P" "LA" DimLay "")
               (command "._ERASE" DimGet "")
             )
         )
         (Setq M (+ M 1))
     )

     (command "._UNDO" "E")
     (prin1)
)


;;;建立线性标注
(defun GnHdg_AddDimAlign (GnHdg_Pt1 GnHdg_Pt2 GnHdg_Pt3 GnHdg_DimCon GnHdg_DimStyle / Ent)
  (if (setq ent        (entmake (list '(0 . "DIMENSION")
                               '(100 . "AcDbEntity")
                               '(100 . "AcDbDimension")
                               (cons 10 GnHdg_Pt3)
                               '(11 0. 0. 0.)
                               '(70 . 32)
                               (cons 1 GnHdg_DimCon)
                               (cons 3 GnHdg_DimStyle)
                               '(100 . "AcDbAlignedDimension")
                               (cons 13 GnHdg_Pt1)
                               (cons 14 GnHdg_Pt2)
                               (cons 50 (angle GnHdg_Pt1 GnHdg_Pt2))
                               '(100 . "AcDbRotatedDimension")
                         )
                )
      )
    ent
  )
)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2009-4-19 20:16:49 | 显示全部楼层
能否做个演示看来
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

发表于 2009-4-21 08:36:31 | 显示全部楼层
楼主,我用dimscale、dimlfac改变标注的特性对齐标注然后用你的程序一刷会改回到原来的特性,能不能改一下。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2009-4-21 12:06:31 | 显示全部楼层
一般的不会发生太大的改变。除标注文字的插入点有可能会不同。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

使用道具 举报

发表于 2009-5-23 09:51:46 | 显示全部楼层
問題存在很久,謝謝樓主把問題解決。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-25 22:23 , Processed in 0.395527 second(s), 45 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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