ONLINE HELP
 WINDEVWEBDEV AND WINDEV MOBILE

Help / WLanguage / WLanguage functions / Standard functions / Windows functions / Dialog Box functions
  • Features of the dialog box
  • Line break in the dialog box
  • Miscellaneous
  • Application in the background: Specific case from Android 10
WINDEV
WindowsLinuxUniversal Windows 10 AppJavaReports and QueriesUser code (UMC)
WEBDEV
WindowsLinuxPHPWEBDEV - Browser code
WINDEV Mobile
AndroidAndroid Widget iPhone/iPadIOS WidgetApple WatchMac CatalystUniversal Windows 10 App
Others
Stored procedures
Displays a message in a standard non-blocking dialog box with the answers "Yes" and "No" and calls a WLanguage procedure with the user's response.
Yes/No dialog
Remarks:
  • This is a non-blocking dialog box. The WLanguage code that follows the call to YesNoAsynchronous continues to run. To close the window, the user must validate one of the buttons. When the user clicks one of the buttons, the code of a WLanguage procedure is run.
  • In the WLanguage code following the call to the function, another modal window cannot be opened before closing the dialog box.
  • WINDEV WINDEV allows you to apply the skin template of your project to this dialog box. For more details, see Customizing dialog boxes.
Example
YesNoAsynchronous("Do you want to close this window?", MyProcedure_OKCancel)
 
INTERNAL PROCÉDURE MyProcedure_OKCancel(nResponse int)
IF nResponse = Yes THEN
ToastDisplay("You want to close the window!")
ELSE
ToastDisplay("You don't want to close the window!")
END
END
Syntax
YesNo([<Selected button>, ] <Text> , <WLanguage procedure>)
<Selected button>: Optional integer constant
Button selected by default in the dialog box:
No0selected by default
Yes
(Default value)
1selected by default
<Text>: Character string
Text to display.
<WLanguage procedure>: Name of the procedure or lambda procedure
Name of the WLanguage procedure ("callback" procedure) called when the user clicks one of the buttons in the confirmation window.
This procedure is used to find out which button was clicked, and to run a specific process if necessary.
For more details on this procedure, see Parameters of the procedure used by YesNoAsynchronous.
This WLanguage procedure can correspond to:
  • a name of a global or local procedure,
  • a name of an internal procedure,
  • a lambda procedure.
Remarks

Features of the dialog box

  • The title of the dialog box corresponds to the title of the current window (or page).
    AndroidiPhone/iPad To comply with the system specifications, the title of dialog box is empty by default. To define this title, use NextTitle.
  • To modify or define the title of dialog box, use NextTitle.
  • The message is aligned to the left.
  • The captions of buttons depend on the runtime language of Windows.
  • The maximum number of characters cannot exceed 4096. If a larger string is passed as parameter, it will be truncated.
  • The icon displayed (exclamation mark) cannot be modified.
WINDEV To customize this dialog box (and all the system dialog boxes in your application), check "Customize system windows (Info, YesNo, Confirm, Dialog)" in the "Style" tab of the project description. For more details, see Customizing dialog boxes.

Line break in the dialog box

The CR string (Carriage Return) can be used to force a break to the next line. For example:
YesNoAsynchronous("The XXX form was modified." + CR + ...
"Do you want to save it before exiting?")
You also have the ability to use the syntax of multiline strings. For example:
YesNoAsynchronous(
[
The XXX form has been modified.
 
Do you want to save changes before closing?
], Procedure_OKCancelAsynchronous)

Miscellaneous

  • Timers (TimerSys) are not stopped when this function is called.
  • WINDEV Windows events are not stopped when this function is called.
  • The text of the buttons is displayed in the system language.
  • iPhone/iPad This function must not be used:
    • in the "Resize" event of the window. Otherwise, the application will be locked.
    • in the "Change the orientation" event of the window.
    • in the "Move to the foreground" event associated with the project.
      Remark: However, the function can be used in the "Move to the foreground" event of a window.
    • in a thread.
  • Android The position of the buttons varies according to the Android version. From Android 4.1, the system sets the validation button on the right. DialogAsynchronous is used to define the position of the buttons, if necessary.
Android

Application in the background: Specific case from Android 10

From Android 10, it is no longer possible to open a window when the application is in the background.
YesNoAsynchronous can open a window. If this function is used while the application is in the background, a fatal error will occur.
Tips:
  • It is possible to determine if the application is in the background using InBackgroundMode.
  • If an application needs to interact with the user while it is in the background, the solution is to display a notification (via the Notification type). The application will be brought back to the foreground when the notification is clicked, if the ActivateApplication property is set to True. You can also open a window from the procedure passed to the ActionClick property.
Business / UI classification: UI Code
Component: wd290obj.dll
Minimum version required
  • Version 25
This page is also available for…
Comments
Click [Add] to post a comment

Last update: 02/29/2024

Send a report | Local help