DOCUMENT:Q105006 05-FEB-2000 [foxpro] TITLE :How to Use the MsgBox() Function in FOXTOOLS.FLL PRODUCT :Microsoft FoxPro PROD/VER:WINDOWS:2.5x,2.6x,3.0 OPER/SYS: KEYWORDS:kbcode ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Visual FoxPro for Windows, version 3.0 - Microsoft FoxPro for Windows, versions 2.5x, 2.6x ------------------------------------------------------------------------------- SUMMARY ======= The MsgBox() function in FOXTOOLS.FLL displays a message in a dialog box, waits for the user to choose a button, and returns a value indicating which button was chosen. By using the MsgBox() function, you can take advantage of the Windows default message dialog boxes. Another benefit of using the MsgBox() function is that it does not create a new READ level. Below is syntax information about MsgBox() and a code example. NOTE: In FoxPro 2.x, when you are using the MsgBox() function in a project, the FOXTOOLS.FLL file must be listed, or you will receive an "Undefined reference" error message. In Visual Foxpro, however, FOXTOOLS.FLL isn't required in order to use the MESSAGEBOX() Function. For more information, see the MESSAGEBOX() topic in online Help. MORE INFORMATION ================ Function Syntax --------------- MsgBox(,,<type>) The MsgBox() function takes these arguments: 1. <msg> - Character expression displayed as the message in the dialog box. 2. <title> - Character expression displayed in the title bar of the dialog box. 3. <type> - Numeric expression that controls the buttons and icons to display in the dialog box. This number is derived by adding the numbers from each group of values. For example, number and type of buttons+icon style+default button= type. MsgBox displays a maximum of 1024 characters. Longer messages are truncated after the 1024th character. Message strings longer than 255 characters with no intervening spaces are truncated after the 255th character. MsgBox breaks lines automatically at the right edge of the dialog box. To set line breaks manually, place a carriage return (ANSI character 13) and a linefeed (ANSI character 10) before the first character of the text that is to begin each new line. The argument type is the sum of values that specify the number and type of buttons to display, the icon style to use, and the identity of the default button. The following table illustrates the values used and the meaning of each group of values: Value Meaning ------------------------------------------------- Number and type of buttons -------------------------- 0 Display OK button only 1 Display OK and Cancel buttons 2 Display Abort, Retry, and Ignore buttons 3 Display Yes, No, and Cancel buttons 4 Display Yes and No buttons 5 Display Retry and Cancel buttons Icon style ---------- 0 Display no icon 16 Display Critical Message icon 32 Display Warning Query icon 48 Display Warning Message icon 64 Display Information Message icon Default button -------------- 0 First button is default 256 Second button is default 512 Third button is default The first group of values (1-5) describes the number and type of buttons displayed in the dialog box; the second group (0, 16, 32, 48, 64) describes the icon style; and the third group (0, 256, 512) determines which button is the default. When adding numbers to create a final value for the argument type, use only one number from each group. The value returned by the MsgBox() function indicates which button has been chosen, as shown in the following table: Value Button chosen ---------------------- 1 OK 2 Cancel 3 Abort 4 Retry 5 Ignore 6 Yes 7 No If the dialog box displays a Cancel button, pressing the ESC key has the same effect as choosing Cancel. Sample Code ----------- SET LIBRARY TO SYS(2004)+"FOXTOOLS.FLL" ADDITIVE msg="Do you want to continue?" title="User Input Needed" userchoice=MSGBOX(msg,title,276) * 276 is created from 4+16+256 * (Display Yes and No Buttons)+(Display Critical Message Icon) * + (Second Button is Default) IF userchoice=6 WAIT WINDOW 'User has chosen "YES"' ELSE WAIT WINDOW 'User has chosen "NO"' ENDIF RELEASE LIBRARY SYS(2004)+"FOXTOOLS.FLL" Additional query words: FoxWin VFoxWin 2.50 2.50a 2.50b 2.60 2.60a alert ====================================================================== Keywords : kbcode Technology : kbVFPsearch kbAudDeveloper kbFoxproSearch kbVFP300 Version : WINDOWS:2.5x,2.6x,3.0 ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 2000.