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
- ControllableStoryboardAction.cs
- ThreadExceptionDialog.cs
- FixedPageStructure.cs
- ClientTargetCollection.cs
- EmptyEnumerable.cs
- ZipIOEndOfCentralDirectoryBlock.cs
- FocusWithinProperty.cs
- DocumentGrid.cs
- Site.cs
- UIInitializationException.cs
- ProtocolsConfigurationEntry.cs
- CreateUserWizardStep.cs
- Int32Converter.cs
- JavaScriptObjectDeserializer.cs
- MessageContractExporter.cs
- MsmqException.cs
- XmlPropertyBag.cs
- Cursor.cs
- MSG.cs
- DataControlFieldHeaderCell.cs
- CompilationPass2TaskInternal.cs
- CodeBlockBuilder.cs
- SourceFileInfo.cs
- MsmqAppDomainProtocolHandler.cs
- HwndMouseInputProvider.cs
- ByteAnimationBase.cs
- ProviderCollection.cs
- PropertyReferenceSerializer.cs
- ListGeneralPage.cs
- CompilerParameters.cs
- TargetException.cs
- URLAttribute.cs
- GPRECTF.cs
- SQLRoleProvider.cs
- WebPartConnectionsCloseVerb.cs
- TextEmbeddedObject.cs
- RecordBuilder.cs
- XamlGridLengthSerializer.cs
- SqlServices.cs
- CatalogPartDesigner.cs
- TextParentUndoUnit.cs
- WmlTextViewAdapter.cs
- SmiXetterAccessMap.cs
- KnownBoxes.cs
- PathSegmentCollection.cs
- ZoneMembershipCondition.cs
- Image.cs
- SqlGatherProducedAliases.cs
- KeyedCollection.cs
- DataContract.cs
- InlineUIContainer.cs
- RemoteWebConfigurationHostServer.cs
- AesCryptoServiceProvider.cs
- StylusPointPropertyInfo.cs
- CroppedBitmap.cs
- AppDomainFactory.cs
- CircleHotSpot.cs
- shaper.cs
- ParameterBuilder.cs
- QilInvokeLateBound.cs
- TableCellAutomationPeer.cs
- ExecutionEngineException.cs
- BaseProcessor.cs
- Image.cs
- SqlAliasesReferenced.cs
- TargetControlTypeAttribute.cs
- RegexWriter.cs
- EventToken.cs
- SettingsPropertyIsReadOnlyException.cs
- CroppedBitmap.cs
- InfoCardRSAOAEPKeyExchangeDeformatter.cs
- HtmlContainerControl.cs
- RelatedImageListAttribute.cs
- RangeValidator.cs
- UserControlParser.cs
- ValuePatternIdentifiers.cs
- MatrixCamera.cs
- XhtmlBasicControlAdapter.cs
- PlatformNotSupportedException.cs
- InputScopeManager.cs
- RecordsAffectedEventArgs.cs
- TreeNodeConverter.cs
- PathFigureCollection.cs
- AttributeEmitter.cs
- SQLByteStorage.cs
- XmlQueryTypeFactory.cs
- CustomLineCap.cs
- processwaithandle.cs
- SymLanguageVendor.cs
- RefreshInfo.cs
- CodeActivityContext.cs
- TimeIntervalCollection.cs
- IndexOutOfRangeException.cs
- IOThreadScheduler.cs
- MeasureItemEvent.cs
- TemplateManager.cs
- XmlElementCollection.cs
- ISCIIEncoding.cs
- CRYPTPROTECT_PROMPTSTRUCT.cs
- FontDifferentiator.cs