乐筑天下

搜索
欢迎各位开发者和用户入驻本平台 尊重版权,从我做起,拒绝盗版,拒绝倒卖 签到、发布资源、邀请好友注册,可以获得银币 请注意保管好自己的密码,避免账户资金被盗
查看: 164|回复: 9

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

[复制链接]

2

主题

9

帖子

1

银币

初来乍到

Rank: 1

铜币
17
发表于 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 .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

回复

使用道具 举报

2

主题

9

帖子

1

银币

初来乍到

Rank: 1

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

使用道具 举报

37

主题

151

帖子

1

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
299
发表于 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
回复

使用道具 举报

37

主题

151

帖子

1

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
299
发表于 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
这样的易用性更好些。
回复

使用道具 举报

2

主题

9

帖子

1

银币

初来乍到

Rank: 1

铜币
17
发表于 2007-5-4 22:38:00 | 显示全部楼层
谢谢StartMe,我用你的提示再做做。
回复

使用道具 举报

2

主题

9

帖子

1

银币

初来乍到

Rank: 1

铜币
17
发表于 2007-5-4 22:43:00 | 显示全部楼层
能够切换到CAD窗口,但是还有和我先前一样的错误出现。
错误锁定在这句“AcadDoc.Utility.GetEntity OBJdoc, ptPick, "请点选文本"”。
这句是否是书写格式的错误?
回复

使用道具 举报

2

主题

9

帖子

1

银币

初来乍到

Rank: 1

铜币
17
发表于 2007-5-4 22:46:00 | 显示全部楼层
提示为“AutoCAD主窗口不可见”
回复

使用道具 举报

2

主题

9

帖子

1

银币

初来乍到

Rank: 1

铜币
17
发表于 2007-5-4 23:24:00 | 显示全部楼层
调试发现程序并没有通过点选获得OBJdoc,因为objdoc.textstring仍然为空
回复

使用道具 举报

37

主题

151

帖子

1

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

铜币
299
发表于 2007-5-5 21:45:00 | 显示全部楼层
运行正常啊,没有错误。
回复

使用道具 举报

37

主题

151

帖子

1

银币

后起之秀

Rank: 20Rank: 20Rank: 20Rank: 20

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

p32ssovdziq.jpg

p32ssovdziq.jpg




30hdmjxjdj2.jpg

30hdmjxjdj2.jpg


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

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

QQ|关于我们|小黑屋|乐筑天下 繁体中文

GMT+8, 2025-7-7 17:20 , Processed in 1.258894 second(s), 75 queries .

© 2020-2025 乐筑天下

联系客服 关注微信 帮助中心 下载APP 返回顶部 返回列表