乐筑天下

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

VBA中功能都可以实现,但在VB中还是没有办法捕捉,见代码!

[复制链接]

41

主题

657

帖子

9

银币

中流砥柱

Rank: 25

铜币
821
发表于 2003-12-23 20:30:00 | 显示全部楼层 |阅读模式
Option ExplicitPrivate Declare Function GetAsyncKeyState Lib "user32" (ByVal vKey As Long) As Integer
Private Const VK_ESCAPE = &H1B
Dim acadapp As AcadApplication
Dim acaddoc As AcadDocumentPrivate Sub Form_Load()
Me.Hide
    Dim ESC As Long
    GetAsyncKeyState VK_ESCAPE
    On Error GoTo Err_Control
    Dim Pnt1 As Variant
    Dim Pnt2 As Variant
    Dim line As AcadLine
    Dim varCancel As Variant
    Set acadapp = GetObject(, ".application")
    Set acaddoc = acadapp.ActiveDocument
    Pnt1 = acaddoc.Utility.GetPoint(, vbCr & "选择第一点:")
   
    Do
        Pnt2 = acaddoc.Utility.GetPoint(Pnt1, vbCr & "选择下一点:")
        Set line = acaddoc.ModelSpace.AddLine(Pnt1, Pnt2)
        Pnt1 = Pnt2
    Loop
Exit_Here:
  Exit Sub
Err_Control:
    varCancel = acaddoc.GetVariable("LASTPROMPT")
    ESC = GetAsyncKeyState(VK_ESCAPE)
    Select Case Err.Number
        '按了取消键或其它透明命令
        Case -2147352567
            '如果命令行提示中没有“取消”这样的文字出现
            '一般来说在2002中按了回车或空格都不会出现“取消”
            '则退出
            If InStr(1, varCancel, "*Cancel*")  0 And _
               InStr(1, varCancel, "*取消*")  0 Then
                Err.Clear
                Resume Exit_Here
            '如果按了ESC键,则退出
            ElseIf ESC  0 Then
                Err.Clear
                Resume Exit_Here
            '其它情况下,则恢复。如选择了透明命令,则会出现“取消”
            '字样,但不是按了“取消”键。
            Else
                Err.Clear
                Resume
            End If
        '右键单击或回车或空格。
        '在这里,-2147467259用于AutoCAD 2000 及2002,
        '而-2145320928为2004专用
        Case -2147467259, -2145320928
            Err.Clear
            Resume Exit_Here
        '其它情况,一律退出
        Case Else
            Err.Clear
            Resume Exit_Here
    End Select
End Sub
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-3-15 07:34 , Processed in 0.445645 second(s), 54 queries .

© 2020-2025 乐筑天下

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