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
- ServiceContractListItem.cs
- InkPresenter.cs
- XmlEntityReference.cs
- AttributeParameterInfo.cs
- FrameworkReadOnlyPropertyMetadata.cs
- BuilderPropertyEntry.cs
- SymmetricAlgorithm.cs
- UIInitializationException.cs
- DesignerFrame.cs
- FrameworkEventSource.cs
- DtrList.cs
- MouseButton.cs
- TypeUsage.cs
- NonClientArea.cs
- EmptyArray.cs
- SqlMethodCallConverter.cs
- PageAdapter.cs
- BitmapEffect.cs
- XmlSchemaObjectTable.cs
- DataSourceUtil.cs
- RadioButtonFlatAdapter.cs
- AppSecurityManager.cs
- VirtualizingStackPanel.cs
- ImageMap.cs
- SimpleApplicationHost.cs
- TableCellCollection.cs
- Win32.cs
- OutputCacheProfileCollection.cs
- RegexCapture.cs
- ClientScriptManagerWrapper.cs
- DesignDataSource.cs
- QilGenerator.cs
- EventItfInfo.cs
- ThreadStaticAttribute.cs
- RawStylusInputCustomDataList.cs
- ManipulationDelta.cs
- NetStream.cs
- RijndaelManagedTransform.cs
- ThousandthOfEmRealDoubles.cs
- itemelement.cs
- RequestCachePolicy.cs
- XmlSchemaRedefine.cs
- Rectangle.cs
- RelationshipDetailsRow.cs
- HasCopySemanticsAttribute.cs
- ApplicationDirectory.cs
- EventProxy.cs
- SecurityAppliedMessage.cs
- DetailsViewInsertEventArgs.cs
- ArgIterator.cs
- GotoExpression.cs
- XmlSchemaAttributeGroup.cs
- NodeFunctions.cs
- LinkedResource.cs
- WebPartHelpVerb.cs
- Material.cs
- WebPartActionVerb.cs
- AppliedDeviceFiltersDialog.cs
- HttpWebResponse.cs
- MediaContext.cs
- WorkflowFormatterBehavior.cs
- DBBindings.cs
- __ComObject.cs
- ObjectQueryExecutionPlan.cs
- PeerEndPoint.cs
- ProxyAttribute.cs
- AuthenticationModulesSection.cs
- HtmlInputHidden.cs
- Int32KeyFrameCollection.cs
- tooltip.cs
- SQLMembershipProvider.cs
- SymDocumentType.cs
- XmlEntityReference.cs
- ShadowGlyph.cs
- AutomationPeer.cs
- SolidBrush.cs
- PageClientProxyGenerator.cs
- IriParsingElement.cs
- DispatchOperationRuntime.cs
- ScrollContentPresenter.cs
- AutomationAttributeInfo.cs
- QueryContinueDragEventArgs.cs
- TransformCollection.cs
- ProfilePropertySettingsCollection.cs
- ZoneMembershipCondition.cs
- XmlSchemaProviderAttribute.cs
- DataGridViewLinkColumn.cs
- CTreeGenerator.cs
- QilStrConcatenator.cs
- DataSourceControlBuilder.cs
- TextEndOfParagraph.cs
- TableParaClient.cs
- CachedRequestParams.cs
- LiteralText.cs
- DesignerListAdapter.cs
- PeerCustomResolverBindingElement.cs
- XsltLibrary.cs
- AxHost.cs
- LifetimeServices.cs
- SelectionGlyphBase.cs