Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Core / CSharp / System / Windows / SizeChangedInfo.cs / 1 / SizeChangedInfo.cs
using System; namespace System.Windows { ////// The SizeChangedinfo class is used as a parameter to OnSizeRenderChanged. /// public class SizeChangedInfo { ////// Initializes a new instance of the SizeChangedinfo class. /// /// /// The element which size is changing. /// /// /// The size of the object before update. New size is element.RenderSize /// /// /// 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. /// /// /// 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 SizeChangedInfo(UIElement element, Size previousSize, bool widthChanged, bool heightChanged) { _element = element; _previousSize = previousSize; _widthChanged = widthChanged; _heightChanged = heightChanged; } ////// 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 _widthChanged; } } ////// 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 _heightChanged; } } //this method is used by UIElement to "accumulate" several cosequitive layout updates //into the single args object cahced on UIElement. Since the SizeChanged is deferred event, //there could be several size changes before it will actually fire. internal void Update(bool widthChanged, bool heightChanged) { _widthChanged = _widthChanged | widthChanged; _heightChanged = _heightChanged | heightChanged; } internal UIElement Element { get { return _element; } } private UIElement _element; private Size _previousSize; private bool _widthChanged; private bool _heightChanged; internal SizeChangedInfo Next; } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. using System; namespace System.Windows { ////// The SizeChangedinfo class is used as a parameter to OnSizeRenderChanged. /// public class SizeChangedInfo { ////// Initializes a new instance of the SizeChangedinfo class. /// /// /// The element which size is changing. /// /// /// The size of the object before update. New size is element.RenderSize /// /// /// 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. /// /// /// 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 SizeChangedInfo(UIElement element, Size previousSize, bool widthChanged, bool heightChanged) { _element = element; _previousSize = previousSize; _widthChanged = widthChanged; _heightChanged = heightChanged; } ////// 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 _widthChanged; } } ////// 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 _heightChanged; } } //this method is used by UIElement to "accumulate" several cosequitive layout updates //into the single args object cahced on UIElement. Since the SizeChanged is deferred event, //there could be several size changes before it will actually fire. internal void Update(bool widthChanged, bool heightChanged) { _widthChanged = _widthChanged | widthChanged; _heightChanged = _heightChanged | heightChanged; } internal UIElement Element { get { return _element; } } private UIElement _element; private Size _previousSize; private bool _widthChanged; private bool _heightChanged; internal SizeChangedInfo Next; } } // 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
- HelpProvider.cs
- SourceSwitch.cs
- SafeTokenHandle.cs
- ProcessThreadCollection.cs
- UIElementHelper.cs
- CompiledQuery.cs
- Errors.cs
- FacetValues.cs
- CatalogPart.cs
- DiffuseMaterial.cs
- ObjectDataSourceDisposingEventArgs.cs
- XmlCustomFormatter.cs
- Geometry3D.cs
- Renderer.cs
- TypeToken.cs
- CompilerResults.cs
- RadioButton.cs
- CanExecuteRoutedEventArgs.cs
- ExceptionCollection.cs
- SystemColors.cs
- InputScopeNameConverter.cs
- EmptyQuery.cs
- SimpleType.cs
- AggregateNode.cs
- NamespaceCollection.cs
- RequestCachePolicy.cs
- HtmlFormWrapper.cs
- DataIdProcessor.cs
- JsonEncodingStreamWrapper.cs
- DatatypeImplementation.cs
- RelatedView.cs
- InternalTransaction.cs
- OracleParameter.cs
- datacache.cs
- Interlocked.cs
- ScrollProviderWrapper.cs
- ButtonBaseAdapter.cs
- SvcMapFileLoader.cs
- FlowDocument.cs
- WebPartRestoreVerb.cs
- JavaScriptString.cs
- SQLSingle.cs
- Overlapped.cs
- URI.cs
- TrackingDataItemValue.cs
- AdapterDictionary.cs
- LinqDataSourceView.cs
- CodePageUtils.cs
- ImpersonateTokenRef.cs
- DataGridViewCheckBoxCell.cs
- RestHandlerFactory.cs
- PackageDigitalSignatureManager.cs
- SQLMembershipProvider.cs
- PropertyIDSet.cs
- TypeBinaryExpression.cs
- Accessible.cs
- PeerPresenceInfo.cs
- ColorMatrix.cs
- SimpleApplicationHost.cs
- KeyFrames.cs
- PasswordDeriveBytes.cs
- InternalSafeNativeMethods.cs
- HwndKeyboardInputProvider.cs
- DynamicQueryableWrapper.cs
- TraceSection.cs
- EmulateRecognizeCompletedEventArgs.cs
- ListViewSortEventArgs.cs
- WeakRefEnumerator.cs
- AssemblyResolver.cs
- SqlStatistics.cs
- CharacterShapingProperties.cs
- SqlUnionizer.cs
- CryptoApi.cs
- CompilerParameters.cs
- WindowShowOrOpenTracker.cs
- WorkflowApplicationEventArgs.cs
- Hyperlink.cs
- Utilities.cs
- ServiceHandle.cs
- CapabilitiesPattern.cs
- PlanCompilerUtil.cs
- LinqDataSourceEditData.cs
- DataSourceUtil.cs
- Aggregates.cs
- LoginName.cs
- EntityDataSourceWizardForm.cs
- DataGridViewButtonCell.cs
- SystemColorTracker.cs
- PerfCounters.cs
- ElementAtQueryOperator.cs
- HostedHttpTransportManager.cs
- RenderDataDrawingContext.cs
- DbDataReader.cs
- PipelineModuleStepContainer.cs
- FigureParaClient.cs
- TextAnchor.cs
- COM2Properties.cs
- XmlDataSource.cs
- PackagePartCollection.cs
- IDQuery.cs