| Purpose | Add an auto-checkbox to a dialog. This is typically used to indicate a True/False or on/off selection, and is common in dialogs that offer choices of options to a user. | ||||||||||||||||||||||||||
| Syntax | CONTROL ADD CHECKBOX, hDlg, id&, txt$, x, y, xx, yy [, [style&] [, [exstyle&]]] [[,] CALL callback] | ||||||||||||||||||||||||||
| hDlg | Handle of the dialog in which the checkbox will be created. The dialog will become the parent of the control. | ||||||||||||||||||||||||||
| id& | Unique identifier for the control in the range 1 to 65535, frequently specified with numeric equates for clarity of the code. For example, the equate %DisableUser is more informative than a literal value such as 497. Best practice suggests identifiers should start at 100 to avoid conflict with any of the standard predefined identifiers. | ||||||||||||||||||||||||||
| txt$ | Text to be displayed next to the checkbox. An ampersand (&) may be included in txt$ to specify a hot-key. See the Remarks section below. | ||||||||||||||||||||||||||
| x, y | 
 | ||||||||||||||||||||||||||
| xx | Integer expression, variable, or numeric literal value, specifying the width of the control. The width is given in the same terms (pixels or dialog units) as the parent dialog. The most common value used in the Microsoft Dialog Editor and Visual Studio is 40 dialog units. | ||||||||||||||||||||||||||
| yy | Integer expression, variable, or numeric literal value, specifying the height of the control. The height is given in the same terms (pixels or dialog units) as the parent dialog. The most common value used in the Microsoft Dialog Editor and Visual Studio is 14 dialog units. | ||||||||||||||||||||||||||
| style& | Primary style of the checkbox control. The default checkbox style comprises %BS_LEFT, %BS_VCENTER, and %WS_TABSTOP. The default style is used only if both the primary and extended parameters are omitted from the statement. For example: CONTROL ADD CHECKBOX, hDlg, id&, txt$, 100, 100, 40, 14, , , _ CALL CheckboxCallback() ' Use default styles Custom style values replace the default values. That is, they are not additional to the default style values - your code must specify all necessary primary and extended style parameters. The primary checkbox style value can be a combination of any values below, combined together with the OR operator to form a bitmask: 
 | ||||||||||||||||||||||||||
| exstyle& | Extended style of the checkbox control. The default extended checkbox style comprises %WS_EX_LEFT. The default extended style is used if both the primary and extended parameters are omitted from the CONTROL ADD CHECKBOX statement, in the same manner as style& above. The extended checkbox style value can be a combination of any values below, combined together with the OR operator to form a bitmask: 
 | ||||||||||||||||||||||||||
| callback | Optional statement to designate the name of a Callback Function to handle all %WM_COMMAND messages for the control. If a callback for the control is not designated, you must create a Callback Function for the dialog to process notification messages from your checkbox. In general, when the control Callback Function processes a message, it should return TRUE (non-zero) to prevent the message being passed unnecessarily to the dialog callback (if one exists). The dialog callback should also return TRUE if the notification message is processed by that Callback Function. Otherwise, the DDT engine processes unhandled messages. | ||||||||||||||||||||||||||
| Remarks | If the ampersand (&) character appears in the txt$ parameter, the letter that follows will be displayed underscored. This adds a control accelerator (hot-key) to enable the user to directly "click" a control, simply by pressing and holding the ALT key while pressing the specified hot-key. For example, "O&ption " makes ALT+p the hot-key. When the user clicks a control, a message is sent to the Callback Function designated for the control. If there is no Callback Function designated, the message is sent to the callback for the dialog. If the control callback processes the notification message, it should return TRUE (non-zero) to prevent the message being passed needlessly to the dialog callback, and eventually to the DDT engine itself. Notification messages are sent to the Callback Function, with CBMSG = %WM_COMMAND, CBCTL holding the ID (id&) of the control, and CBCTLMSG holding the following values: 
 When a Callback Function receives a %WM_COMMAND message, it should explicitly test the value of CBCTL and CBCTLMSG to guarantee it is responding appropriately to the notification message. | ||||||||||||||||||||||||||
| See also | Dynamic Dialog Tools, CONTROL ADD CHECK3STATE, CONTROL ADD OPTION, CONTROL GET CHECK, CONTROL SET CHECK |