Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Core / CSharp / System / Windows / Input / Command / KeyGestureConverter.cs / 1305600 / KeyGestureConverter.cs
//---------------------------------------------------------------------------- // //// Copyright (C) Microsoft Corporation. All rights reserved. // // // // Description: KeyGestureConverter - Converts a KeyGesture string // to the *Type* that the string represents // // // History: // 05/01/2004 : Chandrasekhar Rentachintala - Created // //--------------------------------------------------------------------------- using System; using System.ComponentModel; // for TypeConverter using System.Globalization; // for CultureInfo using System.Reflection; using MS.Internal; using System.Windows; using System.Windows.Input; using MS.Utility; namespace System.Windows.Input { ////// KeyGesture - Converter class for converting between a string and the Type of a KeyGesture /// public class KeyGestureConverter : TypeConverter { private const char MODIFIERS_DELIMITER = '+' ; internal const char DISPLAYSTRING_SEPARATOR = ',' ; //////CanConvertFrom() /// ///ITypeDescriptorContext ///type to convert from ///true if the given type can be converted, false otherwise public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType) { // We can only handle string. if (sourceType == typeof(string)) { return true; } else { return false; } } //////TypeConverter method override. /// ///ITypeDescriptorContext ///Type to convert to ///true if conversion is possible public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType) { // We can convert to an InstanceDescriptor or to a string. if (destinationType == typeof(string)) { // When invoked by the serialization engine we can convert to string only for known type if (context != null && context.Instance != null) { KeyGesture keyGesture = context.Instance as KeyGesture; if (keyGesture != null) { return (ModifierKeysConverter.IsDefinedModifierKeys(keyGesture.Modifiers) && IsDefinedKey(keyGesture.Key)); } } } return false; } ////// ConvertFrom() /// /// /// /// ///public override object ConvertFrom(ITypeDescriptorContext context, CultureInfo culture, object source) { if (source != null && source is string) { string fullName = ((string)source).Trim(); if (fullName == String.Empty) return new KeyGesture(Key.None); string keyToken; string modifiersToken; string displayString; // break apart display string int index = fullName.IndexOf(DISPLAYSTRING_SEPARATOR); if (index >= 0) { displayString = fullName.Substring(index + 1).Trim(); fullName = fullName.Substring(0, index).Trim(); } else { displayString = String.Empty; } // break apart key and modifiers index = fullName.LastIndexOf(MODIFIERS_DELIMITER); if (index >= 0) { // modifiers exists modifiersToken = fullName.Substring(0, index); keyToken = fullName.Substring(index + 1); } else { modifiersToken = String.Empty; keyToken = fullName; } ModifierKeys modifiers = ModifierKeys.None; object resultkey = keyConverter.ConvertFrom(context, culture, keyToken); if (resultkey != null) { object temp = modifierKeysConverter.ConvertFrom(context, culture, modifiersToken); if (temp != null) { modifiers = (ModifierKeys)temp; } return new KeyGesture((Key)resultkey, modifiers, displayString); } } throw GetConvertFromException(source); } /// /// ConvertTo() /// /// /// /// /// ///public override object ConvertTo(ITypeDescriptorContext context, CultureInfo culture, object value, Type destinationType) { if (destinationType == null) throw new ArgumentNullException("destinationType"); if (destinationType == typeof(string)) { if (value != null) { KeyGesture keyGesture = value as KeyGesture; if (keyGesture != null) { if (keyGesture.Key == Key.None) return String.Empty; string strBinding = "" ; string strKey = (string)keyConverter.ConvertTo(context, culture, keyGesture.Key, destinationType) as string; if (strKey != String.Empty) { strBinding += modifierKeysConverter.ConvertTo(context, culture, keyGesture.Modifiers, destinationType) as string; if (strBinding != String.Empty) { strBinding += MODIFIERS_DELIMITER; } strBinding += strKey; if (!String.IsNullOrEmpty(keyGesture.DisplayString)) { strBinding += DISPLAYSTRING_SEPARATOR + keyGesture.DisplayString; } } return strBinding; } } else { return String.Empty; } } throw GetConvertToException(value,destinationType); } // Check for Valid enum, as any int can be casted to the enum. internal static bool IsDefinedKey(Key key) { return (key >= Key.None && key <= Key.OemClear); } private static KeyConverter keyConverter = new KeyConverter(); private static ModifierKeysConverter modifierKeysConverter = new ModifierKeysConverter(); } } // 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: KeyGestureConverter - Converts a KeyGesture string // to the *Type* that the string represents // // // History: // 05/01/2004 : Chandrasekhar Rentachintala - Created // //--------------------------------------------------------------------------- using System; using System.ComponentModel; // for TypeConverter using System.Globalization; // for CultureInfo using System.Reflection; using MS.Internal; using System.Windows; using System.Windows.Input; using MS.Utility; namespace System.Windows.Input { ////// KeyGesture - Converter class for converting between a string and the Type of a KeyGesture /// public class KeyGestureConverter : TypeConverter { private const char MODIFIERS_DELIMITER = '+' ; internal const char DISPLAYSTRING_SEPARATOR = ',' ; //////CanConvertFrom() /// ///ITypeDescriptorContext ///type to convert from ///true if the given type can be converted, false otherwise public override bool CanConvertFrom(ITypeDescriptorContext context, Type sourceType) { // We can only handle string. if (sourceType == typeof(string)) { return true; } else { return false; } } //////TypeConverter method override. /// ///ITypeDescriptorContext ///Type to convert to ///true if conversion is possible public override bool CanConvertTo(ITypeDescriptorContext context, Type destinationType) { // We can convert to an InstanceDescriptor or to a string. if (destinationType == typeof(string)) { // When invoked by the serialization engine we can convert to string only for known type if (context != null && context.Instance != null) { KeyGesture keyGesture = context.Instance as KeyGesture; if (keyGesture != null) { return (ModifierKeysConverter.IsDefinedModifierKeys(keyGesture.Modifiers) && IsDefinedKey(keyGesture.Key)); } } } return false; } ////// ConvertFrom() /// /// /// /// ///public override object ConvertFrom(ITypeDescriptorContext context, CultureInfo culture, object source) { if (source != null && source is string) { string fullName = ((string)source).Trim(); if (fullName == String.Empty) return new KeyGesture(Key.None); string keyToken; string modifiersToken; string displayString; // break apart display string int index = fullName.IndexOf(DISPLAYSTRING_SEPARATOR); if (index >= 0) { displayString = fullName.Substring(index + 1).Trim(); fullName = fullName.Substring(0, index).Trim(); } else { displayString = String.Empty; } // break apart key and modifiers index = fullName.LastIndexOf(MODIFIERS_DELIMITER); if (index >= 0) { // modifiers exists modifiersToken = fullName.Substring(0, index); keyToken = fullName.Substring(index + 1); } else { modifiersToken = String.Empty; keyToken = fullName; } ModifierKeys modifiers = ModifierKeys.None; object resultkey = keyConverter.ConvertFrom(context, culture, keyToken); if (resultkey != null) { object temp = modifierKeysConverter.ConvertFrom(context, culture, modifiersToken); if (temp != null) { modifiers = (ModifierKeys)temp; } return new KeyGesture((Key)resultkey, modifiers, displayString); } } throw GetConvertFromException(source); } /// /// ConvertTo() /// /// /// /// /// ///public override object ConvertTo(ITypeDescriptorContext context, CultureInfo culture, object value, Type destinationType) { if (destinationType == null) throw new ArgumentNullException("destinationType"); if (destinationType == typeof(string)) { if (value != null) { KeyGesture keyGesture = value as KeyGesture; if (keyGesture != null) { if (keyGesture.Key == Key.None) return String.Empty; string strBinding = "" ; string strKey = (string)keyConverter.ConvertTo(context, culture, keyGesture.Key, destinationType) as string; if (strKey != String.Empty) { strBinding += modifierKeysConverter.ConvertTo(context, culture, keyGesture.Modifiers, destinationType) as string; if (strBinding != String.Empty) { strBinding += MODIFIERS_DELIMITER; } strBinding += strKey; if (!String.IsNullOrEmpty(keyGesture.DisplayString)) { strBinding += DISPLAYSTRING_SEPARATOR + keyGesture.DisplayString; } } return strBinding; } } else { return String.Empty; } } throw GetConvertToException(value,destinationType); } // Check for Valid enum, as any int can be casted to the enum. internal static bool IsDefinedKey(Key key) { return (key >= Key.None && key <= Key.OemClear); } private static KeyConverter keyConverter = new KeyConverter(); private static ModifierKeysConverter modifierKeysConverter = new ModifierKeysConverter(); } } // 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
- DataProtection.cs
- EastAsianLunisolarCalendar.cs
- ListViewCommandEventArgs.cs
- ListBoxItemAutomationPeer.cs
- SafeCryptContextHandle.cs
- HandlerBase.cs
- AttributeQuery.cs
- embossbitmapeffect.cs
- DataExpression.cs
- RelationshipEnd.cs
- SoapExtensionStream.cs
- XmlSignatureProperties.cs
- TimersDescriptionAttribute.cs
- ColumnWidthChangedEvent.cs
- FieldToken.cs
- Tag.cs
- UrlAuthorizationModule.cs
- IMembershipProvider.cs
- ProxyWebPartManager.cs
- ContextProperty.cs
- HtmlHead.cs
- EditorZone.cs
- XslTransform.cs
- VerificationException.cs
- VerificationException.cs
- ReferencedType.cs
- OutputCacheSection.cs
- InstanceDescriptor.cs
- VolatileResourceManager.cs
- MailWebEventProvider.cs
- ProfileService.cs
- MarshalByValueComponent.cs
- ObjectMemberMapping.cs
- HttpClientCertificate.cs
- RemoteCryptoDecryptRequest.cs
- DataRecordObjectView.cs
- WebServiceHost.cs
- TextSpanModifier.cs
- DependencyObject.cs
- TransformFinalBlockRequest.cs
- CommandLibraryHelper.cs
- TransactionProxy.cs
- MeshGeometry3D.cs
- ReceiveParametersContent.cs
- XsltSettings.cs
- RightsManagementInformation.cs
- RealProxy.cs
- DataControlPagerLinkButton.cs
- FontResourceCache.cs
- CatalogZone.cs
- FormViewDeleteEventArgs.cs
- TdsParserHelperClasses.cs
- RegexCapture.cs
- BufferModesCollection.cs
- clipboard.cs
- UnsafeNativeMethods.cs
- FormsAuthenticationUserCollection.cs
- AnonymousIdentificationModule.cs
- CheckBoxList.cs
- HijriCalendar.cs
- NavigationPropertyEmitter.cs
- AuthenticateEventArgs.cs
- DecoratedNameAttribute.cs
- LogEntrySerialization.cs
- StrongNameUtility.cs
- TraceUtility.cs
- AddInAdapter.cs
- WebEvents.cs
- SmtpSection.cs
- DefaultProxySection.cs
- MimeMultiPart.cs
- WpfPayload.cs
- EraserBehavior.cs
- StaticSiteMapProvider.cs
- DuplicateContext.cs
- HtmlToClrEventProxy.cs
- ScrollItemPatternIdentifiers.cs
- StrongNameMembershipCondition.cs
- TdsEnums.cs
- TextInfo.cs
- DateTimeOffset.cs
- StateBag.cs
- ReadWriteSpinLock.cs
- ExpressionPrefixAttribute.cs
- StyleConverter.cs
- DefaultCommandConverter.cs
- InheritanceContextHelper.cs
- DynamicValueConverter.cs
- DrawListViewSubItemEventArgs.cs
- __TransparentProxy.cs
- ListSortDescriptionCollection.cs
- AssemblyHash.cs
- MsdtcWrapper.cs
- ClientUtils.cs
- CalendarBlackoutDatesCollection.cs
- ModuleBuilder.cs
- DbConnectionPoolCounters.cs
- Solver.cs
- DataContractSerializer.cs
- MethodAccessException.cs