乐筑天下

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

永无止境的命令

[复制链接]

12

主题

64

帖子

3

银币

初露锋芒

Rank: 3Rank: 3Rank: 3

铜币
112
发表于 2006-11-1 19:54:05 | 显示全部楼层 |阅读模式
我一直在通过观看 BeginCommand、ObjectAdd 和 EndCommand 事件来捕捉到将某些项目添加到绘图中的过程。在触发 EndCommand 事件时,我将处理感兴趣的项目。
现在,在 2007 年,默认情况下,“复制”命令设置为“多个”。
因此,如果用户启动 copy 命令,则会触发 begin 命令事件。
当他们单击目标时,将为每个添加的对象触发对象添加事件。
如果他们点击鼠标右键或输入键,则将触发endcommand事件,一切都很好。
但是,如果他们在丢弃项目一次或多次后按 Escape 键,则 endcommand 事件永远不会触发。
在我看来,每个开始的命令都应该结束。即使通过取消命令结束。
有没有人找到解决这个新问题的方法?

本帖以下内容被隐藏保护;需要你回复后,才能看到!

游客,如果您要查看本帖隐藏内容请回复
回复

使用道具 举报

170

主题

1424

帖子

8

银币

顶梁支柱

Rank: 50Rank: 50

铜币
2119
发表于 2006-11-1 20:38:24 | 显示全部楼层
尝试一下并适应它。它消除了所有的错误陷阱。
基本原则是:在命令开始时设置一个布尔值,然后在命令结束时将其设置为false。如果begincommand的布尔值为真,则endcommand不会被触发。
  1. Option Explicit
  2. Private PrevLayer As AcadLayer
  3. Private CmdActive As Boolean
  4. Function EscPrompt() As Boolean
  5.     Dim varCancel As Variant
  6.     varCancel = ThisDrawing.GetVariable("LASTPROMPT")
  7.     If InStr(1, varCancel, "*Cancel*")  0 Or _
  8.         InStr(1, varCancel, "")  0 Then 'this takes care of vbarun, toolbarsetc w/ ^C^C
  9.         If CmdActive > 0 Then
  10.             EscPrompt = True
  11.         End If
  12.     End If
  13.    
  14. End Function
  15. Public Property Get oPrevLayer() As AcadLayer
  16.     If IsObject(PrevLayer) Then
  17.         If PrevLayer Is Nothing Then
  18.             Set oPrevLayer = ThisDrawing.Layers("0")
  19.             Set PrevLayer = ThisDrawing.ActiveLayer
  20.         End If
  21.     End If
  22.     Set oPrevLayer = PrevLayer
  23. End Property
  24. Public Property Let oPrevLayer(l As AcadLayer)
  25.     Set PrevLayer = l
  26. End Property
  27. Public Sub AcadDocument_BeginCommand(ByVal CommandName As String)
  28.     Dim oLayer As AcadLayer
  29.       
  30.     If CmdActive Then
  31.         If EscPrompt Then
  32.             ThisDrawing.ActiveLayer = oPrevLayer
  33.         End If
  34.     End If
  35. Select Case UCase(CommandName)
  36.    ' blnActive = False
  37.         
  38.         Case "BHATCH"
  39.             Set oLayer = ThisDrawing.Layers("T-Hatch")
  40.             CmdActive = True
  41.             ThisDrawing.ActiveLayer = oLayer
  42.             
  43.     End Select
  44.    
  45. End Sub
  46. Private Sub AcadDocument_EndCommand(ByVal CommandName As String)
  47. If CmdActive Then CmdActive = False
  48.     Select Case UCase(CommandName)
  49.         Case "BHATCH"
  50.             ThisDrawing.ActiveLayer = oPrevLayer
  51.         
  52.         Case Else
  53.             Exit Sub
  54.     End Select
  55.    
  56.    Set PrevLayer = Nothing
  57. End Sub

启动Hatch命令时,绘制矩形并观察图层特性管理器。后来试着逃跑。修复不是直接的,画另一个矩形并观察它的变化。
回复

使用道具 举报

170

主题

1424

帖子

8

银币

顶梁支柱

Rank: 50Rank: 50

铜币
2119
发表于 2006-11-4 14:06:30 | 显示全部楼层
马克,如果你没有答案,我发现布尔技术可以很好地处理多个命令。
它需要一个集合集,并且ObjectAdded子中给出的项目被添加到这个集合中。
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-7-6 20:18 , Processed in 0.904852 second(s), 58 queries .

© 2020-2025 乐筑天下

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