Pues eso, que si quieres usar los cuadros de diálogo de la clase TaskDialog en tus aplicaciones de .NET (C# o Visual Basic) debes usar .NET 5 o superior, al menos para acceder a las clases directamente, pero si te pasa como me pasó ayer a mí que quería usarlo en una aplicación de .NET Framework 4.8.1, pues… sigue leyendo 😉
Esta captura (de la página explicativa de TaskDialog de WindowsControls) te muestra cómo son estos cuadros de diálogo que hicieron su aparición en Windows Vista.
Como ya te he dicho, .NET 5.0 y superior incluye la clase TaskDialog y sus derivados, pero en este caso voy a usar un paquete de NuGet, que está actualizado en este mismo año 2023: WindowsAPICodePack. La versión a la hora de escribir esta entrada en el blog es la v7.0.4 publicada el 26 de febrero de 2023 por Peter William Wagner, (aka Wagnerp).
Para usar las clases agrega ese paquete de NuGet a tu proyecto y ya lo tendrás disponible.
Aquí te pongo un código de ejemplo en Visual Basic para usar ese cuadro de diálogo de forma parecida a como usarías MessageBox.Show.
''' <summary> ''' Mostrar el cuadro de diálogo usando TaskDialog. ''' </summary> ''' <param name="header">El texto de cabecera.</param> ''' <param name="texto">El texto principal.</param> ''' <param name="caption">El texto de la ventana.</param> ''' <param name="buttons">Los botones a mostrar.</param> ''' <param name="icon">El icono a mostrar.</param> ''' <returns>Un valor de tipo TaskDialogResult.</returns> Public Shared Function MostrarDialogo(header As String, texto As String, Optional caption As String = Nothing, Optional buttons As TaskDialogStandardButtons = TaskDialogStandardButtons.Ok, Optional icon As TaskDialogStandardIcon = TaskDialogStandardIcon.Information) As TaskDialogResult If String.IsNullOrEmpty(caption) Then caption = header End If Dim taskDialogMain As TaskDialog = New TaskDialog With { .Caption = caption, .InstructionText = header, .Text = texto, .Cancelable = True, .StandardButtons = buttons, .Icon = icon } Dim tdr As TaskDialogResult = taskDialogMain.Show() Return tdr End Function
Y la forma de usar este método sería algo así:
If fPrincipal.MostrarDialogo("Cerrar VentasPlayaWin", "¿Seguro que quieres cerrar la aplicación de VentasPlayaWin?", Nothing, Microsoft.WindowsAPICodePack.Dialogs.TaskDialogStandardButtons.Yes Or Microsoft.WindowsAPICodePack.Dialogs.TaskDialogStandardButtons.No, Microsoft.WindowsAPICodePack.Dialogs.TaskDialogStandardIcon.Warning) = Microsoft.WindowsAPICodePack.Dialogs.TaskDialogResult.Yes Then Me.Close() fPrincipal.Current.Close() End If
En este caso, fPrincipal es la clase donde está definido el método MostrarDialogo mostrado anteriormente.
No es tan intuitivo como las clases de .NET, ya que es más al estilo del API de Windows, pero… para salir del paso te puede servir y ya es cuestión tuya simplificar los botones, iconos, etc.
Si tengo tiempo prepararé un proyecto tanto para Visual Basic como C# con ejemplos de cómo usar las otras opciones de las notas al pie, enlaces, etc. Pero mientras tanto puedes ver los ejemplos de cómo usar esta API en GitHub: Windows-API-Code-Pack-1.1.
Los ejemplos concretos de TaskDialog para Visual Basic y C# están en esta carpeta: TaskDialogDemo.
Espero que te sea de utilidad. 😊
Ya sabes si quieres hacer un donativo para seguir manteniendo el blog del Guille, usa este enlace. Gracias 🙏🏻
Nos vemos.
Guillermo