src/FingersDance.ViewModel/ViewModelBase.cs
author cavaliet
Thu, 17 Sep 2009 17:25:05 +0200
changeset 75 99d003723474
parent 69 a4c44555f205
permissions -rw-r--r--
data binding second step. we can add annotation by clicking on menu buttons or timeline.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
55
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     1
using System;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     2
using System.Collections.Generic;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     3
using System.Linq;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     4
using System.Text;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     5
using System.ComponentModel;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     6
using System.Diagnostics;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     7
69
a4c44555f205 First Data binding for annotations and timeline
cavaliet
parents: 55
diff changeset
     8
namespace FingersDance.ViewModels
55
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
     9
{
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    10
    /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    11
    /// Base class for all ViewModel classes in the application.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    12
    /// It provides support for property change notifications 
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    13
    /// and has a DisplayName property.  This class is abstract.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    14
    /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    15
    public abstract class ViewModelBase : INotifyPropertyChanged, IDisposable
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    16
    {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    17
        #region Constructor
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    18
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    19
        protected ViewModelBase()
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    20
        {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    21
        }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    22
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    23
        #endregion // Constructor
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    24
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    25
        #region DisplayName
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    26
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    27
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    28
        /// Returns the user-friendly name of this object.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    29
        /// Child classes can set this property to a new value,
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    30
        /// or override it to determine the value on-demand.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    31
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    32
        public virtual string DisplayName { get; protected set; }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    33
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    34
        #endregion // DisplayName
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    35
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    36
        #region Debugging Aides
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    37
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    38
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    39
        /// Warns the developer if this object does not have
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    40
        /// a public property with the specified name. This 
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    41
        /// method does not exist in a Release build.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    42
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    43
        [Conditional("DEBUG")]
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    44
        [DebuggerStepThrough]
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    45
        public void VerifyPropertyName(string propertyName)
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    46
        {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    47
            // Verify that the property name matches a real,  
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    48
            // public, instance property on this object.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    49
            if (TypeDescriptor.GetProperties(this)[propertyName] == null)
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    50
            {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    51
                string msg = "Invalid property name: " + propertyName;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    52
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    53
                if (this.ThrowOnInvalidPropertyName)
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    54
                    throw new Exception(msg);
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    55
                else
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    56
                    Debug.Fail(msg);
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    57
            }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    58
        }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    59
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    60
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    61
        /// Returns whether an exception is thrown, or if a Debug.Fail() is used
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    62
        /// when an invalid property name is passed to the VerifyPropertyName method.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    63
        /// The default value is false, but subclasses used by unit tests might 
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    64
        /// override this property's getter to return true.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    65
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    66
        protected virtual bool ThrowOnInvalidPropertyName { get; private set; }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    67
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    68
        #endregion // Debugging Aides
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    69
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    70
        #region INotifyPropertyChanged Members
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    71
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    72
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    73
        /// Raised when a property on this object has a new value.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    74
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    75
        public event PropertyChangedEventHandler PropertyChanged;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    76
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    77
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    78
        /// Raises this object's PropertyChanged event.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    79
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    80
        /// <param name="propertyName">The property that has a new value.</param>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    81
        protected virtual void OnPropertyChanged(string propertyName)
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    82
        {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    83
            this.VerifyPropertyName(propertyName);
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    84
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    85
            PropertyChangedEventHandler handler = this.PropertyChanged;
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    86
            if (handler != null)
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    87
            {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    88
                var e = new PropertyChangedEventArgs(propertyName);
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    89
                handler(this, e);
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    90
            }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    91
        }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    92
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    93
        #endregion // INotifyPropertyChanged Members
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    94
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    95
        #region IDisposable Members
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    96
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    97
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    98
        /// Invoked when this object is being removed from the application
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
    99
        /// and will be subject to garbage collection.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   100
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   101
        public void Dispose()
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   102
        {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   103
            this.OnDispose();
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   104
        }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   105
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   106
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   107
        /// Child classes can override this method to perform 
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   108
        /// clean-up logic, such as removing event handlers.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   109
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   110
        protected virtual void OnDispose()
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   111
        {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   112
        }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   113
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   114
#if DEBUG
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   115
        /// <summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   116
        /// Useful for ensuring that ViewModel objects are properly garbage collected.
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   117
        /// </summary>
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   118
        ~ViewModelBase()
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   119
        {
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   120
            string msg = string.Format("{0} ({1}) ({2}) Finalized", this.GetType().Name, this.DisplayName, this.GetHashCode());
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   121
            System.Diagnostics.Debug.WriteLine(msg);
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   122
        }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   123
#endif
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   124
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   125
        #endregion // IDisposable Member
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   126
    }
1ec0ef228158 data, viewmodel and view added
cavaliet
parents:
diff changeset
   127
}