Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / WinForms / Managed / System / WinForms / ArrangedElement.cs / 1 / ArrangedElement.cs
namespace System.Windows.Forms { using System.Drawing; using System.Windows.Forms.Layout; using System.Collections.Specialized; using System.Collections; using System.ComponentModel; using System.Diagnostics; internal abstract class ArrangedElement : Component, IArrangedElement { ////// ///private Rectangle bounds = Rectangle.Empty; private IArrangedElement parent = null; private BitVector32 state = new BitVector32(); private PropertyStore propertyStore = new PropertyStore(); // Contains all properties that are not always set. private int suspendCount = 0; private static readonly int stateVisible = BitVector32.CreateMask(); private static readonly int stateDisposing = BitVector32.CreateMask(stateVisible); private static readonly int stateLocked = BitVector32.CreateMask(stateDisposing); private static readonly int PropControlsCollection = PropertyStore.CreateKey(); private Control spacer = new Control(); internal ArrangedElement() { this.Padding = DefaultPadding; this.Margin = DefaultMargin; state[stateVisible] = true; } public Rectangle Bounds { get { return bounds; } } ArrangedElementCollection IArrangedElement.Children { get { return GetChildren(); } } IArrangedElement IArrangedElement.Container { get { return GetContainer(); } } protected virtual Padding DefaultMargin { get { return Padding.Empty; } } protected virtual Padding DefaultPadding { get { return Padding.Empty; } } public virtual Rectangle DisplayRectangle { get { Rectangle displayRectangle = this.Bounds; return displayRectangle; } } public abstract LayoutEngine LayoutEngine { get; } public Padding Margin { get { return CommonProperties.GetMargin(this); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting margin negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Margin != value ) { CommonProperties.SetMargin(this, value); } } } public virtual Padding Padding { get { return CommonProperties.GetPadding(this, DefaultPadding); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting padding negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Padding != value) { CommonProperties.SetPadding(this, value); } } } public virtual IArrangedElement Parent { get { return parent; } set { parent = value as IArrangedElement; } } public virtual bool ParticipatesInLayout { get { return Visible; } } PropertyStore IArrangedElement.Properties { get { return this.Properties; } } private PropertyStore Properties { get { return propertyStore; } } public virtual bool Visible { get { return state[stateVisible]; } set { if ( state[stateVisible] != value) { state[stateVisible] = value; if (Parent != null){ LayoutTransaction.DoLayout(this.Parent, this, PropertyNames.Visible); } } } } protected abstract IArrangedElement GetContainer(); protected abstract ArrangedElementCollection GetChildren(); public virtual Size GetPreferredSize(Size constrainingSize) { Size preferredSize = LayoutEngine.GetPreferredSize(this, constrainingSize - Padding.Size) + Padding.Size; return preferredSize; } public virtual void PerformLayout(IArrangedElement container, string propertyName) { if (suspendCount <= 0) { OnLayout(new LayoutEventArgs(container, propertyName)); } } protected virtual void OnLayout(LayoutEventArgs e) { bool parentNeedsLayout = LayoutEngine.Layout(this, e); } protected virtual void OnBoundsChanged(Rectangle oldBounds, Rectangle newBounds) { ((IArrangedElement)this).PerformLayout((IArrangedElement)this, PropertyNames.Size); } public void SetBounds(Rectangle bounds, BoundsSpecified specified) { // in this case the parent is telling us to refresh our bounds - dont // call PerformLayout SetBoundsCore(bounds, specified); } protected virtual void SetBoundsCore(Rectangle bounds, BoundsSpecified specified) { if (bounds != this.bounds) { Rectangle oldBounds = this.bounds; this.bounds = bounds; OnBoundsChanged(oldBounds, bounds); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. namespace System.Windows.Forms { using System.Drawing; using System.Windows.Forms.Layout; using System.Collections.Specialized; using System.Collections; using System.ComponentModel; using System.Diagnostics; internal abstract class ArrangedElement : Component, IArrangedElement { /// /// ///private Rectangle bounds = Rectangle.Empty; private IArrangedElement parent = null; private BitVector32 state = new BitVector32(); private PropertyStore propertyStore = new PropertyStore(); // Contains all properties that are not always set. private int suspendCount = 0; private static readonly int stateVisible = BitVector32.CreateMask(); private static readonly int stateDisposing = BitVector32.CreateMask(stateVisible); private static readonly int stateLocked = BitVector32.CreateMask(stateDisposing); private static readonly int PropControlsCollection = PropertyStore.CreateKey(); private Control spacer = new Control(); internal ArrangedElement() { this.Padding = DefaultPadding; this.Margin = DefaultMargin; state[stateVisible] = true; } public Rectangle Bounds { get { return bounds; } } ArrangedElementCollection IArrangedElement.Children { get { return GetChildren(); } } IArrangedElement IArrangedElement.Container { get { return GetContainer(); } } protected virtual Padding DefaultMargin { get { return Padding.Empty; } } protected virtual Padding DefaultPadding { get { return Padding.Empty; } } public virtual Rectangle DisplayRectangle { get { Rectangle displayRectangle = this.Bounds; return displayRectangle; } } public abstract LayoutEngine LayoutEngine { get; } public Padding Margin { get { return CommonProperties.GetMargin(this); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting margin negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Margin != value ) { CommonProperties.SetMargin(this, value); } } } public virtual Padding Padding { get { return CommonProperties.GetPadding(this, DefaultPadding); } set { Debug.Assert((value.Right >= 0 && value.Left >= 0 && value.Top >= 0 && value.Bottom >=0), "who's setting padding negative?"); value = LayoutUtils.ClampNegativePaddingToZero(value); if (Padding != value) { CommonProperties.SetPadding(this, value); } } } public virtual IArrangedElement Parent { get { return parent; } set { parent = value as IArrangedElement; } } public virtual bool ParticipatesInLayout { get { return Visible; } } PropertyStore IArrangedElement.Properties { get { return this.Properties; } } private PropertyStore Properties { get { return propertyStore; } } public virtual bool Visible { get { return state[stateVisible]; } set { if ( state[stateVisible] != value) { state[stateVisible] = value; if (Parent != null){ LayoutTransaction.DoLayout(this.Parent, this, PropertyNames.Visible); } } } } protected abstract IArrangedElement GetContainer(); protected abstract ArrangedElementCollection GetChildren(); public virtual Size GetPreferredSize(Size constrainingSize) { Size preferredSize = LayoutEngine.GetPreferredSize(this, constrainingSize - Padding.Size) + Padding.Size; return preferredSize; } public virtual void PerformLayout(IArrangedElement container, string propertyName) { if (suspendCount <= 0) { OnLayout(new LayoutEventArgs(container, propertyName)); } } protected virtual void OnLayout(LayoutEventArgs e) { bool parentNeedsLayout = LayoutEngine.Layout(this, e); } protected virtual void OnBoundsChanged(Rectangle oldBounds, Rectangle newBounds) { ((IArrangedElement)this).PerformLayout((IArrangedElement)this, PropertyNames.Size); } public void SetBounds(Rectangle bounds, BoundsSpecified specified) { // in this case the parent is telling us to refresh our bounds - dont // call PerformLayout SetBoundsCore(bounds, specified); } protected virtual void SetBoundsCore(Rectangle bounds, BoundsSpecified specified) { if (bounds != this.bounds) { Rectangle oldBounds = this.bounds; this.bounds = bounds; OnBoundsChanged(oldBounds, bounds); } } } } // 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
- RequestSecurityTokenSerializer.cs
- Crc32.cs
- FontSourceCollection.cs
- ProviderConnectionPointCollection.cs
- SafeSerializationManager.cs
- ButtonBaseDesigner.cs
- XmlReflectionMember.cs
- ListViewInsertedEventArgs.cs
- CharUnicodeInfo.cs
- SafeNativeMethodsCLR.cs
- Resources.Designer.cs
- SyndicationFeed.cs
- ObjectDataSourceDisposingEventArgs.cs
- __Error.cs
- PointAnimationClockResource.cs
- SizeConverter.cs
- DataServiceProviderMethods.cs
- Font.cs
- TextRunTypographyProperties.cs
- ValidationSummary.cs
- CapabilitiesState.cs
- ScrollViewer.cs
- RegistrySecurity.cs
- SamlEvidence.cs
- DecoratedNameAttribute.cs
- LaxModeSecurityHeaderElementInferenceEngine.cs
- __ConsoleStream.cs
- LinearGradientBrush.cs
- EmissiveMaterial.cs
- FixedSOMPage.cs
- XPathSingletonIterator.cs
- ConnectionOrientedTransportChannelListener.cs
- RemotingException.cs
- ReferenceEqualityComparer.cs
- RefreshPropertiesAttribute.cs
- WebPartHeaderCloseVerb.cs
- COM2PictureConverter.cs
- DesignTimeXamlWriter.cs
- DateTimeFormatInfoScanner.cs
- NotSupportedException.cs
- WebPartVerb.cs
- AnimationClock.cs
- Win32MouseDevice.cs
- RuleSettings.cs
- ContextMenu.cs
- contentDescriptor.cs
- IISMapPath.cs
- VectorValueSerializer.cs
- StylusTip.cs
- MarginsConverter.cs
- CollectionViewSource.cs
- Point3D.cs
- ErrorFormatterPage.cs
- SelectionEditingBehavior.cs
- BitmapEncoder.cs
- BindableTemplateBuilder.cs
- FileFormatException.cs
- _CommandStream.cs
- LongValidatorAttribute.cs
- WsatEtwTraceListener.cs
- UIElementIsland.cs
- Table.cs
- GeometryModel3D.cs
- XmlSchemaAny.cs
- CodeEventReferenceExpression.cs
- ServiceConfigurationTraceRecord.cs
- SpecialNameAttribute.cs
- AdRotator.cs
- XmlAttributeOverrides.cs
- BrushValueSerializer.cs
- BooleanConverter.cs
- FixUp.cs
- HttpsChannelListener.cs
- ContainerVisual.cs
- SqlDependency.cs
- ValueConversionAttribute.cs
- ServiceModelTimeSpanValidator.cs
- XsdBuildProvider.cs
- RuleSettingsCollection.cs
- TextElementEnumerator.cs
- RsaKeyIdentifierClause.cs
- Vector3DAnimation.cs
- CultureInfoConverter.cs
- Source.cs
- WebScriptMetadataInstanceContextProvider.cs
- ContextConfiguration.cs
- OutputCacheProfileCollection.cs
- MethodRental.cs
- XsltCompileContext.cs
- XmlSchemaException.cs
- LineGeometry.cs
- StylusButtonCollection.cs
- TypeReference.cs
- ServiceDebugBehavior.cs
- FunctionImportMapping.ReturnTypeRenameMapping.cs
- FixedPageProcessor.cs
- LOSFormatter.cs
- XmlElementAttribute.cs
- LocationUpdates.cs
- PaperSource.cs