在一个继承了 CDialogImpl 和 IDispEventImpl 的对话框类里用SINK_ENTRY_INFO将excel的SelectionChange事件映射到一个函数,在接收到excel的SelectionChange事件后弹出一个messagebox,但执行时出现问题:单击excel单元格或列(也就是SelectionChange)不会弹出messagebox,只有双击单元格才会弹出,而且是将双击之前的单击操作一股脑的全响应了,也就是弹出了好几个messagebox,这迟到的响应是怎么回事?请问有人遇到过这种情况吗?迟点会把代码贴上来。
根据你描述的问题,看起来可能是因为你的事件处理函数(在接收到excel的SelectionChange事件后弹出一个messagebox的函数)在接收到事件后没有立即处理,而是等待了某个条件(例如,等待用户双击单元格)才处理。
具体来说,当用户单击一个单元格或列时,你的函数可能只是记录了这个事件,而没有立即弹出messagebox。然后,当用户双击一个单元格时,你的函数才弹出messagebox,而且可能会一次弹出多个,这是因为在双击之前可能有多个单击事件被记录下来。
这可能是由于你的代码在某个地方存在错误,导致事件处理被延迟。我建议你检查你的代码,特别是与事件处理和弹出messagebox相关的部分。
如果可能的话,你可以尝试使用调试器来跟踪你的代码的执行过程,看看在单击和双击事件中究竟发生了什么。这可能会帮助你找到问题的根源。
此外,你也可以考虑在接收到每个SelectionChange事件后立即弹出messagebox,而不是等待用户双击单元格。这样,每个单击事件都会立即得到处理,而不会导致多个messagebox的弹出。
希望这些信息对你有所帮助!如果你需要更多的帮助,请随时向我提问。