Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Framework / System / Windows / Data / ValueConversionAttribute.cs / 1 / 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
- ArgumentsParser.cs
- BaseCollection.cs
- ToolStripItemDataObject.cs
- IRCollection.cs
- AuthenticationManager.cs
- SqlTriggerContext.cs
- HitTestResult.cs
- ConnectorSelectionGlyph.cs
- XmlEntity.cs
- FormatVersion.cs
- CustomLineCap.cs
- RowToFieldTransformer.cs
- CatchBlock.cs
- UnsafeNativeMethods.cs
- MemberHolder.cs
- WebPartEditorApplyVerb.cs
- CodeDirectiveCollection.cs
- ProviderConnectionPoint.cs
- ProfileGroupSettings.cs
- TranslateTransform.cs
- UpdatePanelTrigger.cs
- SchemaTypeEmitter.cs
- RangeBaseAutomationPeer.cs
- DesignObjectWrapper.cs
- AnnotationStore.cs
- SemanticKeyElement.cs
- QuadraticBezierSegment.cs
- OleDbRowUpdatedEvent.cs
- ContentPlaceHolder.cs
- DesignerDataSourceView.cs
- InstallHelper.cs
- LicenseProviderAttribute.cs
- DoubleAnimationUsingPath.cs
- jithelpers.cs
- CapabilitiesRule.cs
- CodePageUtils.cs
- TrackingProfileDeserializationException.cs
- SelectorAutomationPeer.cs
- AssemblyResourceLoader.cs
- EndpointInfoCollection.cs
- XPathDescendantIterator.cs
- Peer.cs
- CustomLineCap.cs
- Resources.Designer.cs
- ServiceManagerHandle.cs
- DispatcherTimer.cs
- HtmlShimManager.cs
- securitymgrsite.cs
- PersistChildrenAttribute.cs
- SqlUnionizer.cs
- SByteStorage.cs
- TypeUtils.cs
- AddInAdapter.cs
- SessionPageStatePersister.cs
- FileUpload.cs
- SafeNativeMethods.cs
- ReflectionServiceProvider.cs
- RecognitionEventArgs.cs
- XPathMessageFilter.cs
- TextAction.cs
- PriorityBinding.cs
- CodeTypeMemberCollection.cs
- ObjectSelectorEditor.cs
- PlacementWorkspace.cs
- CollectionViewSource.cs
- PeerNameRegistration.cs
- NullExtension.cs
- Panel.cs
- DeflateInput.cs
- ObjectListCommand.cs
- WebRequest.cs
- IsolatedStorageFilePermission.cs
- PowerStatus.cs
- XslCompiledTransform.cs
- SplayTreeNode.cs
- WebPartTracker.cs
- ProtocolsConfigurationHandler.cs
- SHA512Managed.cs
- ImmutableCollection.cs
- LocalValueEnumerator.cs
- DbDataRecord.cs
- WorkflowOwnershipException.cs
- InvariantComparer.cs
- ComNativeDescriptor.cs
- HttpInputStream.cs
- CurrentChangingEventArgs.cs
- ProfileSettings.cs
- XamlTemplateSerializer.cs
- DesignBindingValueUIHandler.cs
- EntityAdapter.cs
- CharacterMetrics.cs
- Transform3DCollection.cs
- CurrentChangingEventArgs.cs
- XmlBinaryReader.cs
- PresentationTraceSources.cs
- XmlSerializerVersionAttribute.cs
- PageClientProxyGenerator.cs
- ManipulationStartedEventArgs.cs
- FileChangesMonitor.cs
- SpotLight.cs