Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / 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
- StyleTypedPropertyAttribute.cs
- ExceptionValidationRule.cs
- TextTreeUndo.cs
- BrowserDefinition.cs
- BaseCollection.cs
- _TransmitFileOverlappedAsyncResult.cs
- TextServicesDisplayAttribute.cs
- ApplicationSecurityInfo.cs
- ToolStripDropDownItem.cs
- FactoryMaker.cs
- SqlTypesSchemaImporter.cs
- ViewGenResults.cs
- ProviderSettings.cs
- ValuePattern.cs
- DataSourceDescriptorCollection.cs
- ColorBuilder.cs
- NullableConverter.cs
- ZoneMembershipCondition.cs
- WmlPanelAdapter.cs
- SuspendDesigner.cs
- CellTreeNodeVisitors.cs
- Viewport3DAutomationPeer.cs
- NCryptNative.cs
- UserNamePasswordServiceCredential.cs
- xmlNames.cs
- AppSecurityManager.cs
- BamlBinaryWriter.cs
- TextInfo.cs
- CachingHintValidation.cs
- TraceHandler.cs
- JsonDataContract.cs
- PerformanceCounterCategory.cs
- BroadcastEventHelper.cs
- Emitter.cs
- UshortList2.cs
- ReadWriteSpinLock.cs
- BasicKeyConstraint.cs
- FontStyleConverter.cs
- WrappedIUnknown.cs
- DataGridRowHeaderAutomationPeer.cs
- ApplicationBuildProvider.cs
- WeakRefEnumerator.cs
- CompiledAction.cs
- WinFormsComponentEditor.cs
- ButtonBaseAdapter.cs
- DictionaryCustomTypeDescriptor.cs
- TypeConverterAttribute.cs
- ControlPager.cs
- RoleManagerEventArgs.cs
- ContentElement.cs
- securitymgrsite.cs
- PropertyGeneratedEventArgs.cs
- ToolStripItemClickedEventArgs.cs
- ReadOnlyObservableCollection.cs
- AppDomain.cs
- TextEditorTyping.cs
- HtmlLiteralTextAdapter.cs
- CachedTypeface.cs
- ToolStripHighContrastRenderer.cs
- PropertyBuilder.cs
- SequenceFullException.cs
- LocalizedNameDescriptionPair.cs
- SystemEvents.cs
- ParameterReplacerVisitor.cs
- HttpCookieCollection.cs
- AnnotationService.cs
- IntegerCollectionEditor.cs
- UInt64.cs
- SchemaInfo.cs
- SqlClientMetaDataCollectionNames.cs
- VisualBrush.cs
- SqlClientWrapperSmiStreamChars.cs
- Convert.cs
- UniformGrid.cs
- Screen.cs
- ObjectIDGenerator.cs
- EntityRecordInfo.cs
- StreamGeometryContext.cs
- GridEntry.cs
- DataControlLinkButton.cs
- DataView.cs
- OperationParameterInfo.cs
- DeliveryStrategy.cs
- DataGridViewUtilities.cs
- TimestampInformation.cs
- HMAC.cs
- HtmlButton.cs
- TaskFormBase.cs
- TemplatePartAttribute.cs
- ClientSideProviderDescription.cs
- ConfigurationManagerHelper.cs
- NativeMethods.cs
- DataStreams.cs
- UserNamePasswordServiceCredential.cs
- SmtpCommands.cs
- ValidationHelper.cs
- SecurityUtils.cs
- InstanceDescriptor.cs
- BufferModesCollection.cs
- GeometryHitTestResult.cs