前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Excel催化剂开源第44波-窗体在Show模式下受Excel操作影响变为最小化解决方式

Excel催化剂开源第44波-窗体在Show模式下受Excel操作影响变为最小化解决方式

作者头像
Excel催化剂
发布2021-08-19 15:52:09
2750
发布2021-08-19 15:52:09
举报
文章被收录于专栏:Excel催化剂Excel催化剂

在Excel催化剂的许多功能中,都会开发窗体用于给用户更友好的交互使用,但有一个问题,困扰许久,在窗体上运行某些代码后,中途弹出下MessageBox对话框给用户做一些简单的提示或交互时,发现程序运行结束后,窗体本来是显示在前端最顶层的,却变为最小化在任务栏中。

这个问题带来非常不好的用户体验,弄到最后,都不太敢向用户发出MessageBox对话框之类的提示,或者干脆使用ShowDialog的模式显示,总之非常不爽。

最近,尝试着一个简单的处理,程序结束后,通过先Hide隐藏窗体,再重新Show显示窗体,没想到就这么简单的处理,竟然成功达到预期效果,窗体就算中途有MessageBox,有选择Excel单元格区域等操作,窗体仍然显示最前方。

附上图形类型选择的一小段源代码。

代码语言:javascript
复制
        private void SelectMatchShapes(List<string> selectShpNames)
        {

            if (selectShpNames.Count > 0)
            {
                this.CurrentSht.Shapes.Range[selectShpNames.ToArray()].Select();
            }
            else
            {
                this.CurrentSht.Cells[1].Select();//没有图形选中就选择单元格。
            }

            this.Hide();
            this.Show();
        }

结语

有时,一个简单的处理,就能带上一个非常大的体验改善,此篇应该是开源分享最简单的,但若有人在我之前发现此答案,给予回复,对笔者来说,这些真是旧旱逢甘露一般地滋润。

会者不难,难者不会,放到这上面来说有点小题大作了,但现实就是许多这样,看似简单,如果没人指引,一直摸黑到放弃为止,希望你不是VSTO摸黑后放弃的那一位。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-05-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Excel催化剂 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 结语
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档