Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / Data / ValueConversionAttribute.cs / 1305600 / ValueConversionAttribute.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: allows the author of a IValueConverter // to specify what source and target property types the // ValueConverter is capable of converting // // Specs: http://avalon/connecteddata/Specs/Data%20Binding.mht // //--------------------------------------------------------------------------- using System; namespace System.Windows.Data { ////// This attribute allows the author of a ////// to specify what source and target property types the ValueConverter is capable of converting. /// This meta data is useful for designer tools to help categorize and match ValueConverters. /// /// Add this custom attribute to your IValueConverter class definition. /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = true)] public sealed class ValueConversionAttribute : Attribute { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- ////// [ValueConversion(typeof(Employee), typeof(Brush))] /// class MyConverter : IValueConverter /// { /// public object Convert(object value, Type targetType, object parameter, CultureInfo culture) /// { /// if (value is Dev) return Brushes.Beige; /// if (value is Employee) return Brushes.Salmon; /// return Brushes.Yellow; /// } /// } ///
////// Creates a new ValueConversionAttribute to indicate between /// what types of a data binding source and target this ValueConverter can convert. /// /// the expected source type this ValueConverter can handle /// the target type to which this ValueConverter can convert to public ValueConversionAttribute(Type sourceType, Type targetType) { if (sourceType == null) throw new ArgumentNullException("sourceType"); if (targetType == null) throw new ArgumentNullException("targetType"); _sourceType = sourceType; _targetType = targetType; } ////// The expected source type this ValueConverter can handle. /// public Type SourceType { get { return _sourceType; } } ////// The target type to which this ValueConverter can convert to. /// public Type TargetType { get { return _targetType; } } ////// The type of the optional ValueConverter Parameter object. /// public Type ParameterType { get { return _parameterType; } set { _parameterType = value; } } ////// Returns the unique identifier for this Attribute. /// // Type ID is used to remove redundant attributes by // putting all attributes in a dictionary of [TypeId, Attribute]. // If you want AllowMultiple attributes to work with designers, // you must override TypeId. The default implementation returns // this.GetType(), which is appropriate for AllowMultiple = false, but // not for AllowMultiple = true; public override object TypeId { // the attribute itself will be used as a key to the dictionary get { return this; } } ////// Returns the hash code for this instance. /// override public int GetHashCode() { // the default implementation does some funky enumeration over its fields // we can do better and use the 2 mandatory fields source/targetType's hash codes return _sourceType.GetHashCode() + _targetType.GetHashCode(); } //-------------------------------------------- // Private members //-------------------------------------------- private Type _sourceType; private Type _targetType; private Type _parameterType; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // Description: allows the author of a IValueConverter // to specify what source and target property types the // ValueConverter is capable of converting // // Specs: http://avalon/connecteddata/Specs/Data%20Binding.mht // //--------------------------------------------------------------------------- using System; namespace System.Windows.Data { ////// This attribute allows the author of a ////// to specify what source and target property types the ValueConverter is capable of converting. /// This meta data is useful for designer tools to help categorize and match ValueConverters. /// /// Add this custom attribute to your IValueConverter class definition. /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = true)] public sealed class ValueConversionAttribute : Attribute { //----------------------------------------------------- // // Constructors // //----------------------------------------------------- ////// [ValueConversion(typeof(Employee), typeof(Brush))] /// class MyConverter : IValueConverter /// { /// public object Convert(object value, Type targetType, object parameter, CultureInfo culture) /// { /// if (value is Dev) return Brushes.Beige; /// if (value is Employee) return Brushes.Salmon; /// return Brushes.Yellow; /// } /// } ///
////// Creates a new ValueConversionAttribute to indicate between /// what types of a data binding source and target this ValueConverter can convert. /// /// the expected source type this ValueConverter can handle /// the target type to which this ValueConverter can convert to public ValueConversionAttribute(Type sourceType, Type targetType) { if (sourceType == null) throw new ArgumentNullException("sourceType"); if (targetType == null) throw new ArgumentNullException("targetType"); _sourceType = sourceType; _targetType = targetType; } ////// The expected source type this ValueConverter can handle. /// public Type SourceType { get { return _sourceType; } } ////// The target type to which this ValueConverter can convert to. /// public Type TargetType { get { return _targetType; } } ////// The type of the optional ValueConverter Parameter object. /// public Type ParameterType { get { return _parameterType; } set { _parameterType = value; } } ////// Returns the unique identifier for this Attribute. /// // Type ID is used to remove redundant attributes by // putting all attributes in a dictionary of [TypeId, Attribute]. // If you want AllowMultiple attributes to work with designers, // you must override TypeId. The default implementation returns // this.GetType(), which is appropriate for AllowMultiple = false, but // not for AllowMultiple = true; public override object TypeId { // the attribute itself will be used as a key to the dictionary get { return this; } } ////// Returns the hash code for this instance. /// override public int GetHashCode() { // the default implementation does some funky enumeration over its fields // we can do better and use the 2 mandatory fields source/targetType's hash codes return _sourceType.GetHashCode() + _targetType.GetHashCode(); } //-------------------------------------------- // Private members //-------------------------------------------- private Type _sourceType; private Type _targetType; private Type _parameterType; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- LinqTreeNodeEvaluator.cs
- CodeGroup.cs
- DateTime.cs
- HorizontalAlignConverter.cs
- CodeCommentStatementCollection.cs
- WebBrowserPermission.cs
- NetworkInformationPermission.cs
- BoolExpr.cs
- PageCodeDomTreeGenerator.cs
- UriScheme.cs
- FormViewDeleteEventArgs.cs
- WorkflowRuntimeSection.cs
- VisualStyleTypesAndProperties.cs
- GradientStop.cs
- HiddenField.cs
- ColorContext.cs
- XmlUtf8RawTextWriter.cs
- FixedSOMLineCollection.cs
- GridViewEditEventArgs.cs
- TextSelection.cs
- OutputCacheSection.cs
- PixelShader.cs
- DeflateEmulationStream.cs
- WindowsFormsHelpers.cs
- SpecularMaterial.cs
- SerialStream.cs
- StyleXamlTreeBuilder.cs
- ExpressionTable.cs
- CategoryValueConverter.cs
- TextWriter.cs
- TextFormatterContext.cs
- Line.cs
- ZipIOLocalFileHeader.cs
- BufferBuilder.cs
- InstancePersistence.cs
- Ref.cs
- SchemaCollectionPreprocessor.cs
- HttpInputStream.cs
- WebServicesDescriptionAttribute.cs
- UnionCodeGroup.cs
- NetMsmqBindingCollectionElement.cs
- SqlDataSourceStatusEventArgs.cs
- ReplyChannelBinder.cs
- BooleanConverter.cs
- SqlDataSourceSelectingEventArgs.cs
- Point.cs
- LinqExpressionNormalizer.cs
- ErasingStroke.cs
- KoreanLunisolarCalendar.cs
- SafeFileHandle.cs
- CapabilitiesPattern.cs
- MappingModelBuildProvider.cs
- DataTransferEventArgs.cs
- PanelStyle.cs
- DesignerWebPartChrome.cs
- CompositeControl.cs
- FixedSOMPageConstructor.cs
- EntityCommandDefinition.cs
- StorageMappingItemLoader.cs
- XmlReflectionImporter.cs
- CodeMemberEvent.cs
- TextTreeRootTextBlock.cs
- BindingRestrictions.cs
- BrowsableAttribute.cs
- SequentialUshortCollection.cs
- DocumentViewerBaseAutomationPeer.cs
- SerializationStore.cs
- Profiler.cs
- XmlWriter.cs
- UpdatePanel.cs
- CompilationPass2Task.cs
- String.cs
- HexParser.cs
- _HeaderInfo.cs
- GeometryGroup.cs
- DecoderNLS.cs
- SessionStateItemCollection.cs
- BitmapData.cs
- RSACryptoServiceProvider.cs
- WindowsBrush.cs
- Style.cs
- ProcessModelSection.cs
- EndpointAddressMessageFilter.cs
- Floater.cs
- GenericPrincipal.cs
- Pair.cs
- TextHidden.cs
- _SpnDictionary.cs
- ReliableMessagingVersionConverter.cs
- DataServiceRequest.cs
- XmlSchemaGroup.cs
- XmlCharCheckingWriter.cs
- WorkflowTransactionOptions.cs
- AssociationProvider.cs
- ImageMap.cs
- FormattedTextSymbols.cs
- TextBoxAutomationPeer.cs
- ComplexBindingPropertiesAttribute.cs
- StandardBindingReliableSessionElement.cs
- DocumentOrderComparer.cs