• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

介绍一款C#中可携带附加消息的增强消息框(MessageBoxEx)

c# 搞代码 4年前 (2022-01-09) 14次浏览 已收录 0个评论

一个可携带附加消息的增强消息框MessageBoxEx分享给大家,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

————–201507160917更新—————

无意中发现标准消息框在Windows7是有声音的,只是在Windows server 2008(R2)无声,而我用的刚好是后者,所以误以为是MessageBeep API在所有NT6系统都不工作造成~汗,有人在stackoverflow也提过这问题。但我仍然决定使用PlaySound API,不做修改
将声音处理交给ProcessIcon方法负责。之前考虑松耦合,所以将MessageBoxIcon和声音分开处理,但其实声音就是根据前者而来,两者天然就是耦合的,分开处理多此一举

————–201507091034更新—————

首先感谢猿友E204在回复中的反馈。

解决双击【详细信息】按钮造成的Checked状态改变问题,办法是让ToggleButton忽略WM_LBUTTONDBLCLK消息
修正收起详细信息区逻辑,改为直接取用plAttachZone.Height。之前是取ExpandHeight,会造成视觉体验问题

————–201507082014原文(已更新)—————

适用于:.net 2.0+的Winform项目

样子:

有损录制+制图的原因不可能原样展示出真实效果,可至文章结尾下载Demo体验。

功能和特点:

  • 相对父窗体居中

  • 可附带附加消息。附加消息可以是string和Exception类型,【详细信息】按钮会根据是否传入附加信息显示和隐藏。传入Exception实例时,呈现的是exception.ToString(),也就是可能携带StackTrace信息,所以如果你只是想呈现异常文本,还是老实传入ex.Message

  • 展开/收起附加信息时有动画效果。实用为王的你亦可设置EnableAnimate=false关闭动画效果

  • 在Windows Server 2008 R2(未测试其它服务器系统)也有本文来源gao*daima.com搞@代#码&网6声音反馈。标准消息框在个人系统(XP/Win7等)是有声音的,但在srv08却没有。同时亦提供了EnableSound属性允许你关闭声音反馈

  • 移除了标准MessageBox提供的IWin32Window、MessageBoxOptions和Help相关参数,原因是我用不到,懒得实现

  • 可拖拉改变消息框尺寸,消息文本和附加文本会随窗体大小重排。这是标准消息框未提供的能力。改变尺寸分两种情况有不同的行为:①详细信息未展开时,改变的是主消息区大小;②详细信息展开时,改变的是详细信息区的大小

总体来说,此消息框比较适合用在需要反馈大量消息文本的场合,用标准消息框的话,文本太多可能会使消息框超出屏幕大小,比如codeproject.com上这位老兄举的例子,由于标准消息框不具备改变窗体大小的能力,将导致部分消息无法让用户看到。而就算没有超出屏幕,一下子让用户面对那么多消息文字,体验也不地道。使用本消息框就可以解决此类问题,比如可以将扼要信息显示在主消息区,将大量的明细消息(例如批量处理中的单项处理情况)、次要消息、异常信息等放置在详细信息区,由用户或IT支持人员自己去展开获取这些信息。同时,在没有附加消息的时候,你仍然可以像标准消息框一样使用它,所以,如果你跟我一样不会用到标准消息框的IWin32Window、MessageBoxOptions和Help相关参数的话,基本上你可以在整个项目中全程用此消息框替换掉标准消息框,别忘了相比标准消息框,它还具备了可缩放、相对父窗体居中等额外能力。总言之,你值得拥有。至于如果你担心性能问题,这个~我想这么说,我对自己的代码质量还是有点信心的。也希望能得大侠指出槽点,感激!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:介绍一款C#中可携带附加消息的增强消息框(MessageBoxEx)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址