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
- ServiceReflector.cs
- XmlLanguageConverter.cs
- WSHttpTransportSecurityElement.cs
- TextElementEnumerator.cs
- WebPartDisplayMode.cs
- CodeIdentifier.cs
- RightsManagementEncryptionTransform.cs
- Attachment.cs
- RootProfilePropertySettingsCollection.cs
- LayoutEditorPart.cs
- View.cs
- ContentValidator.cs
- CredentialCache.cs
- SectionXmlInfo.cs
- DrawingState.cs
- DbCommandDefinition.cs
- webeventbuffer.cs
- TextFindEngine.cs
- DataStreamFromComStream.cs
- DiagnosticsElement.cs
- SourceExpressionException.cs
- SelectionListDesigner.cs
- BatchServiceHost.cs
- FontFamilyIdentifier.cs
- EndpointIdentityExtension.cs
- InvalidAsynchronousStateException.cs
- CollectionContainer.cs
- QilChoice.cs
- SqlBulkCopyColumnMappingCollection.cs
- DataGridViewCellEventArgs.cs
- JsonCollectionDataContract.cs
- EventLogEntry.cs
- SymbolPair.cs
- ActiveDocumentEvent.cs
- ComponentManagerBroker.cs
- TextDecoration.cs
- Switch.cs
- JoinGraph.cs
- ManipulationDevice.cs
- GatewayIPAddressInformationCollection.cs
- XmlSchemaAttributeGroupRef.cs
- EarlyBoundInfo.cs
- ReachFixedPageSerializer.cs
- TypedReference.cs
- AppDomainAttributes.cs
- ImmComposition.cs
- MdiWindowListStrip.cs
- WSFederationHttpBinding.cs
- SafeEventLogReadHandle.cs
- EventRecordWrittenEventArgs.cs
- XPathNodePointer.cs
- GuidConverter.cs
- IPEndPoint.cs
- ProtocolsConfiguration.cs
- ControlsConfig.cs
- XmlSerializationReader.cs
- OracleTimeSpan.cs
- DataGridSortingEventArgs.cs
- DataGridViewRowsAddedEventArgs.cs
- WindowsScrollBar.cs
- AsyncContentLoadedEventArgs.cs
- XmlAttributeProperties.cs
- DataObjectAttribute.cs
- Constraint.cs
- X509Certificate2Collection.cs
- BaseCollection.cs
- path.cs
- PingOptions.cs
- CodeBlockBuilder.cs
- WebPartMinimizeVerb.cs
- XpsS0ValidatingLoader.cs
- OleDbRowUpdatedEvent.cs
- WCFServiceClientProxyGenerator.cs
- ProgressiveCrcCalculatingStream.cs
- FrameworkElementFactory.cs
- Size.cs
- SmtpFailedRecipientsException.cs
- WebPartManagerDesigner.cs
- Regex.cs
- SiteMapDataSourceView.cs
- DataGridViewLinkColumn.cs
- ClientScriptManagerWrapper.cs
- BitmapEncoder.cs
- ISAPIRuntime.cs
- SubpageParagraph.cs
- DataGridViewCellFormattingEventArgs.cs
- SaveWorkflowCommand.cs
- MarkupCompiler.cs
- ClientScriptItem.cs
- SignedXml.cs
- RadioButtonAutomationPeer.cs
- DBParameter.cs
- UnsafeNativeMethodsCLR.cs
- LocatorManager.cs
- HTTP_SERVICE_CONFIG_URLACL_PARAM.cs
- DataServiceException.cs
- SystemInformation.cs
- WorkflowView.cs
- BrowserDefinition.cs
- XmlSchemaSimpleContentRestriction.cs