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
- ICollection.cs
- NTAccount.cs
- TypeLibConverter.cs
- ContourSegment.cs
- HtmlImage.cs
- Parameter.cs
- MediaTimeline.cs
- CodeCompileUnit.cs
- SafeHandle.cs
- WebPartDescriptionCollection.cs
- SignedXmlDebugLog.cs
- IxmlLineInfo.cs
- FileVersionInfo.cs
- TextTreeInsertUndoUnit.cs
- DocumentXmlWriter.cs
- HttpCapabilitiesEvaluator.cs
- DataGridColumn.cs
- SqlDataSourceStatusEventArgs.cs
- RadioButton.cs
- WindowsPen.cs
- OletxVolatileEnlistment.cs
- CertificateManager.cs
- BamlRecords.cs
- HwndProxyElementProvider.cs
- NamespaceInfo.cs
- DetailsViewDeletedEventArgs.cs
- Hex.cs
- ToolStripSplitStackLayout.cs
- Substitution.cs
- HMACSHA512.cs
- ProtocolReflector.cs
- EventListenerClientSide.cs
- XmlRootAttribute.cs
- PenCursorManager.cs
- MetabaseServerConfig.cs
- ComponentChangedEvent.cs
- DoubleIndependentAnimationStorage.cs
- LinqDataSource.cs
- FileDataSource.cs
- FixedSOMSemanticBox.cs
- Thumb.cs
- WmlValidationSummaryAdapter.cs
- RijndaelManaged.cs
- MetabaseReader.cs
- DependencyPropertyChangedEventArgs.cs
- MonikerSyntaxException.cs
- SecureStringHasher.cs
- DetailsViewActionList.cs
- FigureParaClient.cs
- TraceSwitch.cs
- LostFocusEventManager.cs
- SignatureToken.cs
- MatchingStyle.cs
- SerializationException.cs
- DnsPermission.cs
- DurableDispatcherAddressingFault.cs
- ComPlusTypeLoader.cs
- MultiByteCodec.cs
- CompiledAction.cs
- EUCJPEncoding.cs
- TimeStampChecker.cs
- AnimationException.cs
- CharacterMetricsDictionary.cs
- TableDetailsRow.cs
- KeyedCollection.cs
- SimpleTypeResolver.cs
- ChannelSinkStacks.cs
- ToolStripDropDownClosingEventArgs.cs
- SqlClientPermission.cs
- DiffuseMaterial.cs
- MatrixAnimationUsingKeyFrames.cs
- MsdtcWrapper.cs
- DataSourceControlBuilder.cs
- StrokeFIndices.cs
- ValueHandle.cs
- PeerOutputChannel.cs
- MaskedTextBoxDesigner.cs
- DataStreams.cs
- XPathEmptyIterator.cs
- SchemaMapping.cs
- HttpAsyncResult.cs
- TopClause.cs
- ClientConfigurationSystem.cs
- CommandEventArgs.cs
- PeerNameRegistration.cs
- RefExpr.cs
- AttachedPropertyInfo.cs
- MessageQueueKey.cs
- WinEventHandler.cs
- Encoding.cs
- SrgsItemList.cs
- IntegerValidator.cs
- InfoCardCryptoHelper.cs
- DateTimeConstantAttribute.cs
- XamlBrushSerializer.cs
- BindingCollectionElement.cs
- CompiledRegexRunnerFactory.cs
- NetworkAddressChange.cs
- Int16Converter.cs
- CngAlgorithm.cs