How can I show a message box with details in WinForms?

You need to set following properties of Form to create a custom Dialog/Message window.

  1. AcceptButton
  2. CancelButton
  3. FormBorderStyle=FixedDialog
  4. MaximizeBox=False
  5. MinimizeBox=False
  6. ShowIcon=False
  7. ShowInTaskBar=False
  8. StartPosition=CenterParent

Now, use ShowDialog() method to show custom dialog.

MyDialog dialog=new MyDialog();
DialogResult result=dialog.ShowDialog();
if(result == DialogResult.OK)
{
  //
}

For more information on Dialog read MSDN article - Dialog Boxes (Visual C#)


Based on the answer above (which I upvoted) I wrote the following. Paste this into a form you generated using a VS template and it should work, maybe with few tweaks.

My code:

using System;
using System.Windows.Forms;

namespace MessageBoxWithDetails
{
    /// <summary>
    /// A dialog-style form with optional colapsable details section
    /// </summary>
    public partial class MessageBoxWithDetails : Form
    {
        private const string DetailsFormat = "Details {0}";

    public MessageBoxWithDetails(string message, string title, string details = null)
    {
        InitializeComponent();

        lblMessage.Text = message;
        this.Text = title;

        if (details != null)
        {
            btnDetails.Enabled = true;
            btnDetails.Text = DownArrow;
            tbDetails.Text = details;
        }
    }

    private string UpArrow
    {
        get
        {
            return string.Format(DetailsFormat, char.ConvertFromUtf32(0x25B4));
        }
    }

    private string DownArrow
    {
        get
        {
            return string.Format(DetailsFormat, char.ConvertFromUtf32(0x25BE));
        }
    }

    /// <summary>
    /// Meant to give the look and feel of a regular MessageBox
    /// </summary>
    public static void Show(string message, string title, string details = null)
    {
        new MessageBoxWithDetails(message, title, details).ShowDialog();
    }

    protected override void OnLoad(EventArgs e)
    {
        base.OnLoad(e);

        // Change these properties now so the label is rendered so we get its real height
        var height = lblMessage.Height;
        SetMessageBoxHeight(height);
    }

    private void SetMessageBoxHeight(int heightChange)
    {
        this.Height = this.Height + heightChange;
        if (this.Height < 150)
        {
            this.Height = 150;
        }
    }

    private void btnClose_Click(object sender, EventArgs e)
    {
        this.Close();
    }

    private void btnDetails_Click(object sender, EventArgs e)
    {
        // Re-anchoring the controls so they stay in their place while the form is resized
        btnCopy.Anchor = AnchorStyles.Top;
        btnClose.Anchor = AnchorStyles.Top;
        btnDetails.Anchor = AnchorStyles.Top;
        tbDetails.Anchor = AnchorStyles.Top;

        tbDetails.Visible = !tbDetails.Visible;
        btnCopy.Visible = !btnCopy.Visible;

        btnDetails.Text = tbDetails.Visible ? UpArrow : DownArrow;

        SetMessageBoxHeight(tbDetails.Visible ? tbDetails.Height + 10 : -tbDetails.Height - 10);
    }

    private void btnCopy_Click(object sender, EventArgs e)
    {
        Clipboard.SetText(tbDetails.Text);
    }
}

Designer auto generated code (it should give you an idea regarding what to put in the form if you don't want to paste it):

namespace MessageBoxWithDetails
{
    partial class MessageBoxWithDetails
    {
        /// <summary>
        /// Required designer variable.
        /// </summary>
        private System.ComponentModel.IContainer components = null;
        /// <summary>
        /// Clean up any resources being used.
        /// </summary>
        /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
        protected override void Dispose(bool disposing)
        {
            if (disposing && (components != null))
            {
                components.Dispose();
            }
            base.Dispose(disposing);
        }

        #region Windows Form Designer generated code

        /// <summary>
        /// Required method for Designer support - do not modify
        /// the contents of this method with the code editor.
        /// </summary>
        private void InitializeComponent()
        {
            this.btnClose = new System.Windows.Forms.Button();
            this.btnDetails = new System.Windows.Forms.Button();
            this.btnCopy = new System.Windows.Forms.Button();
            this.lblMessage = new System.Windows.Forms.Label();
            this.tbDetails = new System.Windows.Forms.TextBox();
            this.SuspendLayout();
            // 
            // btnClose
            // 
            this.btnClose.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) 
            | System.Windows.Forms.AnchorStyles.Right)));
            this.btnClose.Location = new System.Drawing.Point(267, 37);
            this.btnClose.Name = "btnClose";
            this.btnClose.Size = new System.Drawing.Size(75, 23);
            this.btnClose.TabIndex = 0;
            this.btnClose.Text = "Close";
            this.btnClose.UseVisualStyleBackColor = true;
            this.btnClose.Click += new System.EventHandler(this.btnClose_Click);
            // 
            // btnDetails
            // 
            this.btnDetails.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) 
            | System.Windows.Forms.AnchorStyles.Right)));
            this.btnDetails.Enabled = false;
            this.btnDetails.Location = new System.Drawing.Point(12, 37);
            this.btnDetails.Name = "btnDetails";
            this.btnDetails.Size = new System.Drawing.Size(75, 23);
            this.btnDetails.TabIndex = 1;
            this.btnDetails.Text = "Details";
            this.btnDetails.UseVisualStyleBackColor = true;
            this.btnDetails.Click += new System.EventHandler(this.btnDetails_Click);
            // 
            // btnCopy
            // 
            this.btnCopy.Anchor = ((System.Windows.Forms.AnchorStyles)(((System.Windows.Forms.AnchorStyles.Bottom | System.Windows.Forms.AnchorStyles.Left) 
            | System.Windows.Forms.AnchorStyles.Right)));
            this.btnCopy.Location = new System.Drawing.Point(93, 37);
            this.btnCopy.Name = "btnCopy";
            this.btnCopy.Size = new System.Drawing.Size(102, 23);
            this.btnCopy.TabIndex = 4;
            this.btnCopy.Text = "Copy To Clipboard";
            this.btnCopy.UseVisualStyleBackColor = true;
            this.btnCopy.Visible = false;
            this.btnCopy.Click += new System.EventHandler(this.btnCopy_Click);
            // 
            // lblMessage
            // 
            this.lblMessage.AutoSize = true;
            this.lblMessage.Location = new System.Drawing.Point(12, 9);
            this.lblMessage.MaximumSize = new System.Drawing.Size(310, 0);
            this.lblMessage.Name = "lblMessage";
            this.lblMessage.Size = new System.Drawing.Size(35, 13);
            this.lblMessage.TabIndex = 5;
            this.lblMessage.Text = "label1";
            // 
            // tbDetails
            // 
            this.tbDetails.Anchor = System.Windows.Forms.AnchorStyles.Bottom;
            this.tbDetails.Location = new System.Drawing.Point(12, 68);
            this.tbDetails.MaximumSize = new System.Drawing.Size(328, 100);
            this.tbDetails.Multiline = true;
            this.tbDetails.Name = "tbDetails";
            this.tbDetails.ReadOnly = true;
            this.tbDetails.ScrollBars = System.Windows.Forms.ScrollBars.Vertical;
            this.tbDetails.Size = new System.Drawing.Size(328, 100);
            this.tbDetails.TabIndex = 6;
            this.tbDetails.Visible = false;
            // 
            // MessageBoxWithDetails
            // 
            this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
            this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
            this.ClientSize = new System.Drawing.Size(354, 72);
            this.Controls.Add(this.tbDetails);
            this.Controls.Add(this.lblMessage);
            this.Controls.Add(this.btnCopy);
            this.Controls.Add(this.btnDetails);
            this.Controls.Add(this.btnClose);
            this.FormBorderStyle = System.Windows.Forms.FormBorderStyle.FixedDialog;
            this.MaximizeBox = false;
            this.MinimizeBox = false;
            this.Name = "MessageBoxWithDetails";
            this.ShowIcon = false;
            this.ShowInTaskbar = false;
            this.StartPosition = System.Windows.Forms.FormStartPosition.CenterScreen;
            this.ResumeLayout(false);
            this.PerformLayout();

        }

        #endregion

        private System.Windows.Forms.Button btnClose;
        private System.Windows.Forms.Button btnDetails;
        private System.Windows.Forms.Button btnCopy;
        private System.Windows.Forms.Label lblMessage;
        private System.Windows.Forms.TextBox tbDetails;
    }
}

As others have pointed out, you should write a custom dialog with the desired features. For help on this, you can look at the actual implementation used by the PropertyGrid for this dialog (perhaps with a decompiler) , which is, as of .NET 4.0, the System.Windows.Forms.PropertyGridInternal.GridErrorDlg type, internal to the System.Windows.Forms assembly.

I really wouldn't recommend it (could break in a future release), but if you're feeling really lazy, you can directly use this internal type using reflection.

// Get reference to the dialog type.
var dialogTypeName = "System.Windows.Forms.PropertyGridInternal.GridErrorDlg";
var dialogType = typeof(Form).Assembly.GetType(dialogTypeName);

// Create dialog instance.
var dialog = (Form)Activator.CreateInstance(dialogType, new PropertyGrid());

// Populate relevant properties on the dialog instance.
dialog.Text = "Sample Title";
dialogType.GetProperty("Details").SetValue(dialog, "Sample Details", null);
dialogType.GetProperty("Message").SetValue(dialog, "Sample Message", null);

// Display dialog.
var result = dialog.ShowDialog();

Result:

Details Dialog


just write your own dialog, there is no overload like you want to show method.