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 / SizeChangedEventArgs.cs / 1 / SizeChangedEventArgs.cs
using System; namespace System.Windows { ////// The SizeChangedEventArgs class is used by SizeChangedEventHandler. /// This handler is used for ComputedWidthChanged and ComputedHeightChanged events /// on UIElement. /// public class SizeChangedEventArgs : RoutedEventArgs { ////// Initializes a new instance of the SizeChangedEventArgs class. /// /// /// The UIElement which has its size changed by layout engine/>. /// /// /// The SizeChangeInfo that is used by. /// internal SizeChangedEventArgs(UIElement element, SizeChangedInfo info) { if (info == null) { throw new ArgumentNullException("info"); } if (element == null) { throw new ArgumentNullException("element"); } _element = element; _previousSize = info.PreviousSize; if(info.WidthChanged) _bits |= _widthChangedBit; if(info.HeightChanged) _bits |= _heightChangedBit; } /// /// Read-only access to the previous Size /// public Size PreviousSize { get { return _previousSize; } } ////// Read-only access to the new Size /// public Size NewSize { get { return _element.RenderSize; } } ////// Read-only access to the flag indicating that Width component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Width != newSize.Width) and widthChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool WidthChanged { get { return ((_bits & _widthChangedBit) != 0); } } ////// Read-only access to the flag indicating that Height component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Height != newSize.Height) and heightChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool HeightChanged { get { return ((_bits & _heightChangedBit) != 0); } } private Size _previousSize; private UIElement _element; private byte _bits; private static byte _widthChangedBit = 0x1; private static byte _heightChangedBit = 0x2; ////// The mechanism used to call the type-specific handler on the /// target. /// /// /// The generic handler to call in a type-specific way. /// /// /// The target to call the handler on. /// ///protected override void InvokeEventHandler(Delegate genericHandler, object genericTarget) { SizeChangedEventHandler handler = (SizeChangedEventHandler) genericHandler; handler(genericTarget, this); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System; namespace System.Windows { /// /// The SizeChangedEventArgs class is used by SizeChangedEventHandler. /// This handler is used for ComputedWidthChanged and ComputedHeightChanged events /// on UIElement. /// public class SizeChangedEventArgs : RoutedEventArgs { ////// Initializes a new instance of the SizeChangedEventArgs class. /// /// /// The UIElement which has its size changed by layout engine/>. /// /// /// The SizeChangeInfo that is used by. /// internal SizeChangedEventArgs(UIElement element, SizeChangedInfo info) { if (info == null) { throw new ArgumentNullException("info"); } if (element == null) { throw new ArgumentNullException("element"); } _element = element; _previousSize = info.PreviousSize; if(info.WidthChanged) _bits |= _widthChangedBit; if(info.HeightChanged) _bits |= _heightChangedBit; } /// /// Read-only access to the previous Size /// public Size PreviousSize { get { return _previousSize; } } ////// Read-only access to the new Size /// public Size NewSize { get { return _element.RenderSize; } } ////// Read-only access to the flag indicating that Width component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Width != newSize.Width) and widthChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool WidthChanged { get { return ((_bits & _widthChangedBit) != 0); } } ////// Read-only access to the flag indicating that Height component of the size changed. /// Note that due to double math /// effects, the it may be (previousSize.Height != newSize.Height) and heightChanged = true. /// This may happen in layout when sizes of objects are fluctuating because of a precision "jitter" of /// the input parameters, but the overall scene is considered to be "the same" so no visible changes /// will be detected. Typically, the handler of SizeChangedEvent should check this bit to avoid /// invalidation of layout if the dimension didn't change. /// public bool HeightChanged { get { return ((_bits & _heightChangedBit) != 0); } } private Size _previousSize; private UIElement _element; private byte _bits; private static byte _widthChangedBit = 0x1; private static byte _heightChangedBit = 0x2; ////// The mechanism used to call the type-specific handler on the /// target. /// /// /// The generic handler to call in a type-specific way. /// /// /// The target to call the handler on. /// ///protected override void InvokeEventHandler(Delegate genericHandler, object genericTarget) { SizeChangedEventHandler handler = (SizeChangedEventHandler) genericHandler; handler(genericTarget, this); } } } // 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
- Facet.cs
- AuthenticationService.cs
- SoapDocumentMethodAttribute.cs
- FontFamilyIdentifier.cs
- SelectionItemPattern.cs
- CompleteWizardStep.cs
- Attributes.cs
- FlowDecisionDesigner.xaml.cs
- ParseNumbers.cs
- GridViewRowEventArgs.cs
- ConsoleTraceListener.cs
- Font.cs
- HttpSysSettings.cs
- UntypedNullExpression.cs
- TextureBrush.cs
- ActiveXContainer.cs
- ConnectionPoolManager.cs
- EncryptedXml.cs
- PreApplicationStartMethodAttribute.cs
- RenderCapability.cs
- Encoding.cs
- Item.cs
- GorillaCodec.cs
- OpenTypeLayoutCache.cs
- ExpressionVisitorHelpers.cs
- ISAPIRuntime.cs
- WeakReferenceList.cs
- IntSecurity.cs
- PassportAuthenticationModule.cs
- XmlDictionary.cs
- XmlSchemaSubstitutionGroup.cs
- DataGridCommandEventArgs.cs
- AppDomainFactory.cs
- WebPartAddingEventArgs.cs
- FixedSOMSemanticBox.cs
- ProxyAttribute.cs
- ColorTranslator.cs
- XhtmlBasicCalendarAdapter.cs
- DrawTreeNodeEventArgs.cs
- HwndProxyElementProvider.cs
- UnionCqlBlock.cs
- IdentityValidationException.cs
- EventLogPropertySelector.cs
- NativeMethods.cs
- DetectEofStream.cs
- ResourcesGenerator.cs
- Crc32.cs
- ListenerElementsCollection.cs
- MdImport.cs
- Win32Exception.cs
- ErrorHandler.cs
- MarshalDirectiveException.cs
- DataViewSetting.cs
- NameValuePermission.cs
- ProfilePropertySettings.cs
- MethodCallTranslator.cs
- FixedSOMElement.cs
- CodeTypeMemberCollection.cs
- TcpConnectionPool.cs
- BaseTemplateParser.cs
- BinaryMethodMessage.cs
- ADMembershipProvider.cs
- PropertyEmitterBase.cs
- WpfPayload.cs
- BitmapPalette.cs
- SimplePropertyEntry.cs
- FixedSOMGroup.cs
- _SslStream.cs
- TypeDescriptionProvider.cs
- EnumerableRowCollection.cs
- LinearQuaternionKeyFrame.cs
- StickyNoteContentControl.cs
- DataServiceKeyAttribute.cs
- VBCodeProvider.cs
- WorkflowServiceBuildProvider.cs
- PixelShader.cs
- MenuBase.cs
- BitmapPalette.cs
- XmlDocumentSerializer.cs
- Base64WriteStateInfo.cs
- QilBinary.cs
- Preprocessor.cs
- TimelineGroup.cs
- TTSEngineProxy.cs
- ArraySegment.cs
- UnsafeNativeMethods.cs
- ThumbButtonInfoCollection.cs
- SafeNativeMethods.cs
- IdentityReference.cs
- TextStore.cs
- odbcmetadatacolumnnames.cs
- AsyncDataRequest.cs
- EntityCommandExecutionException.cs
- NotSupportedException.cs
- AppSettingsExpressionBuilder.cs
- BuildDependencySet.cs
- ValidationSummary.cs
- PropertyEmitterBase.cs
- WindowsFormsLinkLabel.cs
- CryptoStream.cs