首页 > 代码库 > API 之 MessageBox

API 之 MessageBox

函数功能:

MessageBox 函数用于显示一个模态对话框,其中包含一个系统图标、 一组按钮和一个简短的特定于应用程序消息,如状态或错误的信息。
消息框中返回一个整数值,该值指示用户单击了哪个按钮。


API 函数原型:

注释:_In_ 说明该参数是输入的,_opt_ 说明该参数是可选参数。

1 int WINAPI MessageBox(2   _In_opt_  HWND hWnd,3   _In_opt_  LPCTSTR lpText,4   _In_opt_  LPCTSTR lpCaption,5   _In_      UINT uType6 );

参数解析:

参数含义
hWnd1. 该消息框的父窗口句柄
2. 如果此参数为NULL,则该消息框没有拥有父窗口
lpText消息框的内容
lpCaption消息框的标题
uType1. 指定一个决定对话框的内容和行为的位标志集
2. 此参数可以通过指定下列标志或标志的组合,来显示消息框中的按钮以及图标


uType参数定义解析:

按钮含义
MB_OK默认值,有一个“确认”按钮在里面
MB_YESNO有“是”和“否”两个按钮在里面
MB_ABORTRETRYIGNORE有“中止”,“重试”和“跳过”三个按钮在里面
MB_YESNOCANCEL有“是”,“否”和“取消”三个按钮在里面
MB_RETRYCANCEL有“重试”和“取消”两个按钮在里面
MB_OKCANCEL有“确定”和“取消”两个按钮在里面



图标含义
MB_ICONEXCLAMATION一个惊叹号出现在消息框: <ignore_js_op>技术分享
MB_ICONWARNING一个惊叹号出现在消息框(同上)
MB_ICONINFORMATION一个圆圈中小写字母i组成的图标出现在消息框: <ignore_js_op>技术分享
MB_ICONASTERISK一个圆圈中小写字母i组成的图标出现在消息框(同上)
MB_ICONQUESTION一个问题标记图标出现在消息框: <ignore_js_op>技术分享
MB_ICONSTOP一个停止消息图标出现在消息框: <ignore_js_op>技术分享
MB_ICONERROR一个停止消息图标出现在消息框(同上)
MB_ICONHAND一个停止消息图标出现在消息框(同上)



默认按钮含义
MB_DEFBUTTON1指定第一个按钮为默认按钮
MB_DEFBUTTON2指定第二个按钮为默认按钮
MB_DEFBUTTON3指定第三个按钮为默认按钮
MB_DEFBUTTON4指定第四个按钮为默认按钮



消息框形态含义
MB_APPLMODAL1. 在 hWnd 参数标识的窗口中继续工作以前,用户一定响应消息框
2. 但是,用户可以移动到其他线程的窗口且在这些窗口中工作
3. 根据应用程序中窗口的层次机构,用户则以移动到线程内的其他窗口
4. 所有母消息框的子窗口自动地失效,但是弹出窗口不是这样
5. 如果既没有指定 MB_SYSTEMMODAL 也没有指定 MB_TASKMODAL,则 MB_APPLMODAL 为默认的
MB_SYSTEMMODAL1. 除了消息框有 WB_EX_TOPMOST 类型,否则 MB_APPLMODAL 和 MB_SYSTEMMODAL 一样
2. 用系统模态消息框来改变各种各样的用户,主要的损坏错误需要立即注意(例如,内存溢出)
3. 如果不是那些与 hWnd 联系的窗口,此标志对用户对窗口的相互联系没有影响
MB_TASKMODAL1. 如果参数 hWnd 为 NULL 的话,那么除了所有属于当前线程高层次的窗口失效外,MB_TASKMODAL 和 MB_APPLMODAL 一样
2. 当调用应用程序或库没有一个可以得到的窗口句柄时,可以使用此标志,但仍需要阻止输入到调用线程的其他窗口,而不是搁置其他线程

 

其他标志含义
MB_DEFAULT_DESKTOP_ONLY1. 接收输入的当前桌面一定是一个默认桌面,否则函数调用失败
2. 默认桌面是一个在用户已经记录且以后应用程序在此上面运行的桌面
MB_HELP1. 把一个 Help 按钮增加到消息框
2. 选择 Help 按钮或按 F1 产生一个 Help 事件
MB_RIGHT文本为右对齐
MB_RTLREADING用在 Hebrew 和 Arabic 系统中从右到左的顺序显示消息和大写文本
MB_SETFOREGROUND1. 消息框变为前景窗口
2. 在内部系统为消息个调用 SetForegroundWindow 函数
MB_TOPMOST消息框用 WS_EX_TOPMOST 窗口类型来创建 MB_SERVICE_NOTIFICATION


返回值:

返回值含义
IDOK用户按下了“确认”按钮
IDCANCEL用户按下了“取消”按钮
IDABORT用户按下了“中止”按钮
IDRETRY用户按下了“重试”按钮
IDIGNORE用户按下了“忽略”按钮
IDYES用户按下了“是”按钮
IDNO用户按下了“否”按钮



链接:http://bbs.fishc.com/forum.php?mod=viewthread&tid=46730&extra=page%3D1%26filter%3Dtypeid%26typeid%3D420

 

API 之 MessageBox