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日

悬赏问题

  • ¥15 matlab 用yalmip搭建模型,cplex求解,线性化处理的方法
  • ¥15 qt6.6.3 基于百度云的语音识别 不会改
  • ¥15 关于#目标检测#的问题:大概就是类似后台自动检测某下架商品的库存,在他监测到该商品上架并且可以购买的瞬间点击立即购买下单
  • ¥15 神经网络怎么把隐含层变量融合到损失函数中?
  • ¥30 自适应 LMS 算法实现 FIR 最佳维纳滤波器matlab方案
  • ¥15 lingo18勾选global solver求解使用的算法
  • ¥15 全部备份安卓app数据包括密码,可以复制到另一手机上运行
  • ¥20 测距传感器数据手册i2c
  • ¥15 RPA正常跑,cmd输入cookies跑不出来
  • ¥15 求帮我调试一下freefem代码