BrewManNH Posted March 19, 2015 Posted March 19, 2015 (edited) What's not working? I just tested this, found out that you're using the wrong flag for your msgbox. The flag #48 corresponds to $MB_ICONWARNING, when you use that by itself it tells AutoIt to create a msgbox with one button and the warning icon inside it. If you want both buttons to show up, you have to use one of the flags that has more than one button displayed. If you replace your _MsgBoxEx(48, with _MsgBoxEx(52, then it will show both buttons with the correct text on them. BTW, if you only specify text for 2 buttons and use a 3 button message box flag, the first button's text won't change. Edited March 19, 2015 by BrewManNH TheDcoder 1 If I posted any code, assume that code was written using the latest release version unless stated otherwise. Also, if it doesn't work on XP I can't help with that because I don't have access to XP, and I'm not going to.Give a programmer the correct code and he can do his work for a day. Teach a programmer to debug and he can do his work for a lifetime - by Chirag GudeHow to ask questions the smart way! I hereby grant any person the right to use any code I post, that I am the original author of, on the autoitscript.com forums, unless I've specifically stated otherwise in the code or the thread post. If you do use my code all I ask, as a courtesy, is to make note of where you got it from. Back up and restore Windows user files _Array.au3 - Modified array functions that include support for 2D arrays. - ColorChooser - An add-on for SciTE that pops up a color dialog so you can select and paste a color code into a script. - Customizable Splashscreen GUI w/Progress Bar - Create a custom "splash screen" GUI with a progress bar and custom label. - _FileGetProperty - Retrieve the properties of a file - SciTE Toolbar - A toolbar demo for use with the SciTE editor - GUIRegisterMsg demo - Demo script to show how to use the Windows messages to interact with controls and your GUI. - Latin Square password generator
TheDcoder Posted March 20, 2015 Posted March 20, 2015 Thanks EasyCodeIt - A cross-platform AutoIt implementation - Fund the development! (GitHub will double your donations for a limited time) DcodingTheWeb Forum - Follow for updates and Join for discussion
KaFu Posted March 20, 2015 Posted March 20, 2015 (edited) Works fine for me, except that flag=48 only displays one button. _MsgBoxEx(1+48, "Test", "Taste", -1, -1, "Pest", "Paste") P.S.: Upsa, didn't saw the answer on page 2 of the thread ... Edited March 20, 2015 by KaFu TheDcoder 1 OS: Win10-22H2 - 64bit - German, AutoIt Version: 3.3.16.1, AutoIt Editor: SciTE, Website: https://funk.eu AMT - Auto-Movie-Thumbnailer (2024-Oct-13) BIC - Batch-Image-Cropper (2023-Apr-01) COP - Color Picker (2009-May-21) DCS - Dynamic Cursor Selector (2024-Oct-13) HMW - Hide my Windows (2024-Oct-19) HRC - HotKey Resolution Changer (2012-May-16) ICU - Icon Configuration Utility (2018-Sep-16) SMF - Search my Files (2024-Oct-20) - THE file info and duplicates search tool SSD - Set Sound Device (2017-Sep-16)
chinadoug Posted November 20, 2023 Posted November 20, 2023 I found this wasn't working when trying to set a button text using Chinese characters while running Arabic Windows. What I discovered after a lot of poking around was that the following change fixed the issue. The original code inside _CBT_MsgBoxProc() function If _WinAPI_GetDlgItem($h_msgbox, $iid) Then DllCall("User32.dll", "int", "SetDlgItemText", "hwnd", $h_msgbox, _ "int", $iid, "str", $__aMsgBoxText[$iid]) EndIf should be changed to If _WinAPI_GetDlgItem($h_msgbox, $iid) Then DllCall("User32.dll", "int", "SetDlgItemTextW", "hwnd", $h_msgbox, _ "int", $iid, "wstr", $__aMsgBoxText[$iid]) EndIf This uses the Unicode version of the SetDlgItemText function, SetDlgItemTextW, and instead of passing a "str", it needs to pass a "wstr".
TimRude Posted September 7, 2024 Posted September 7, 2024 I know this is a very late arrival to the party but I found and fixed a bug in the MsgBoxUDF.au3 file that others might find helpful. The bug only appears if you use the _MsgBoxEx function to set your position and button texts all in one command rather than using the _MsgBox_SetWindowPos, _MsgBox_SetButtonText, _MsgBox series of function calls. In the _MsgBoxEx function, it attempts to determine which flag (1 through 6) you are using with the msgbox to know how many buttons you have to work with. It does this with this snippet of code: Local $i_button_flag = 0 For $iflag = 1 To 6 If BitAND($i_flag, $iflag) = $iflag Then $i_button_flag = $iflag ExitLoop EndIf Next There's a logical flaw in this code snippet. As written, it tests the possible values in order of 1, 2, 3, 4, 5, 6 to see which is a bitwise match with the flag passed in. However, when starting with the lowest possible number, the first test is BitAND(flag, 1). In this case, if the flag is 1, 3, or 5, this test will return 1 since BitAND(1,1) = 1, BitAND(3,1) = 1, and BitAND(5,1) = 1. In binary mode, it's BitAND(0001,0001) which returns 0001; BitAND(0011,0001) which returns 0001; and BitAND(0101,0001) which returns 0001. All of these return 1 since they all have the the right-most bit as 1. So if the msgbox was supposed to be either $MB_OKCANCEL (1), $MB_YESNOCANCEL (3), or $MB_RETRYCANCEL (5), the code snippet is always going to think it was $MB_OKCANCEL. And as such, the button renaming doesn't work properly if $MB_YESNOCANCEL (with three buttons) was actually the intended flag. The logic fix is simple. Test the possible flag values starting at the highest (6) and working back down to the lowest (1). Like this: Local $i_button_flag = 0 For $iflag = 6 To 1 Step -1 ; <--- change this one line of code If BitAND($i_flag, $iflag) = $iflag Then $i_button_flag = $iflag ExitLoop EndIf Next
Recommended Posts
Create an account or sign in to comment
You need to be a member in order to leave a comment
Create an account
Sign up for a new account in our community. It's easy!
Register a new accountSign in
Already have an account? Sign in here.
Sign In Now