找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 736|回复: 4

[求助]:求助lisp修改

[复制链接]
发表于 2005-10-1 04:44:32 | 显示全部楼层 |阅读模式

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

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

×
哪位能帮助修改以下LISP程序.
单线改双线,支持框选
(defun c:test1 ()
  (CMDLA0)
  (setq        no1 (ureal 1 "" "\n双线宽" no1)
        ss  (ssget (list (cons 0 "LINE")))
        i   -1
  )
  (command ".undo" "BE")
  (setvar "osmode" 0)
  (while (setq s1 (ssname ss (setq i (1+ i))))
    (setq pt1 (dxf 10 (entget s1))
          pt2 (dxf 11 (entget s1))
          pt3 (_midpup pt1 pt2 0.35)
          pt4 (_midpdn pt1 pt2 0.35)
    )
    (command "offset" (/ no1 2) s1 pt3 s1 pt4 "")
    (entdel s1)
  )
  (command ".undo" "E")
  (CMDLA1)
)

;;;双向偏移
(defun c:test2 ()
  (SETQ getds (UDIST 7 "" "\n输入偏移距离<可直接量取>:" getds nil))
  (if (ssget '((0 . "Arc,Circle,Ellipse,*Line")))
    (vlax-for obj (vla-get-activeselectionset
                    (vla-get-activedocument (vlax-get-acad-object))
                  )
      (vla-offset obj getds)
      (vla-offset obj (* getds -1))
    )
    (vlax-release-object obj)
  )
)

1.偏移后线自动到当前层,这样轴线偏移后可以到自已设的墙层.
2.单线改双线偏移后原线是否删除可选.
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2005-10-1 06:44:09 | 显示全部楼层
  1. [FONT=courier new](defun c:test1 ()
  2.   (CMDLA0)
  3.   (setq        no1 (ureal 1 "" "\n双线宽" no1)
  4.         TX1 (UKWORD 1 "1 2" "\n原线 : 1-保留/2-删除" TX1)
  5.         ss  (ssget (list (cons 0 "LINE")))
  6.         i   -1
  7.   )
  8.   (setvar "osmode" 0)
  9.   (while (setq s1 (ssname ss (setq i (1+ i))))
  10.     (setq pt1 (dxf 10 (entget s1))
  11.           pt2 (dxf 11 (entget s1))
  12.           pt3 (_midpup pt1 pt2 (/ no1 2.0))
  13.           pt4 (_midpdn pt1 pt2 (/ no1 2.0))
  14.     )
  15.     (command "offset" (/ no1 2) s1 pt3 s1 pt4 "")
  16.     (if        (= TX1 "2")
  17.       (entdel s1)
  18.     )
  19.   )
  20.   (CMDLA1)
  21. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

发表于 2005-10-6 13:32:37 | 显示全部楼层
  1. [FONT=courier new](defun c:test1 ()
  2.   (CMDLA0)
  3.   (setq        no1 (ureal 1 "" "\n双线宽" no1)
  4.         TX1 (UKWORD 1 "1 2" "\n原线 : 1-保留/2-删除" TX1)
  5.         ss  (ssget (list (cons 0 "LINE")))
  6.         i   -1
  7.   )
  8.   (setvar "osmode" 0)
  9.   (while (setq s1 (ssname ss (setq i (1+ i))))
  10.     (setq pt1 (dxf 10 (entget s1))
  11.           pt2 (dxf 11 (entget s1))
  12.           pt3 (_midpup pt1 pt2 (/ no1 2.0))
  13.           pt4 (_midpdn pt1 pt2 (/ no1 2.0))
  14.     )
  15.     (command "offset" (/ no1 2) s1 pt3  "")
  16.     (command"change" (entlast) "" "p""la"(getvar"clayer")"")
  17.     (command "offset" (/ no1 2) s1 pt4 "")
  18.     (command"change" (entlast) "" "p""la"(getvar"clayer")"")
  19.     (if        (= TX1 "2")
  20.       (entdel s1)
  21.     )
  22.   )
  23.   (CMDLA1)
  24. )[/FONT]
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-9-22 02:51 , Processed in 0.432842 second(s), 40 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

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