Click here to Skip to main content
15,070,613 members
Articles / Programming Languages / Visual Basic
Posted 7 Nov 2007


243 bookmarked

VDialog (Vista TaskDialog for Windows XP)

Rate me:
Please Sign up or sign in to vote.
4.91/5 (71 votes)
27 Mar 2013LGPL34 min read
Vista-like TaskDialog control for .NET Framework 2.0, compatible with Windows XP

VDialog using LockSystem feature.

VDialog using LockSystem feature

Sample customized VDialog.

Sample customized VDialog

Sample security VDialog.

Sample security VDialog

Expandable VDialog with footer (RightToLeft property set to RightToLeft.Yes and RightToLeftLayout property set to True).

Expandable VDialog with footer


Many programmers would like to use Windows Vista TaskDialog on earlier systems like Windows 2000/XP. Unfortunately this is not possible.

There are some TaskDialog implementations on the Internet, but none of them are written in VB.NET. I decided to write my own version of a TaskDialog-like form with all the functionality of Vista TaskDialog. It is almost fully compatible with the MessageBox class. And there are some features of Vista TaskDialog implemented (the rest of them will be implemented later). Some features, which are not implemented, can be emulated using custom controls (like radio buttons or progress bar — see the first screenshot above).

Using the Code

The VDialog class is compatible with the MessageBox class so it can be used in the same way, e.g.:

VDialog.Show(Me, "Text", "Caption", MessageBoxButtons.YesNo, MessageBoxIcon.Error)

To customize the appearance of VDialog, one must create a VDialog object, set its properties and then invoke the Show() method, e.g.:

Dim vd As New VDialog()
With vd
    .WindowTitle = "Windows Vista"
    .Owner = Me
    .MainInstruction = "You must click OK button to continue"
    .Buttons = New VDialogButton() _
              { New VDialogButton(VDialogResult.OK), _
                New VDialogButton(VDialogResult.Continue) }
    .MainIcon = VDialogIcon.SecurityShieldBlue
    .DefaultButton = VDialogDefaultButton.None
    .Content = "If you don't know what to do, click Cancel button."
    .LockSystem = True
    .CustomControl = New MyCustomControl()
End With


Almost Full Compatibility with the MessageBox Class

Existing code can be easily changed to one which uses the VDialog class instead of the MessageBox class by changing the MessageBox.Show(…) invocation to the VDialog.Show(…) invocation.

Supported methods:

Show(String) As DialogResult
Show(String, String) As DialogResult
Show(String, String, MessageBoxButtons) As DialogResult
Show(String, String, MessageBoxButtons, MessageBoxIcon) As DialogResult
Show(String, String, MessageBoxButtons, MessageBoxIcon, MessageBoxDefaultButton) _
	As DialogResult
Show(String, String, MessageBoxButtons, MessageBoxIcon, _
	MessageBoxDefaultButton, MessageBoxOptions) As DialogResult
Show(IWin32Window, String) As DialogResult
Show(IWin32Window, String, String) As DialogResult
Show(IWin32Window, String, String, MessageBoxButtons) As DialogResult
Show(IWin32Window, String, String, MessageBoxButtons, MessageBoxIcon) As DialogResult
Show(IWin32Window, String, String, MessageBoxButtons, _
	MessageBoxIcon, MessageBoxDefaultButton) As DialogResult

Advanced Usage

The VDialog class can also be used in another way. One can create a VDialog object and set its properties, such as:

  • Owner — Determines the parent of the VDialog message window.
  • Content, ContentLinks, WindowTitle and MainInstruction — Determines the content of the dialog window which will be displayed, the caption of the window, and the main instruction.
  • Buttons — Determines what buttons will be displayed on the VDialog message window. VDialogButton is a class containing UseCustomText, Text and VDialogResult properties, and also a Click event which is raised when the associated button is clicked (but before closing the window).
  • MainIcon, CustomMainIcon — The image shown at the left side of the window (or right side when right-to-left layout is used).
  • DefaultButton — Determines which button is initially focused.
  • RightToLeft and RightToLeftLayout — Determines whether the layout of the window should be "mirrored".
  • Result — Indicates the return value of the VDialog window.
  • LockSystem — Enables the UAC-like system locking behavior.
  • CustomControl — Provides an easy way to extend the VDialog window. It can be used to emulate the features of TaskDialog which are not supported yet.
  • VerificationText and VerificationFlagChecked — Manages the check box shown at the left side of the buttons. It can be used for "Don't show it again"-like check boxes.
  • Sound — Played when the dialog window is shown.
  • FooterText, FooterLinks, FooterIcon and CustomFooterIcon — Determines the text and the image of the footer.
  • ExpandedInformation, ExpandedInformationLinks, ExpandFooterArea, ExpandedByDefault, ExpandedControlText and CollapsedControlText — determines the look and behavior of the expand control and label with extra information.

Localization Support

The captions of the standard buttons (e.g. OK, Yes, Ignore, etc.) can be easily localized by translating the resources file. The English versions of these captions are contained in the Resources.resx file.


The VDialogIcon class contains twelve read-only fields which provide access to Vista-like images, such as:

  • InformationInformation
  • QuestionQuestion
  • WarningWarning
  • ErrorError
  • SecurityShieldSecurityShield, SecurityShieldBlue, SecurityShieldGray
  • SecuritySuccessSecuritySuccess
  • SecurityQuestionSecurityQuestion
  • SecurityWarningSecurityWarning
  • SecurityErrorSecurityError
  • There is also the None field.

Assigning the VDialogIcon.Security* field (except the SecurityShield) to the MainIcon property of the VDialog class causes the appropriate gradient to be drawn beneath the icon and main instruction.


The VDialogSound class provides access to six sounds (Default, Information, Question, Warning, Error, Security) that can be assigned to the Sound property of the VDialog class. Custom sound can be provided by an object which implements the ISound interface.

Command Links

There is an animated CommandLink control which can be used to build a custom control and then embed it in the VDialog.

Screenshot 5 - Command links


Although the VDialog class provides many useful properties, there are some features of TaskDialog that my VDialog does not implement yet, such as:

  • Full support for CommandLinks
  • RadioButtons
  • ProgressBar
  • Timer

These features can only be obtained by using custom controls.


  • 1.5 (15.10.2008) — Important! This is the last “standalone” version of the control. The next version is included in a new project hosted at CodePlex.
    • Parent window no longer loses focus in certain situations on Windows Vista
    • Added HotForeColor property to the CommandLink control
    • Added German localization (I would be grateful if someone checked it with German Windows Vista)
    • Fixed some bugs
  • 1.4 (02.01.2008)
    • Added support for Links
    • Fixed some bugs
  • 1.3 (12.12.2007)
    • Added partial support for CommandLinks
    • Added support for elevation (shield) icon
    • Fixed some bugs
  • 1.2 (05.12.2007)
    • Added XML documentation
    • Added Close method to the VDialog class
    • Added license
    • Minor bugs fixed
  • 1.1 (18.11.2007)
    • Renamed some properties so they are compliant with TaskDialog
    • Added sounds support
    • Added footer support
    • Added expandable information support
    • Added support for security dialogs
    • Minor bugs fixed
  • 1.0
    • 11.11.2007 — Added Vista-like images
    • 07.11.2007 — First version


This article, along with any associated source code and files, is licensed under The GNU Lesser General Public License (LGPLv3)


About the Author

Lukasz Swiatkowski
Software Developer
Poland Poland
I am a graduate of Wroclaw University of Science and Technology, Poland.

My interests: reading, programming, drawing, Japan, Spain.

Comments and Discussions

QuestionHow can I use in .NET Core? Pin
Sandy Brun16-Nov-20 10:17
MemberSandy Brun16-Nov-20 10:17 
QuestionHow to close dialog with custom button? Pin
Balázs Lengyel2-Nov-17 7:36
MemberBalázs Lengyel2-Nov-17 7:36 
QuestionVDialog (Vista TaskDialog for Windows XP) Pin
Member 1094852215-Jul-14 23:35
MemberMember 1094852215-Jul-14 23:35 
QuestionNew MessageBoxIcon Pin
rojaldearintok1-Apr-14 23:28
Memberrojaldearintok1-Apr-14 23:28 
AnswerRe: New MessageBoxIcon Pin
Lukasz Swiatkowski1-Apr-14 23:54
MemberLukasz Swiatkowski1-Apr-14 23:54 
GeneralRe: New MessageBoxIcon Pin
rojaldearintok6-Apr-14 23:29
Memberrojaldearintok6-Apr-14 23:29 
GeneralRe: New MessageBoxIcon Pin
Lukasz Swiatkowski7-Apr-14 1:46
MemberLukasz Swiatkowski7-Apr-14 1:46 
GeneralRe: New MessageBoxIcon Pin
rojaldearintok8-Apr-14 5:05
Memberrojaldearintok8-Apr-14 5:05 
QuestionSolved Problem ? Pin
Mohamad Mansour15-Jan-14 21:57
MemberMohamad Mansour15-Jan-14 21:57 
AnswerRe: Solved Problem ? Pin
Lukasz Swiatkowski16-Jan-14 0:54
MemberLukasz Swiatkowski16-Jan-14 0:54 
BugReport a bug Pin
Mohamad Mansour4-Jun-13 4:46
MemberMohamad Mansour4-Jun-13 4:46 
GeneralRe: Report a bug Pin
Lukasz Swiatkowski5-Jun-13 20:24
MemberLukasz Swiatkowski5-Jun-13 20:24 
GeneralMy vote of 5 Pin
sumans43242-Nov-12 4:35
Membersumans43242-Nov-12 4:35 
GeneralC# version. Converted ! [modified] Pin
Bill Lee Vn15-Mar-11 1:55
MemberBill Lee Vn15-Mar-11 1:55 
GeneralRe: C# version. Converted ! Pin
Lukasz Swiatkowski15-Mar-11 22:54
MemberLukasz Swiatkowski15-Mar-11 22:54 
GeneralRe: C# version. Converted ! Pin
Bill Lee Vn21-Mar-11 15:53
MemberBill Lee Vn21-Mar-11 15:53 
GeneralRe: C# version. Converted ! Pin
Lukasz Swiatkowski21-Mar-11 20:11
MemberLukasz Swiatkowski21-Mar-11 20:11 
QuestionRe: C# version. Converted ! Pin
Geraldo Magella Junior24-Mar-11 5:20
MemberGeraldo Magella Junior24-Mar-11 5:20 
AnswerRe: C# version. Converted ! [fix] Pin
Xmen Real 26-Aug-11 17:12
professional Xmen Real 26-Aug-11 17:12 
GeneralRe: C# version. Converted ! Pin
Xmen Real 15-May-11 14:43
professional Xmen Real 15-May-11 14:43 
GeneralRe: C# version. Converted ! Pin
Alucia8913-Jun-12 23:36
MemberAlucia8913-Jun-12 23:36 
GeneralRe: C# version. Converted ! Pin
Xmen Real 14-Jun-12 0:00
professional Xmen Real 14-Jun-12 0:00 
GeneralRe: C# version. Converted ! Pin
Lukasz Swiatkowski14-Jun-12 1:38
MemberLukasz Swiatkowski14-Jun-12 1:38 
GeneralRightToLeftLayout in CustomControl Pin
PeaceTiger22-Apr-10 14:02
MemberPeaceTiger22-Apr-10 14:02 
GeneralExcellent, and a question Pin
PeaceTiger22-Apr-10 13:19
MemberPeaceTiger22-Apr-10 13:19 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Praise Praise    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.