明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 8213|回复: 16

一个结合Lisp的拖动例子

  [复制链接]
发表于 2004-5-14 11:36:00 | 显示全部楼层 |阅读模式
Lisp函数:,先导入一下
  1. (defun Drag( pBlock / ppnt ed ped)
  2. (defun GetPoint( / a pnt )
  3.    (setq a (grread t))
  4.    (setq pnt (list 0 0 1))
  5.    (if (= 3 (car a)) (setq pnt (list 0 0 -1)))
  6.    (if (= 5 (car a)) (setq pnt (cadr a)))
  7.    pnt
  8.   )
  9.    (while (not (= (caddr (setq ppnt (GetPoint)))   -1))
  10.    (setq ed (entget (handent pBlock)))
  11.    (setq ped (list 10 (car ppnt) (cadr ppnt) (caddr ppnt)))
  12.    (setq ed (subst ped (assoc 10 ed) ed))
  13.    (entmod ed)
  14.    )
  15. )
测试(由于拖动在Lisp中做好了,不需频繁调用Vlax类,应该不会使AutoCAD崩溃):
  1. Sub Test()
  2.        Dim obj As VLAX
  3.        Dim c(2) As Double
  4.        Dim pObj As AcadBlockReference
  5.        Set obj = New VLAX
  6.        Set pObj = ThisDrawing.ModelSpace.InsertBlock(c, "123", 1, 1, 1, 0)
  7.        a = "(drag " & Chr(34) & pObj.Handle & Chr(34) & ")"
  8.        obj.EvalLispExpression (a)
  9.        Set obj = Nothing
  10. End Sub

评分

参与人数 1威望 +1 金钱 +10 贡献 +5 激情 +5 收起 理由
mccad + 1 + 10 + 5 + 5 【精华】好程序

查看全部评分

发表于 2004-5-15 14:05:00 | 显示全部楼层
看不懂啊~~~


是不是插入图块时能显示图块?
 楼主| 发表于 2004-5-15 19:33:00 | 显示全部楼层
差不多是这个意思



思路是在VBA里插入一个块


再通过Vlax类调用Lisp函数Drag做拖动


模拟Move命令的操作


(当然没有Move做的好,因为Lisp毕竟不是我的强项,只懂点皮毛)
 楼主| 发表于 2004-5-16 14:40:00 | 显示全部楼层
改良版(不需导入Lisp函数)
  1. Public Sub BlockInsert(Name As String)
  2.        Dim pLisp As String
  3.        Dim obj As VLAX
  4.        Dim pnt(2) As Double
  5.        Set obj = New VLAX
  6.        Set pObj = ThisDrawing.ModelSpace.InsertBlock(pnt, Name, 1, 1, 1, 0)
  7.        obj.EvalLispExpression "(setq ed (entget (handent " & ToStr(pObj.Handle) & ")))"
  8.        pLisp = "(while (not (= (caddr " & _
  9.                        "(setq pTime (grread t) " & _
  10.                                    "pSt (car pTime) " & _
  11.                                    "pnt (cond ((= pSt 3) (List 0 0 -1)) ((= pSt 5) (cadr pTime)) (t (List 0 0 1)))))   -1)) " & _
  12.                        "(setq ed (subst (cons 10 pnt) (assoc 10 ed) ed)) " & _
  13.                        "(entmod ed) " & _
  14.                        ") "
  15.        obj.EvalLispExpression pLisp
  16.        Set obj = Nothing
  17. End Sub
  1. Public function ToStr(ByVal str) As String
  2.        ToStr = Chr(34) & str & Chr(34)
  3. End Function
  1. Sub test()
  2.        BlockInsert "123"
  3. End Sub
发表于 2004-5-23 16:10:00 | 显示全部楼层
2002怎么没有VLAX类?
发表于 2004-5-23 17:07:00 | 显示全部楼层
vlax 如何引用?


"Dim obj As VLAX"
 楼主| 发表于 2004-5-23 17:10:00 | 显示全部楼层
Dim obj As VLAX
Set obj = New VLAX
发表于 2004-5-23 18:09:00 | 显示全部楼层
执行到"Dim obj As VLAX"是显示用户类型未定义。也就是说你的代码不能直接运行(cad2000)。请指教,谢谢。
 楼主| 发表于 2004-5-23 18:10:00 | 显示全部楼层
VLAX类未导入
发表于 2004-5-23 18:14:00 | 显示全部楼层
究竟怎么导入?我对vlax一窍不通。


要想运行你的代码,还要设置些什么?谢谢
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

GMT+8, 2024-11-25 12:41 , Processed in 0.156828 second(s), 25 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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