乐筑天下

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

选择集存在的BUG及解决方法

[复制链接]

158

主题

2315

帖子

10

银币

顶梁支柱

Rank: 50Rank: 50

铜币
2951
发表于 2003-10-27 15:51:00 | 显示全部楼层 |阅读模式
创建选择集时如果选择集重名则会出错,这个大家都是知道的。
一般的处理方法是通过检查选择集中是否有同名的选择集,如果有则清空选择集。
这个方法大家一直在用,而且实用函数中也提供了一个专用的函数来解决这个问题。
但目前还存在 一个BUG。
当用户点击打开文件对话框,但又点了对话框中的取消键取出(也就是本来想打开文件,但最后没有打开,又回到原来的图中)。这时该函数就存在问题。
这时选择集的ss.Count属性以及Item等属性均会出错。
这个问题以前有网友提过,但没有认真去对待,现在解决如下:
大家创建选择集后试图使用ss.Count,如果出错,则进行进一步处理,将选择集删除,再重建。如果没有出错,则直接通过,以下为实现的函数
  1. Function CreatSSet() As AcadSelectionSet
  2.     Dim ss As AcadSelectionSet
  3.     Dim i  As Integer
  4.     On Error Resume Next
  5.     Set ss = ThisDrawing.SelectionSets.Add("mccad")
  6.     If Err Then
  7.         Err.Clear
  8.         Set ss = ThisDrawing.SelectionSets("mccad")
  9.         ss.Clear
  10.     End If
  11.     i = ss.Count
  12.     If Err Then
  13.         ss.Delete
  14.         Err.Clear
  15.         Set ss = ThisDrawing.SelectionSets.Add("mccad")
  16.     End If
  17.     Set CreatSSet = ss
  18. End Function
回复

使用道具 举报

41

主题

657

帖子

9

银币

中流砥柱

Rank: 25

铜币
821
发表于 2003-10-27 18:27:00 | 显示全部楼层
这个问题倒是没有注意!
回复

使用道具 举报

发表回复

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

本版积分规则

  • 微信公众平台

  • 扫描访问手机版

  • 点击图片下载手机App

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

GMT+8, 2025-6-29 12:28 , Processed in 0.418499 second(s), 68 queries .

© 2020-2025 乐筑天下

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