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
- ReliabilityContractAttribute.cs
- ControlAdapter.cs
- SymLanguageVendor.cs
- WindowsUserNameSecurityTokenAuthenticator.cs
- ValidationRuleCollection.cs
- SessionParameter.cs
- WebControl.cs
- WinEventQueueItem.cs
- BamlLocalizer.cs
- SHA256Managed.cs
- NegationPusher.cs
- BitmapFrame.cs
- TempFiles.cs
- SmiMetaDataProperty.cs
- GeneratedCodeAttribute.cs
- ProvidePropertyAttribute.cs
- AttributeEmitter.cs
- QuaternionRotation3D.cs
- PrimaryKeyTypeConverter.cs
- Column.cs
- SimpleBitVector32.cs
- EmissiveMaterial.cs
- TextMessageEncoder.cs
- EmptyStringExpandableObjectConverter.cs
- BulletChrome.cs
- ComponentManagerBroker.cs
- TreeNode.cs
- MILUtilities.cs
- SchemaNamespaceManager.cs
- CheckBoxField.cs
- Cloud.cs
- FieldAccessException.cs
- MatrixConverter.cs
- DBSchemaRow.cs
- DataDesignUtil.cs
- ControlBuilderAttribute.cs
- AudioException.cs
- Utils.cs
- remotingproxy.cs
- CodeTypeReferenceSerializer.cs
- WebScriptMetadataMessageEncoderFactory.cs
- ConnectionPoolManager.cs
- EmptyReadOnlyDictionaryInternal.cs
- XmlWrappingWriter.cs
- PropertyDescriptorComparer.cs
- OneToOneMappingSerializer.cs
- GcHandle.cs
- DataGridViewCellLinkedList.cs
- ApplicationBuildProvider.cs
- DataStreamFromComStream.cs
- ReaderWriterLock.cs
- DefaultProxySection.cs
- WebSysDescriptionAttribute.cs
- CompiledRegexRunnerFactory.cs
- WSDualHttpSecurity.cs
- PolicyChain.cs
- ListBindingHelper.cs
- UnmanagedMemoryAccessor.cs
- TableLayoutSettings.cs
- remotingproxy.cs
- DataGridHeaderBorder.cs
- DependencyPropertyAttribute.cs
- _DisconnectOverlappedAsyncResult.cs
- SafeRightsManagementPubHandle.cs
- DynamicPropertyHolder.cs
- DbReferenceCollection.cs
- mda.cs
- SettingsPropertyCollection.cs
- _BaseOverlappedAsyncResult.cs
- DbBuffer.cs
- ContextDataSource.cs
- PrimitiveCodeDomSerializer.cs
- NumericUpDown.cs
- TextLineBreak.cs
- UserControlParser.cs
- ImagingCache.cs
- StateRuntime.cs
- DataServiceRequest.cs
- WebPartChrome.cs
- OperandQuery.cs
- Transform3D.cs
- AudioFormatConverter.cs
- ResourceContainer.cs
- WSIdentityFaultException.cs
- XPathNodePointer.cs
- TypeUtils.cs
- ConfigXmlText.cs
- GridViewHeaderRowPresenter.cs
- TextServicesProperty.cs
- ScrollContentPresenter.cs
- DataGridColumnHeader.cs
- IndexOutOfRangeException.cs
- PathStreamGeometryContext.cs
- Graph.cs
- IisHelper.cs
- StylusCaptureWithinProperty.cs
- TemplateControlParser.cs
- SurrogateChar.cs
- ItemCollection.cs
- Int32.cs