找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 2542|回复: 10

[原创]:一个结合Lisp的拖动例子

[复制链接]
发表于 2004-5-14 11:41:02 | 显示全部楼层 |阅读模式

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

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

×
Lisp函数:,先导入一下
(defun Drag( pBlock / ppnt ed ped)
(defun GetPoint( / a pnt )
  (setq a (grread t))
  (setq pnt (list 0 0 1))
  (if (= 3 (car a)) (setq pnt (list 0 0 -1)))
  (if (= 5 (car a)) (setq pnt (cadr a)))
  pnt
)
  (while (not (= (caddr (setq ppnt (GetPoint)))  -1))
  (setq ed (entget (handent pBlock)))
  (setq ped (list 10 (car ppnt) (cadr ppnt) (caddr ppnt)))
  (setq ed (subst ped (assoc 10 ed) ed))
  (entmod ed)
  )
)
测试(由于拖动在Lisp中做好了,不需频繁调用Vlax类,应该不会使AutoCad崩溃):
Sub Test()
    Dim obj As VLAX
    Dim c(2) As Double
    Dim pObj As AcadBlockReference
    Set obj = New VLAX
    Set pObj = ThisDrawing.ModelSpace.InsertBlock(c, "123", 1, 1, 1, 0)
    a = "(drag " & Chr(34) & pObj.Handle & Chr(34) & ")"
    obj.EvalLispExpression (a)
    Set obj = Nothing
End Sub
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
发表于 2004-5-14 12:28:50 | 显示全部楼层
Sendcommand即可,不用如此繁琐。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-5-14 12:32:26 | 显示全部楼层
Sendcommand容易使程序产生混乱

改良版(不需导入Lisp函数)

Public Sub BlockInsert(Name As String)
    Dim pLisp As String
    Dim obj As VLAX
    Dim pnt(2) As Double
    Set obj = New VLAX
    Set pObj = ThisDrawing.ModelSpace.InsertBlock(pnt, Name, 1, 1, 1, 0)
    obj.EvalLispExpression "(setq ed (entget (handent " & ToStr(pObj.Handle) & ")))"
    pLisp = "(while (not (= (caddr " & _
            "(setq pTime (grread t) " & _
                  "pSt (car pTime) " & _
                  "pnt (cond ((= pSt 3) (List 0 0 -1)) ((= pSt 5) (cadr pTime)) (t (List 0 0 1)))))  -1)) " & _
            "(setq ed (subst (cons 10 pnt) (assoc 10 ed) ed)) " & _
            "(entmod ed) " & _
            ") "
    obj.EvalLispExpression pLisp
    Set obj = Nothing
End Sub

Public function ToStr(ByVal str) As String
    ToStr = Chr(34) & str & Chr(34)
End Function

Sub Test()
    BlockInsert "123"
End Sub
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-8-6 13:38:30 | 显示全部楼层
但是在我的机器上运行上面的程序,提示说VLAX是用户自定义类型未定义,我用的是Autocad2004,是不是少装了什么??
它不认VLAX这个类
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-8-6 16:20:49 | 显示全部楼层
Vlax类在:
http://www.xdcad.net/forum/showt ... 1193001#post1193001
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-8-8 10:15:05 | 显示全部楼层
vlax类的开始处有下列代码:
VERSION 1.0 CLASS
BEGIN
MultiUse = -1 'True
END
Attribute VB_Name = "VLAX"
Attribute VB_GlobalNameSpace = False
Attribute VB_Creatable = False
Attribute VB_PredeclaredId = False
Attribute VB_Exposed = False
我搞不清这些东西是什么?
我把他们注释掉了,并不影响可以使用,为什么??

我用什么样的方式可以实现Lisp和VBA的数据交换呢?我想把(setq pTime (grread t))里面的坐标值传递给VBA使用,以便判断当前鼠标所在位置从而执行相应东西?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-8-11 08:55:01 | 显示全部楼层
Lisp和VBA的数据交换可以用User系列系统变量实现
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2004-9-18 23:51:35 | 显示全部楼层
Public Sub BlockInsert(Name As String)
On Error Resume Next
Dim pLisp As String
Dim obj As VLAX
Dim pnt(2) As Double
Set obj = New VLAX
If BlockScale <= 0 Then BlockScale = 1
Set pObj = ThisDrawing.ModelSpace.InsertBlock(pnt, Name, BlockScale, BlockScale, BlockScale, 0)
obj.EvalLispExpression "(setq ed (entget (handent """ & pObj.Handle & """)))"
pLisp = "(while (not (= (caddr " & _
"(setq pTime (grread t) " & _
"pSt (car pTime) " & _
"pnt (cond ((= pSt 25) (entdel (cdr (assoc -1 ed))) (List 0 0 -1)) ((= pSt 3) (List 0 0 -1)) ((= pSt 5) (cadr pTime)) (t (List 0 0 1))))) -1)) " & _
"(setq ed (subst (cons 10 pnt) (assoc 10 ed) ed)) " & _
"(entmod ed) " & _
") "
obj.EvalLispExpression pLisp
Set obj = Nothing
End Sub
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

发表于 2004-9-26 22:26:11 | 显示全部楼层
回楼上。把LSP写到ACAD。LSP里面。或者在ACAD。LSP里加上(LOAD “LSP文件路径”)
然后在CAD设置里面 把“每次重新加载ACAD。LSP”勾上。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-29 07:27 , Processed in 0.426411 second(s), 49 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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