Usar TaskDialog desde .NET Framework 4

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

Y el sol ha dado 66 vueltas desde entonces

Pues eso… 66 vueltas al sol desde que nació un servidor de ustedes. 😊
Un día como hoy me parió mi madre… según escribió mi padre en mi álbum de fotos fue a las 9 de la mañana de un viernes 7 de junio de 1957 (ver foto 1) en el Hospital Civil de Málaga.

Foto 1.

Después de leer esto (foto 2) lo que tuvo que pasar mi madre para «echar fuera» un monstruito de 5,5 KG 😮

Foto 2.

Aquí con dos añitos, jugando con la PlayStation… cómo puedes comprobar, no eran como las de ahora 😅 (foto 3).

Foto 3.

Eso sí, necesité ayuda para saber qué botones apretar… (foto 4)

Foto 4.

Bueno, también tengo fotos actuales, te dejo una de ahora, con mi nieta Mila, que ha sido el mejor regalo de este año 🤤

Foto 5. Con Mila el 4 de junio 2023

Nos vemos.
Guillermo

P.S.
Lo de las vueltas al sol es un «robado» a mi amiga Amanda 😉

He vuelto a activar el Site Kit de Google (los anuncios de AdSense)

Actualizado (02-jun-23 22.46):
Pues parece que ahora no quieren que «monetice» el sitio, así que… ¡Que le den a Google AdSense! 🙄
Así que… ya sabes… PayPaleame algo 😉

Pues eso… lo mismo lo vuelvo a quitar, ya que en realidad lo quité porque a mí no me gustaba que pusieran tantos anuncios, veré si puedo que no se muestren tantos anuncios, tal como he hecho en elguille.info que ahora solo se muestra un anuncio por página (o eso es lo que me parece). También esperaba algo de más actividad por PayPal, pero… nada… ¡me invitan a pocas cervezas virtuales! 😉Y de alguna forma hay que mantener al que mantiene el sitio para que pueda seguir manteniéndolo… no sé si me explico 🤔😅

Dejaré que se activen los anuncios y ya decidiré si molestan mucho o no… si no molestan, los dejo y espero que algo entrará en «la cesta de la compra».

Y ya sabes, si prefieres que elguillemola.com esté sin anuncio, ten la buena costumbre de invitarme al menos una vez al mes a un «mate* virtual» (*mate = ya sabes, u refresco, una birra, un ponche, jajaja)

De todas formas, aquí te dejo el enlace de PayPal para que hagas un donativo si así lo estimas oportuno. Gracias🙏🏻

Escanea este código QR para hacer una donación por PayPal.

Nos vemos.
Guillermo