qq_40745500 2023-09-10 10:41 采纳率: 100%
浏览 23
已结题

用ATL编写excel插件接收excel的SelectionChange事件,不能正确执行?

在一个继承了 CDialogImpl 和 IDispEventImpl 的对话框类里用SINK_ENTRY_INFO将excel的SelectionChange事件映射到一个函数,在接收到excel的SelectionChange事件后弹出一个messagebox,但执行时出现问题:单击excel单元格或列(也就是SelectionChange)不会弹出messagebox,只有双击单元格才会弹出,而且是将双击之前的单击操作一股脑的全响应了,也就是弹出了好几个messagebox,这迟到的响应是怎么回事?请问有人遇到过这种情况吗?迟点会把代码贴上来。

  • 写回答

2条回答 默认 最新

  • 呈两面包夹芝士 2023-09-10 10:43
    关注

    根据你描述的问题,看起来可能是因为你的事件处理函数(在接收到excel的SelectionChange事件后弹出一个messagebox的函数)在接收到事件后没有立即处理,而是等待了某个条件(例如,等待用户双击单元格)才处理。

    具体来说,当用户单击一个单元格或列时,你的函数可能只是记录了这个事件,而没有立即弹出messagebox。然后,当用户双击一个单元格时,你的函数才弹出messagebox,而且可能会一次弹出多个,这是因为在双击之前可能有多个单击事件被记录下来。

    这可能是由于你的代码在某个地方存在错误,导致事件处理被延迟。我建议你检查你的代码,特别是与事件处理和弹出messagebox相关的部分。

    如果可能的话,你可以尝试使用调试器来跟踪你的代码的执行过程,看看在单击和双击事件中究竟发生了什么。这可能会帮助你找到问题的根源。

    此外,你也可以考虑在接收到每个SelectionChange事件后立即弹出messagebox,而不是等待用户双击单元格。这样,每个单击事件都会立即得到处理,而不会导致多个messagebox的弹出。

    希望这些信息对你有所帮助!如果你需要更多的帮助,请随时向我提问。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 10月17日
  • 已采纳回答 10月9日
  • 创建了问题 9月10日