HOWTO: Terminate Windows From a 16-Bit VB Application
ID: Q142820
|
The information in this article applies to:
-
Microsoft Visual Basic Professional and Enterprise Editions, 16-bit only, for Windows, version 4.0
SUMMARY
The Microsoft Visual Basic for Windows SendKeys function cannot be used to
close the Microsoft Windows Program Manager in order to terminate Microsoft
Windows. To correctly close Program Manager, you must invoke the
ExitWindows API function, as shown below.
Many software setup or installation programs are designed to exit Windows,
and then restart Windows when the setup or installation is complete. You
can make a Visual Basic program automatically exit Windows and then restart
Windows by passing the EW_RESTARTWINDOWS value to the ExitWindows API
function. The value for the EW_RESTARTWINDOWS constant is &H42.
MORE INFORMATION
You may want to terminate the current Windows session by closing the
Program Manager from within a Visual Basic application. You may think that
you can activate the Program Manager control menu and send the appropriate
key sequences using the Visual Basic SendKeys function. However, this
method does not work because after the Close menu item is chosen, a system
modal dialog box is opened that prompts you to save changes to Program
Manager. A system modal dialog box locks out ALL other programs until it is
satisfied. Therefore, the keystroke you send by using the SendKeys function
never arrives in the dialog box.
To correctly close Program Manager, you must use the ExitWindows API
function. You can declare this API function in a code module name Module1.
Step-by-Step Example
- Start a new project in Visual Basic.
- Draw a Command button on the form.
- Add the following as a single line to Module1:
' Use for Windows 3.11 or Windows for Workgroups 3.11 applications:
Declare Function ExitWindows Lib "user" (ByVal wReturnCode as Long, _
ByVal dwReserved as Integer) as Integer
' Use for Windows 95/98 or Windows NT applications:
Declare Function ExitWindows Lib "user32" alias "ExitWindowsEx" _
(ByVal wReturnCode as Long, ByVal dwReserved as Long) as Long
- Add the following line of code to the command button's Click procedure:
' Use for Windows 3.11 or Windows for Workgroups 3.11 applications:
RetVal% = ExitWindows(0,0)
' Use for Windows 95/98 or Windows NT Applications:
RetVal& = ExitWindows(0&, 0&)
- Run the program.
- Click the Command button.
The ExitWindows API call initiates the standard Windows shutdown procedure.
If all applications agree to terminate, the windows session is terminated
and control returns to MS-DOS. If the ExitWindows API call fails due to an
open MS-DOS session or for some other reason, FALSE is returned. You should
check for this return value and handle it appropriately.
Steps to Reproduce Behavior
- Start a new Project in Visual Basic.
- Draw a Command button on the form.
- In the Command button Click event procedure, add this code:
AppActivate("Program Manager")
SendKeys "%{ }{DOWN 5}{ENTER 2}", 0 'ALT, SPACE, DOWN 5, ENTER 2
- Run the program.
The Program Manager does not close. If you choose the OK button with the
mouse, a message is displayed stating, "Can't quit at this time." If you
choose the Cancel button, a message is displayed stating, "Cannot start
more than one copy of the specified program." These messages are
misleading, but are the result of attempting an unsupported action.
Additional query words:
kbVBp400 kb16bitonly kbVBp kbCtrl
Keywords : kb16bitonly kbCtrl kbVBp kbVBp400 kbGrpVB
Version : WINDOWS:4.0
Platform : WINDOWS
Issue type : kbhowto
|