教程中国
PHOTOSHOP CS9.0中文版 MAYA 8.5 FOR WINDOWS Corel Painter v9.0 Flash MX2004 中文版 Illustrator cs2 中文版
VC++6.0含sp6 中英文版 VB6.0 +sp6 简体中文版 Borland Delphi 7汉化版 MSDN for vb6.0中文版 Visual Studio 2005简体
教程中国下属 文件存储共享专家BIBIDU.COM 提供大型软件,教材,源码,电影,音乐,图书等下载 更多精品请点此进入
  您目前所在位置: 教程中国 >> VB >> 编程实例 >> VB 自定义消息框上的按钮的文字 RSS订阅
VB 自定义消息框上的按钮的文字
教程(视频,书籍)下载:  ASP.NET AutoCAD 数据库 C# ASP java photoshop 网页设计 delphi 3dmax Flash C++ VB 张孝祥 实例   更多请进入BIBIDU搜索
IT搜索引擎   

'/////////////////////////////////////
'自定义消息框上的按钮的文字
'\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\
'鬼龙之舞
'2004-3-1
'以下代码在模块
Option Explicit
Private Declare Function MessageBox Lib "user32" Alias "MessageBoxA" (ByVal hwnd As Long, ByVal lpText As String, ByVal lpCaption As String, ByVal wType As Long) As Long
Private Declare Function SetDlgItemText Lib "user32" Alias "SetDlgItemTextA" (ByVal hDlg As Long, ByVal nIDDlgItem As Long, ByVal lpString As String) As Long
Private Declare Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As Long, ByVal hmod As Long, ByVal dwThreadId As Long) As Long
Private Declare Function UnhookWindowsHookEx Lib "user32" (ByVal hHook As Long) As Long
Private Const WH_CBT = 5
Private Const HCBT_ACTIVATE = 5
Private hHook As Long
Private Function HookProc(ByVal nCode As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
  If nCode = HCBT_ACTIVATE Then
        'HCBT_ACTIVATE时wParam是将被激活的窗口的句柄
        Dim hwnd As Long
        hwnd = wParam
        '设定按钮的文字
        SetDlgItemText hwnd, vbOK, ByVal "确定[&O]"
        SetDlgItemText hwnd, vbCancel, ByVal "取消[&C]"
        SetDlgItemText hwnd, vbYes, ByVal "是[&Y]"
        SetDlgItemText hwnd, vbNo, ByVal "否[&N]"
        SetDlgItemText hwnd, vbAbort, ByVal "放弃[&A]"
        SetDlgItemText hwnd, vbIgnore, ByVal "忽略[&I]"
        SetDlgItemText hwnd, vbRetry, ByVal "重试[&R]"
        '不要再Hook,以免带来不必要的麻烦
        UnhookWindowsHookEx hHook
  End If
  HookProc = 0
End Function
'使用和VB的MsgBox一样的名字,如果你不想使用自定文字格式,只需要移除本模块即可
Public Function MsgBox(Prompt As String, Optional Button As VbMsgBoxStyle = vbOKOnly, Optional Title As String) As VbMsgBoxResult
    If Len(Title) = 0 Then Title = App.Title
    hHook = SetWindowsHookEx(WH_CBT, AddressOf HookProc, App.hInstance, App.ThreadID)
    '注意下面的第一个参数最好传递一个窗口的句柄,当然,让它作为0也可以
    'MsgBox= MessageBox(0, Prompt, Title, Button) '不推荐这样做
    MsgBox = MessageBox(Form1.hwnd, Prompt, Title, Button)
End Function

'窗体部分,
'就如你所见一样,只是像平常一样的用法
Option Explicit
Private Sub Command1_Click()
If MsgBox("你好", vbOKCancel + vbInformation) = vbOK Then
    Call MsgBox("你按了OK", vbInformation)
End If
End Sub

来源:www.upschool.com.cn
作者:鬼龙之舞
关键字:自定义消息框
发表日期:2007-2-9 17:24:06

网页显示有限 阅读全文请下载本文完整版WORD文档

上一篇:VB 建立窗体时所响应的消息   下一篇:


本文的相类似文章
网友评论 查看本文全部评论
笔 名: *
评 论:
最多500字。当前字数:0
联系方式:
验证码:
在学习中进步 在进步中成长 教程中国相随您的成长之路
华腾联合科技股份有限公司版权所有
广告联系:Rosibo@163.com