Display Unicode characters in visual basic 6

User200012

New Member
Joined
Apr 4, 2023
Messages
2
Office Version
  1. 2010
Platform
  1. Windows
Hi, is it possible to display unicode characters in the ansi system in vb6? And especially for the delimiter? For example, I'm using Windows 10 en version, I wrotte data arrays at the end of the exe with a delimiter everything works fine on my english version of WIndows, but when i move my project to the Bulgarian Windows im getting "werfault" error, and it seems that the delimiter is the problem, I tried using ChrW(&H430) Bulgarian character on my English version of Windows, but I still get "?"

attaching a image

Any alternatives?
 

Attachments

  • 22.png
    22.png
    6.3 KB · Views: 29

Excel Facts

Can Excel fill bagel flavors?
You can teach Excel a new custom list. Type the list in cells, File, Options, Advanced, Edit Custom Lists, Import, OK
Sadly I found this:
The Visual Basic Editor does not support Unicode encoding, neither for input, nor for display. Instead, VBE uses a legacy Windows technology of the nineties called ANSI code pages to provide support for international ASCII characters. Windows code pages were gradually superseded when Unicode was implemented in Windows, although they are still supported, both within Windows and other platforms.

But you can try the steps described here:
How to display foreign characters in Excel's Visual Basic Editor
 
Upvote 0
What is the delimiter character you are using ?
BTW, the built-in VB6/VBA Msgbox is an ANSI window so it won't properly display unicode characters.

Use the unicode version of the user32.dll MessageBoxW and pass the pointers to the lpText and lpCaption string arguments.
 
Upvote 0
I wrote this a while ago, but I think it should still work:


It has examples of displaying unicode characters in a messagebox (using the MessageBoxW API that Jaafar refers to above). I'm not at my laptop right now, but can repost the full code when I get a chance.
 
Upvote 0
As promised, I set out below the entirety of my IconMsgBox routine - originally designed to allow for custom icons to msgboxes (inspirted by Jaafar's many examples of customised MsgBoxes), but it can be used to display Unicode characters. There are 5 demo routines included, which show how to display unicode characters (and how to use the related helper functions included below). You can also customise the msgbox buttons.

The following needs to be put into a new standard module.

VBA Code:
' _
    |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||                                                                                     ' _
    ||||||||||||||||||||||||||                                       ||||||||||||||||||||||||||||||||||                                                                                     ' _
    ||||||||||||||||||||||||||             ICONMSGBOX (v1.4)         ||||||||||||||||||||||||||||||||||                                                                                     ' _
    ||||||||||||||||||||||||||                                       ||||||||||||||||||||||||||||||||||                                                                                     ' _
    |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
                                                                                                                                                                                            ' _
    AUTHOR:   Kallun Willock                                                                                                                                                                ' _
    URL:      https://github.com/KallunWillock/JustMoreVBA/blob/main/Boxes/modBox_IconMsgBox.bas                                                                                            ' _
    PURPOSE:  The IconMsgBox is a Unicode-enabled MessageBox that can display a custom icon (ICO file).                                                                                     ' _
              It also features a timeout feature resulting in it closing down after a designated period of time.                                                                            ' _
    LICENSE:  MIT                                                                                                                                                                           ' _
    VERSION:  1.4        19/04/2022         Custom button labels; Right-To-Left text support.                                                                                               ' _
              1.3        07/04/2022         Corrections; Fixed sound notifications; implemented right-justified text;                                                                       ' _
                                            Improved existing demo and added two more samples to demonstrate                                                                                ' _
                                            functionality: including Japanese and simplified Chinese script, custom icon file, etc.                                                         ' _
              1.2        22/03/2022         Improved timeout functiontionality. Fixed 32-bit compatibility.                                                                                 ' _
              1.1        16/03/2022         Added timeout functiontionality. Improved comments and corrected errors.                                                                        ' _
              1.0        18/02/2022         Version 1 uploaded to Github. Compatible with 32-bit and 64-bit Office
                                                                                                                                                                                            ' _
    NOTES:    A return value of 32000 indicates that the user did not press a button.                                                                                                       ' _
              The timeout period is measured in milliseconds, but where a whole number under 60 has been passed                                                                             ' _
              to IconMsgBox for the timeout parameter, that will be interpreted as seconds.
                                                                                                                                                                                            ' _
    TODO:     [X] Add access to system DLL icons               [X] Sound notification                                                                                                       ' _
              [X] Allow use of custom ICO files                [X] Left / Right Justification of content                                                                                    ' _
              [X] Unicode compatibility                        [X] Add unicode conversion compatibility                                                                                     ' _
              [X] Add timeout feature                          [X] Custom button labels                                                                                                     ' _
              [X] RTL Support                                                                                                                                                               ' _
              [ ] Can make use of a fourth button if use the MessageBoxIndirect API:                                                                                                        ' _
                  https://www.codeproject.com/Articles/562/Add-a-Help-Button-to-a-MessageBox

    Option Explicit

    Public Enum ImageDLL
        icn_shell32                 '        C:\Windows\System32\shell32.dll                - 329   icons
        icn_imageres                '        C:\Windows\System32\imageres.dll               - 334   icons
        icn_pifmgr                  '        C:\Windows\System32\pifmgr.dll                 - 38    icons
        icn_accessibilitycpl        '        C:\Windows\System32\accessibilitycpl.dll       - 24    icons
        icn_ddores                  '        C:\Windows\System32\ddores.dll                 - 149   icons
        icn_moricons                '        C:\Windows\System32\moricons.dll               - 113   icons
        icn_explorer                '        C:\Windows\explorer.exe                        - 28    icons
        icn_mmcndmgr                '        C:\Windows\System32\mmcndmgr.dll               - 129   icons
        icn_mmres                   '        C:\Windows\System32\mmres.dll                  - 18    icons
        icn_netcenter               '        C:\Windows\System32\netcenter.dll              - 14    icons
        icn_netshell                '        C:\Windows\System32\netshell.dll               - 165   icons
        icn_networkexplorer         '        C:\Windows\System32\networkexplorer.dll        - 20    icons
        icn_pnidui                  '        C:\Windows\System32\pnidui.dll                 - 43    icons
        icn_sensorscpl              '        C:\Windows\System32\sensorscpl.dll             - 22    icons
        icn_mshtml                  '        C:\Windows\System32\mshtml.dll                 - 27    icons
        icn_diagcpl                 '        C:\Windows\System32\diagcpl.dll                - 9     icons
    End Enum
   
    #If VBA7 Then

        Private Declare PtrSafe Function CallNextHookEx Lib "user32" (ByVal hHook As LongPtr, ByVal nCode As Long, ByVal wParam As LongPtr, lParam As Any) As LongPtr
        Private Declare PtrSafe Function DestroyIcon Lib "user32" (ByVal hIcon As LongPtr) As Long
        Private Declare PtrSafe Function ExtractIcon Lib "SHELL32.DLL" Alias "ExtractIconA" (ByVal hInstance As LongPtr, ByVal lpszExeFileName As String, ByVal nIconIndex As Long) As LongPtr
        Private Declare PtrSafe Function FindWindowEx Lib "user32" Alias "FindWindowExA" (ByVal hWnd1 As LongPtr, ByVal hWnd2 As LongPtr, ByVal lpsz1 As String, ByVal lpsz2 As String) As LongPtr
        Private Declare PtrSafe Function GetClassName Lib "user32" Alias "GetClassNameA" (ByVal hwnd As LongPtr, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long
        Private Declare PtrSafe Function GetCurrentThreadId Lib "KERNEL32" () As Long
        Private Declare PtrSafe Function MessageBoxW Lib "user32" (ByVal hwnd As LongPtr, ByVal lpText As LongPtr, ByVal lpCaption As LongPtr, ByVal uType As Long) As Long
        Private Declare PtrSafe Function MessageBoxTimeoutW Lib "user32.dll" (ByVal hwnd As LongPtr, ByVal lpText As LongPtr, ByVal lpCaption As LongPtr, ByVal uType As Long, ByVal wLanguageID As Long, ByVal lngMilliseconds As Long) As Long
        Private Declare PtrSafe Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As LongPtr, ByVal wMsg As Long, ByVal wParam As LongPtr, lParam As Any) As LongPtr
        Private Declare PtrSafe Function SetDlgItemText Lib "user32" Alias "SetDlgItemTextW" (ByVal hDlg As LongPtr, ByVal nIDDlgItem As Long, ByVal lpString As Any) As Long
        Private Declare PtrSafe Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As LongPtr, ByVal hmod As LongPtr, ByVal dwThreadID As Long) As LongPtr
        Private Declare PtrSafe Function UnhookWindowsHookEx Lib "user32" (ByVal hHook As LongPtr) As Long

        Private pHook                               As LongPtr
        Private hIcon                               As LongPtr
        Private hIconWnd                            As LongPtr
    #Else

        Private Declare Function CallNextHookEx Lib "user32" (ByVal hHook As Long, ByVal CodeNo As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
        Private Declare Function DestroyIcon Lib "user32" (ByVal hIcon As LongPtr) As Long
        Private Declare Function ExtractIcon Lib "SHELL32.DLL" Alias "ExtractIconA" (ByVal hInst As LongPtr, ByVal lpszExeFileName As String, ByVal nIconIndex As Long) As LongPtr
        Private Declare Function FindWindowEx Lib "user32" Alias "FindWindowExA" (ByVal ParenthWnd As Long, ByVal ChildhWnd As Long, ByVal ClassName As String, ByVal Caption As String) As Long
        Private Declare Function GetClassName Lib "user32" Alias "GetClassNameA" (ByVal hwnd As Long, ByVal lpClassName As String, ByVal nMaxCount As Long) As Long
        Private Declare Function GetCurrentThreadId Lib "KERNEL32" () As Long
        Private Declare Function MessageBoxW Lib "user32" (ByVal hwnd As Long, ByVal lpText As Long, ByVal lpCaption As Long, ByVal uType As Long) As Long
        Private Declare Function MessageBoxTimeoutW Lib "user32.dll" (ByVal hwnd As Long, ByVal lpText As Long, ByVal lpCaption As Long, ByVal uType As Long, ByVal wLanguageID As Long, ByVal lngMilliseconds As Long) As Long
        Private Declare Function SendMessage Lib "user32" Alias "SendMessageA" (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Any) As Long
        Private Declare Function SetDlgItemText Lib "user32" Alias "SetDlgItemTextW" (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 pHook                               As Long
        Private hIcon                               As Long
        Private hIconWnd                            As Long

    #End If
   
    Private Const IDOK                              As Long = &H1
    Private Const IDCANCEL                          As Long = &H2
    Private Const IDABORT                           As Long = &H3
    Private Const IDRETRY                           As Long = &H4
    Private Const IDIGNORE                          As Long = &H5
    Private Const IDYES                             As Long = &H6
    Private Const IDNO                              As Long = &H7
   
    Private Const IDPROMPT                          As Long = &HFFFF&
   
    Private Const WH_CBT                            As Long = &H5
    Private Const HCBT_ACTIVATE                     As Long = &H5
    Private Const STM_SETICON                       As Long = &H170
    Private Const MSGBOX_CLASSNAME                  As String = "#32770"
    Private Const MB_SETFOREGROUND                  As Long = &H10000
    Private Const MB_TOPMOST                        As Long = &H40000
    Private Const MB_RIGHT                          As Long = &H80000
    Private Const MB_RTLREADING                     As Long = &H100000
    Private Const ICNMB_ADDBEEP                     As Long = &H10
    Private Const ICNMB_ADDICON                     As Long = &H20
   
    Private mbFlags                                 As Long
    Private Button()                                As String
   
                                                                                                                                  
'      :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

'                                           DEMO ROUTINES

'      ...................................................................................................

    Sub IconMsgBox_Demo1()
    ' IconMsgBox with a 15 second timeout - Unicode compatible (displays Hello World in Japanese script - katakana / hiragana) - uses icon#77 of the ImageRes.dll
       
        Dim Content(1 To 10)                        As String
        Dim Title                                   As String
        Dim IconFilePath                            As String
        Dim HelloWorld_JA                           As Variant
        Dim TimeOutPeriod                           As Long
        Dim YES_JA                                  As String
        Dim NO_JA                                   As String
       
        HelloWorld_JA = Array(12495, 12525, 12540, 12539, 12527, 12540, 12523, 12489)
        YES_JA = GetUnicodeMessage(Array(12399, 12356))
        NO_JA = GetUnicodeMessage(Array(12356, 12356, 12360))
       
        TimeOutPeriod = 15
       
        Title = "Title - IconMsgBox_Demo1 - " & GetUnicodeMessage(HelloWorld_JA)
        Content(1) = "IconMsgBox (v1.4) allows for:"
        Content(3) = "1. Custom icons;"
        Content(4) = "2. Unicode text;"
        Content(5) = "3. Timeout feature;"
        Content(6) = "4. Sound notification;"
        Content(7) = "5. Right-justified text support; and now,"
        Content(8) = "6. Custom button labels!"
        Content(9) = vbNewLine & "This routine uses Icon#177 of the ImageRes.dll library, displays Japanese text in the title and in the button labels, and with timeout set for " & TimeOutPeriod & " seconds."
        Content(10) = vbNewLine & "Note that there is no sound notification and the text is left-justified."
       
        Debug.Print IconMsgBox(Join(Content, vbNewLine), vbYesNo, Array(YES_JA, NO_JA), Title, IconFilePath, icn_imageres, 177, TimeOutPeriod)
       
    End Sub
   
    Sub IconMsgBox_Demo2()
    ' IconMsgBox with no timeout - Unicode compatible (displays Hello World in simplified Chinese script) - uses icon#12 of the ddores.dll -
    ' right-justified content - beep notification - 3 custom button labels
       
        Dim Content(1 To 10)                        As String
        Dim Title                                   As String
        Dim BellIcon                                As String
        Dim HelloWorld_ZHCN                         As Variant
       
        HelloWorld_ZHCN = Array(20320, 22909, -244, 19990, 30028)
        BellIcon = GetUnicodeMessage(128276)
       
        Title = "Title - IconMsgBox_Demo2 - " & GetUnicodeMessage(HelloWorld_ZHCN) & "  " & BellIcon
       
        Content(1) = "IconMsgBox (v1.4) allows for:"
        Content(3) = "1. Custom icons;"
        Content(4) = "2. Unicode text;"
        Content(5) = "3. Timeout feature;"
        Content(6) = "4. Sound notification;"
        Content(7) = "5. Right-justified text support; and now,"
        Content(8) = "6. Custom button labels!"
        Content(9) = vbNewLine & "This routine uses Icon#12 of the ddores.dll library, displays simplified Chinese script in the title, and with no timeout set."
        Content(10) = vbNewLine & "Note that it includes a sound notification " & BellIcon & " and the text is right-justified."
       
        Debug.Print IconMsgBox(Join(Content, vbCr), vbAbortRetryIgnore, Array("Option A", "Option B", "Option C"), Title, , icn_ddores, 12, , , True, True)

    End Sub

    Sub IconMsgBox_Demo3()
    ' IconMsgBox with 20 second timeout - Unicode compatible (displays unicode tick marks) - uses custom icon file, github.ico - left-justified content - no beep
    ' Unicode button labels
       
        Dim Content                                 As String
        Dim Title                                   As String
        Dim IconFilePath                            As String
        Dim TimeOutPeriod                           As Long
        Dim TickMark                                As String
        Dim CROSS_ICON                              As String
        Dim STAR_ICON                               As String
       
        TimeOutPeriod = 20
       
        TickMark = ChrW(10004)
       
        CROSS_ICON = GetUnicodeMessage(10006)
        STAR_ICON = GetUnicodeMessage(10026)
       
        Title = "Title - IconMsgBox_Demo3"
        Content = "IconMsgBox (v1.4) allows for:" & vbNewLine & vbNewLine & TickMark & " Custom icons" & vbNewLine & TickMark & " Unicode text"
        Content = Content & vbNewLine & TickMark & " Timeout feature" & vbNewLine & TickMark & " Sound notification" & vbNewLine & TickMark & " Right-justified text support" & vbNewLine & TickMark & " Custom button labels"
        Content = Content & vbNewLine & vbNewLine & "This routine uses a custom icon file (github.ico), displays unicode characters (tick mark and symbols in the button labels), and has a timeout set for " & TimeOutPeriod & " seconds."
        Content = Content & vbNewLine & vbNewLine & ActiveCell.Value '"Note that there is no sound notification and the text is left-justified."
        IconFilePath = "D:\Github\KallunWillock\JustMoreVBA\Boxes\github.ico"
       
        Debug.Print IconMsgBox(Content, vbYesNoCancel, Array(TickMark, CROSS_ICON, STAR_ICON), Title, IconFilePath, , , TimeOutPeriod)

    End Sub
   
    Sub IconMsgBox_Demo4()
    ' IconMsgBox with no timeout - Unicode compatible (displays unicode tick marks) - custom width - atttempts to use non-existant custom icon file, nogithub.ico -
    ' left-justified content - beep - no custom button labels.
   
        Dim Content                                 As String
        Dim Title                                   As String * 100
        Dim IconFilePath                            As String
        Dim TickMark                                As String
        Dim BellIcon                                As String
       
        TickMark = ChrW(10003)
        BellIcon = GetUnicodeMessage(128276)
       
        Title = "Title - IconMsgBox_Demo4 " & BellIcon
        Content = "IconMsgBox (v1.4) allows for:" & vbNewLine & vbNewLine & TickMark & " Custom icons" & vbNewLine & TickMark & " Unicode text"
        Content = Content & vbNewLine & TickMark & " Timeout feature" & vbNewLine & TickMark & " Sound notification" & vbNewLine & TickMark & " Right-justified text support"
        Content = Content & vbNewLine & vbNewLine & "This routine demonstrates that " & vbNewLine & "there is some (limited) flexibility " & vbNewLine & "in setting the width of the IconMsgBox."
        Content = Content & vbNewLine & vbNewLine & "It also demonstrates " & vbNewLine & "the default icon if no valid icon is " & vbNewLine & "found at the designated filepath."
        Content = Content & vbNewLine & vbNewLine & "Note that it includes a sound" & vbNewLine & "notification " & BellIcon & " and the text is left-justified."
       
        IconFilePath = "C:\PATHTOFILE\nogithub.ico"
       
        Debug.Print IconMsgBox(Content, vbOKOnly, , Title, IconFilePath, icn_shell32, 13, , , True)

    End Sub
   
    Sub IconMsgBox_Demo5()
    ' IconMsgBox with no timeout - Unicode compatible (displays unicode tick marks) - custom width - atttempts to use non-existant custom icon file, nogithub.ico - left-justified content - no beep
   
        Dim Content                                 As String
        Dim Title                                   As String * 100
        Dim IconFilePath                            As String
        Dim TickMark                                As String
        Dim BellIcon                                As String
       
        TickMark = ChrW(10003)
        BellIcon = GetUnicodeMessage(128276)
       
        Title = "Title - IconMsgBox_Demo5"
       
        Content = Content & vbNewLine & vbNewLine & "It also demonstrates " & vbNewLine & "the default icon if no valid icon is " & vbNewLine & "found at the designated filepath."
        Content = Content & vbNewLine & vbNewLine & "Note that it includes a sound" & vbNewLine & "notification " & BellIcon & " and the text is left-justified."
       
        Debug.Print IconMsgBox(Content, vbOKOnly, , Title, , icn_shell32, 14, , True, True, True)

    End Sub
                                                                                                                                  
'      :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

'                                    MAIN ICONMSGBOX ROUTINE

'      ...................................................................................................

    Public Function IconMsgBox(ByVal Content As String, _
                      Optional ByVal Style As VbMsgBoxStyle = vbOKOnly, _
                      Optional ByVal ButtonLabels As Variant, _
                      Optional ByVal Title As String = "", _
                      Optional ByVal IconFilePath As String, _
                      Optional ByVal IconLibrary As ImageDLL, _
                      Optional ByVal IconNumber As Long = 0, _
                      Optional ByVal Timeout As Long = -1, _
                      Optional ByVal RightToLeft As Boolean = False, _
                      Optional ByVal BeepNotification As Boolean = False, _
                      Optional ByVal RightJustified As Boolean = False) As VbMsgBoxResult

        Dim IconPath                                As String
        Dim TargetThreadID                          As Long
        Dim Counter                                 As Long
       
        mbFlags = -1
       
        ' Custom Button Labels - assign any captions to the buttons.
               
        If IsArray(ButtonLabels) = True Then
            mbFlags = Style
            ReDim Button(1 To UBound(ButtonLabels) + 1)
            For Counter = LBound(ButtonLabels) To UBound(ButtonLabels)
                Button(Counter + 1) = ButtonLabels(Counter)
            Next
        End If
      
             
        If Len(Dir(IconFilePath)) = 0 Then IconFilePath = ""
              
        If IconFilePath = vbNullString Then
           
            Dim ImageLibraryPaths                   As Variant
           
            ImageLibraryPaths = Array("System32\shell32.dll", "system32\imageres.dll", "system32\pifmgr.dll", "system32\accessibilitycpl.dll", "system32\ddores.dll", "system32\moricons.dll", _
                                      "explorer.exe", "system32\mmcndmgr.dll", "system32\mmres.dll", "system32\netcenter.dll", "system32\netshell.dll", "system32\networkexplorer.dll", _
                                      "system32\pnidui.dll", "system32\sensorscpl.dll", "System32\mshtml.dll", "System32\diagcpl.dll")

            IconPath = Environ("SystemRoot") & Application.PathSeparator & ImageLibraryPaths(IconLibrary)
        Else
            IconPath = IconFilePath
            IconNumber = 0
        End If

        hIcon = ExtractIcon(0&, IconPath, IconNumber)
       
        If hIcon <> 0 Then Style = Style Or ICNMB_ADDICON
        Style = IIf(BeepNotification, Style Or ICNMB_ADDBEEP, Style)
        Style = IIf(RightJustified, Style Or MB_RIGHT, Style)
        Style = IIf(RightToLeft, Style Or MB_RTLREADING, Style)
        Style = Style Or MB_TOPMOST
       
        ' Sets the hook
       
        TargetThreadID = GetCurrentThreadId()
        pHook = SetWindowsHookEx(WH_CBT, AddressOf MsgBoxHookProc, 0&, TargetThreadID)
       
        ' API determined by requirement for timeout functionality
       
        If Timeout < 60 Then Timeout = Timeout * 1000
       
        If Timeout > -1 Then
            IconMsgBox = MessageBoxTimeoutW(0, StrPtr(Content), StrPtr(Title), Style, 0, Timeout)
        Else
            IconMsgBox = MessageBoxW(0, StrPtr(Content), StrPtr(Title), Style)
        End If
       
        DestroyIcon hIcon
       
    End Function

    Private Function MsgBoxHookProc(ByVal uMsg As Long, ByVal wParam As LongPtr, ByVal lParam As Long) As LongPtr

        Dim ClassNameSize                           As Long
        Dim CurrWindowClassName                     As String
        
        ' Hook the process
        MsgBoxHookProc = CallNextHookEx(pHook, uMsg, wParam, lParam)

        If uMsg = HCBT_ACTIVATE Then
            CurrWindowClassName = Space(32)
          
            ' This function call will populate both the CurrWindowClassName and ClassNameSize variables:- 6 and #32770 respectively
            ClassNameSize = GetClassName(wParam, CurrWindowClassName, 32)
          
            If Left(CurrWindowClassName, ClassNameSize) <> MSGBOX_CLASSNAME Then Exit Function
          
            ' If hIcon has been assigned a pointer then get the handle for the STATIC control (which houses the icon),
            ' and then assign that icon to the msgbox with SendMessage - STM_SETICON
         
            If hIcon <> 0 Then
                hIconWnd = FindWindowEx(wParam, 0&, "Static", vbNullString)
                SendMessage hIconWnd, STM_SETICON, hIcon, ByVal 0&
            End If
           
            ' Assign captions to buttons, if any
           
            Select Case mbFlags
                Case -1
                    ' Do Nothing
                Case vbOKOnly
                    SetDlgItemText wParam, IDOK, StrPtr(Button(1))
                Case vbOKCancel
                    SetDlgItemText wParam, IDOK, StrPtr(Button(1))
                    SetDlgItemText wParam, IDCANCEL, StrPtr(Button(2))
                Case vbAbortRetryIgnore
                    SetDlgItemText wParam, IDABORT, StrPtr(Button(1))
                    SetDlgItemText wParam, IDRETRY, StrPtr(Button(2))
                    SetDlgItemText wParam, IDIGNORE, StrPtr(Button(3))
                Case vbYesNoCancel
                    SetDlgItemText wParam, IDYES, StrPtr(Button(1))
                    SetDlgItemText wParam, IDNO, StrPtr(Button(2))
                    SetDlgItemText wParam, IDCANCEL, StrPtr(Button(3))
                Case vbYesNo
                    SetDlgItemText wParam, IDYES, StrPtr(Button(1))
                    SetDlgItemText wParam, IDNO, StrPtr(Button(2))
                Case vbRetryCancel
                    SetDlgItemText wParam, IDRETRY, StrPtr(Button(1))
                    SetDlgItemText wParam, IDCANCEL, StrPtr(Button(2))
            End Select
           
            ' Unhook the process
            UnhookWindowsHookEx pHook
       
        End If

    End Function

'      :::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::

'                                    HELPER FUNCTIONS

'      ...................................................................................................


    Private Function GetUnicodeMessage(ByVal UnicodeCharacters As Variant) As String
   
        Dim Counter                                 As Long
        Dim TempMessage                             As String
       
        If IsArray(UnicodeCharacters) = False Then UnicodeCharacters = Array(UnicodeCharacters)
       
        For Counter = LBound(UnicodeCharacters) To UBound(UnicodeCharacters)
            TempMessage = TempMessage & UnicodeConverter(UnicodeCharacters(Counter))
        Next
       
        GetUnicodeMessage = TempMessage
       
    End Function
   
    Private Function UnicodeConverter(ByVal Code As Variant) As String
       
        If VBA.IsNumeric(Code) = False Then
            If Left(Code, 2) = "U+" Then
                Code = CLng(Replace(Code, "U+", "&H"))
            ElseIf Left(Code, 2) = "0x" Then
                Code = CLng(Replace(Code, "0x", "&H"))
            Else
                Code = CLng("&H" & Code)
            End If
        End If
       
        ' Conversion algorithm below partially based on code by GSerg at
        ' https://stackoverflow.com/questions/57158679/alternative-of-chrw-function
        ' Revised to allow for negative values (see Demo2, comma) | Sourced: 07/04/2022
        If (Code >= &H8000 And Code <= &HD7FF&) Or (Code >= &HE000& And Code <= &HFFFF&) Then
            UnicodeConverter = ChrW(Code)
        Else
            Code = Code - &H10000
            UnicodeConverter = ChrW(&HD800 Or (Code \ &H400&)) & ChrW(&HDC00 Or (Code And &H3FF&))
        End If
       
    End Function
 
Upvote 0

Forum statistics

Threads
1,215,325
Messages
6,124,252
Members
449,149
Latest member
mwdbActuary

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top