找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 1198|回复: 24

[VBA程序]:vb控制acad

[复制链接]
发表于 2004-6-24 22:19:18 | 显示全部楼层 |阅读模式

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

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

×
我通过以下代码在vb6中调用acad,原来用    AppActivate "AutoCAD" 来激活acad使它置于其他窗口前面,没出问题,近来不行了,执行到AppActivate "AutoCAD" 就报错,说是非法函数,还不知道是什么原因。后来改成下面这个就可以了,有没有别的办法激活acad呢?并且做到与acad版本无关?

AcadApp.Visible = True    为什么做不到将autocad在前台显示?


On Error Resume Next
    AppActivate "AutoCAD 2002"
    AppActivate "AutoCAD 2004"
    AppActivate "AutoCAD 2005"
    On Error GoTo 0





  1.     Public AcadApp As Object  '//应用程序对象声明
  2.     Public AcadPre As Object  '//属性设置对象声明
  3.     Public AcadDoc As Object '//CAD文档对象声明
  4.     Public AcadMod As Object  '//模型空间对象声明
  5.     Public AcadPap As Object  '//图纸空间对象声明
  6.    
  7.    
  8. '    Public AcadApp As AutoCAD.AcadApplication '建立Application?象
  9. '    Public AcadDoc As AcadDocument '建立Document?象
  10. '    Public AcadMod As AcadModelSpace '建立Model Space ?象

  11.    On Error Resume Next
  12.     Set AcadApp = GetObject(, "autocad.application")   '若AutoCad已启动 , 则直接得到
  13.     If Err Then
  14.         Err.Clear
  15.         Set AcadApp = CreateObject("autocad.application")   '若AutoCad未启动,则运行它
  16.         If Err Then
  17.             MsgBox Err.Description, , "错误"
  18.             On Error GoTo 0
  19.             Exit Sub
  20.         End If
  21.     End If
  22.     On Error GoTo 0
  23.    
  24.     Set AcadApp = GetObject(, "AutoCAD.Application") '//自动启动autocad程序
  25.     AcadApp.Visible = True '//将autocad在前台显示
  26.     Set AcadPre = AcadApp.Preferences '//属性设置对象初始化
  27.     Set AcadDoc = AcadApp.ActiveDocument '//文档对象初始化
  28.     Set AcadMod = AcadDoc.ModelSpace '//模型空间对象初始化
  29.     Set AcadPap = AcadDoc.PaperSpace '//图纸空间对象初始化
  30.    
  31.     On Error Resume Next
  32.     AppActivate "AutoCAD 2002"
  33.     AppActivate "AutoCAD 2004"
  34.     AppActivate "AutoCAD 2005"
  35.     On Error GoTo 0

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

使用道具 举报

 楼主| 发表于 2004-6-25 09:10:39 | 显示全部楼层
怎么做呢? 比如AcadApp.Version的返回值是  一、 15.06      二、    16.0s (LMS Tech)     ,分别是2002和2004。
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

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

使用道具 举报

 楼主| 发表于 2004-6-25 10:00:21 | 显示全部楼层
太高深了,我很菜的,你又说得这么笼统,不知道怎么做。
用哪个api函数?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-6-25 10:41:30 | 显示全部楼层
Private Declare Function SetWindowLong Lib "user32" Alias "SetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long, ByVal dwNewLong As Long) As Long
Private Declare Function GetWindowLong Lib "user32" Alias "GetWindowLongA" (ByVal hwnd As Long, ByVal nIndex As Long) As Long
Private Declare Function SetWindowPos Lib "user32" (ByVal hwnd As Long, ByVal hWndInsertAfter As Long, ByVal x As Long, ByVal y As Long, ByVal cx As Long, ByVal cy As Long, ByVal wFlags As Long) As Long
Const GWL_STYLE = (-16)
Const WS_CAPTION = &HC00000
Const SWP_FRameCHANGED = &H20
Const SWP_NOMOVE = &H2
Const SWP_NOSIZE = &H1
Const HWND_TOP = 0
Public AcadApp As Object

Private Sub Form_Click()
On Error Resume Next
Set AcadApp = GetObject(, "AutoCAD.Application")   '若AutoCad已启动 , 则直接得到
    If Err Then
        Err.Clear
        Set AcadApp = CreateObject("AutoCAD.Application")   '若AutoCad未启动,则运行它
        If Err Then
            MsgBox Err.Description, , "错误"
            On Error GoTo 0
            Exit Sub
        End If
    End If
    AcadApp.WindowState = 3
    SetWindowPos AcadApp.hwnd, HWND_TOP, 0, 0, 0, 0, SWP_FRameCHANGED Or SWP_NOMOVE Or SWP_NOSIZE

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

使用道具 举报

 楼主| 发表于 2004-6-25 11:37:44 | 显示全部楼层
你真高。怎么这么厉害阿!!

这个语句里 Set AcadApp = GetObject(, "AutoCAD.Application"),引号里的字符是怎么确定的,如果我要获得某个软件是否运行的信息,比如写字板或其它软件,怎么知道Application前面该用什么字符串?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-6-25 11:46:14 | 显示全部楼层
GetObject只能获取ActiveX对象,即提供了ActiveX接口的应用程序
如果是其他软件可能可以调用Api实现(我没试过)
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-6-25 12:01:06 | 显示全部楼层
你是说提供了ActiveX接口的应用程序,会在使用说明里说明这一点吗?如果没说明就没法知道Application前面该用什么字符串?

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

使用道具 举报

发表于 2004-6-25 13:01:19 | 显示全部楼层
最初由 god 发布
[B]你是说提供了ActiveX接口的应用程序,会在使用说明里说明这一点吗?如果没说明就没法知道Application前面该用什么字符串?

怎么你怎么快就知道有人回帖了?该怎么设置? [/B]

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

使用道具 举报

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

使用道具 举报

发表于 2004-6-25 13:12:22 | 显示全部楼层
打住了,再贴就有水贴的嫌疑了,我的工作因为太悠闲,天天都挂在网上的
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-6-25 13:57:41 | 显示全部楼层
http://www.xdcad.net/forum/showt ... d=551299#post551299

这个贴子里说的直接浏览数据库是什么意思?vb能做到吗?
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

发表于 2004-6-25 14:04:54 | 显示全部楼层
Arx的方法和VBA有很大差别,直接浏览数据库在VBA来说是底层操作,不可见,反而用选择集+过滤器还快一些
论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
回复 支持 反对

使用道具 举报

 楼主| 发表于 2004-6-25 16:48:03 | 显示全部楼层
我用下面这段vb6代码的 aa过程 按物件的EntityType属性来判断是否为文字,取出图档中所有文字。
但是执行效率非常低,一秒钟只能检查几十个实体,是什么原因?能更快吗?vb的遍历效率这么低吗?
效率低的是这两个语句
Set retObj = .Item(i)  
a = retObj.EntityType



  1.    Public AcadApp As Object  '//应用程序对象声明
  2.     Public AcadPre As Object  '//属性设置对象声明
  3.     Public AcadDoc As Object '//CAD文档对象声明
  4.     Public AcadMod As Object  '//模型空间对象声明
  5.     Public AcadPap As Object  '//图纸空间对象声明
  6.    
  7.    
  8. '    Public AcadApp As AutoCAD.AcadApplication '建立Application?象
  9. '    Public AcadDoc As AcadDocument '建立Document?象
  10. '    Public AcadMod As AcadModelSpace '建立Model Space ?象

  11. Public Sub DeclareAcad()
  12.     On Error Resume Next
  13.     Set AcadApp = GetObject(, "autocad.application")   '若AutoCad已启动 , 则直接得到
  14.     If Err Then
  15.          Err.Clear
  16.         Set AcadApp = CreateObject("autocad.application")   '若AutoCad未启动,则运行它
  17.         If Err Then
  18.             MsgBox Err.Description, , "错误"
  19.             On Error GoTo 0
  20.             Exit Sub
  21.         End If
  22.     End If
  23.     On Error GoTo 0
  24.    
  25.     Set AcadApp = GetObject(, "AutoCAD.Application") '//自动启动autocad程序
  26.     AcadApp.Visible = True '//将autocad在前台显示
  27.     Set AcadPre = AcadApp.Preferences '//属性设置对象初始化
  28.     Set AcadDoc = AcadApp.ActiveDocument '//文档对象初始化
  29.     Set AcadMod = AcadDoc.ModelSpace '//模型空间对象初始化
  30.     Set AcadPap = AcadDoc.PaperSpace '//图纸空间对象初始化
  31.    
  32.     On Error Resume Next
  33.     AppActivate "AutoCAD"
  34.     AppActivate "AutoCAD 2002"
  35.     AppActivate "AutoCAD 2004"
  36.     AppActivate "AutoCAD 2005"
  37.     On Error GoTo 0

  38. End Sub


  39. Public Sub aa()
  40. qw = Timer
  41. Dim i As Integer
  42. Dim retObj As Object
  43. Form1.StringList.Clear
  44. With AcadApp.ActiveDocument.ModelSpace
  45.     For i = 0 To .Count - 1 Step 1
  46.         Set retObj = .Item(i)
  47.         a = retObj.EntityType
  48.         If a = acText Or a = acMtext Then
  49.             Form1.StringList.AddItem retObj.TextString, 0
  50.         End If
  51.     Next i
  52. End With
  53. Form1.StringList.Refresh
  54. Debug.Print Timer - qw
  55. End Sub

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-9-29 09:28 , Processed in 0.372775 second(s), 59 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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