Click here to Skip to main content
15,892,298 members
Articles / Desktop Programming / Windows Forms

ButtonBar Control using .NET

Rate me:
Please Sign up or sign in to vote.
4.95/5 (43 votes)
3 Dec 2009CPOL5 min read 64.9K   5.5K   104  
Themed ButtonBar control supporting custom draw with full Designer support
using System.ComponentModel;

namespace ButtonBarsControl.Design.Generics
{
    /// <summary>
    /// Represents a method which can be used for Change events which will have <see cref="GenericChangeEventArgs{T}.OldValue"/>, <see cref="GenericChangeEventArgs{T}.NewValue"/> and <see cref="CancelEventArgs.Cancel"/>.
    /// </summary>
    /// <typeparam name="T">Type of object to be used for.</typeparam>
    /// <param name="sender">sender of Event.</param>
    /// <param name="e">Object containing event data</param>
    public delegate void GenericValueChangingHandler<T>(object sender, GenericChangeEventArgs<T> e);

    /// <summary>
    /// Place holder for change event containing Old and New Value.
    /// </summary>
    /// <typeparam name="T">Generic type</typeparam>
    public class GenericChangeEventArgs<T> : CancelEventArgs
    {
        private readonly T oldValue;

        /// <summary>
        /// Initializes new instance with specified parameter.
        /// </summary>/// 
        /// <param name="oldValue">Old Value.</param>
        /// <param name="newValue">New Value</param>
        public GenericChangeEventArgs(T oldValue, T newValue) : base(false)
        {
            this.oldValue = oldValue;
            NewValue = newValue;
        }

        /// <summary>
        /// Initializes new instance with specified parameter.
        /// </summary>/// 
        /// <param name="oldValue">Old Value.</param>
        /// <param name="newValue">New Value</param>
        /// <param name="cancel">Cancel flag which can be used to stop event execution.</param>
        public GenericChangeEventArgs(T oldValue, T newValue, bool cancel) : base(cancel)
        {
            this.oldValue = oldValue;
            NewValue = newValue;
        }

        /// <summary>
        /// Gets old value which is being modified.
        /// </summary>
        public T OldValue
        {
            get { return oldValue; }
        }

        /// <summary>
        /// Gets or Sets new Value which is being set for old value.
        /// </summary>
        public T NewValue { get; set; }
    }
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)


Written By
Software Developer (Senior)
India India
This member has not yet provided a Biography. Assume it's interesting and varied, and probably something to do with programming.

Comments and Discussions