明经CAD社区

 找回密码
 注册

QQ登录

只需一步,快速开始

搜索
查看: 3096|回复: 10

[求助]再次提问,关于VB中获取CAD文本

[复制链接]
发表于 2007-5-4 16:53:00 | 显示全部楼层 |阅读模式
这是我发的原贴http://bbs.mjtd.com/forum.php?mod=viewthread&tid=59890,感谢明总!!(看论坛大家都这样叫)
原贴里面是我在一本书上抄的一段代码(实际上我也没全看明白,接触CAD的VB开发才几天,很多东西都不是很明白)
明总提示后我参照CAD开发帮助文档自己写了一段代码,还是有错,再次拜托高手帮忙修改或者提示下啦,真的很急用。
(我要实现的功能,点击command后切换到CAD窗口,提示点选一个单行文本,然后获取该文本的textstring赋给一个VB的文本框)


Dim acadApp As AutoCAD.AcadApplication
Dim AcadDoc As AcadDocument


Private Sub Command1_Click()
StartAcad
Dim OBJdoc As AcadText
Dim ptPick As Variant

Set acadApp = New autocad.AcadApplication

Set AcadDoc = acadApp.ActiveDocument

AcadDoc.Utility.GetEntity OBJdoc, ptPick, "请点选文本"

Text1.Text = OBJdoc.TextString
End Sub

Sub StartAcad()
    Dim acadApp As AcadApplication
    On Error Resume Next

    Set acadApp = GetObject(, "AutoCAD.Application.16")
    If Err Then
        Err.Clear
        Set acadApp = CreateObject("AutoCAD.Application.16")
        If Err Then
            MsgBox Err.Description
            Exit Sub
        End If
    End If
    MsgBox "Now running " + acadApp.Name + " version " + acadApp.Version
End Sub



 楼主| 发表于 2007-5-4 17:02:00 | 显示全部楼层
同一个问题发两个帖子不知道是否违规?
真的是急用这段代码,而且我想这是一个很简单的任务吧(对于已经入门的人来说)。希望有能力帮忙的不吝赐教。
发表于 2007-5-4 22:22:00 | 显示全部楼层

刚刚看到,这样试试:

Dim acadApp As AutoCAD.AcadApplication
Dim AcadDoc As AcadDocument

Private Sub Command1_Click()

'隐藏自身窗体,以把控制权交给CAD
Me.Hide
StartAcad

‘激活CAD窗体进行操作
AppActivate (acadApp.Caption)

Dim OBJdoc As AcadText
Dim ptPick As Variant

Set AcadDoc = acadApp.ActiveDocument

AcadDoc.Utility.GetEntity OBJdoc, ptPick, "请点选文本"

Text1.Text = OBJdoc.TextString

'重新显示自身
Me.Show
End Sub

Sub StartAcad()
    Dim acadApp As AcadApplication’已经定义为模块级变量了,这句必须去掉!
    On Error Resume Next

    Set acadApp = GetObject(, "AutoCAD.Application.16")
    If Err Then
        Err.Clear
        Set acadApp = CreateObject("AutoCAD.Application.16")
        If Err Then
            MsgBox Err.Description
            Exit Sub
        End If
    End If
    MsgBox "Now running " + acadApp.Name + " version " + acadApp.Version
End Sub

发表于 2007-5-4 22:29:00 | 显示全部楼层

再优化一下,声明API,使自身窗体置前:

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

在Me.show后面加上一句:

SetWindowPos Me.hwnd, -1, 0, 0, 0, 0, 3

这样的易用性更好些。

 楼主| 发表于 2007-5-4 22:38:00 | 显示全部楼层
谢谢StartMe,我用你的提示再做做。
 楼主| 发表于 2007-5-4 22:43:00 | 显示全部楼层
能够切换到CAD窗口,但是还有和我先前一样的错误出现。
错误锁定在这句“AcadDoc.Utility.GetEntity OBJdoc, ptPick, "请点选文本"”。
这句是否是书写格式的错误?
 楼主| 发表于 2007-5-4 22:46:00 | 显示全部楼层
提示为“AutoCAD主窗口不可见”
 楼主| 发表于 2007-5-4 23:24:00 | 显示全部楼层
调试发现程序并没有通过点选获得OBJdoc,因为objdoc.textstring仍然为空
发表于 2007-5-5 21:45:00 | 显示全部楼层

运行正常啊,没有错误。

发表于 2007-5-5 21:56:00 | 显示全部楼层

 

你再仔细检查一下是否程序中其它语句的影响,单就这几句是没错误的。

你单独运行这几句试试看。

本帖子中包含更多资源

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

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

本版积分规则

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

GMT+8, 2024-11-26 16:49 , Processed in 0.188847 second(s), 24 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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