Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / wpf / src / Framework / System / Windows / GridLength.cs / 1305600 / GridLength.cs
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
//
// Description: Grid length implementation
//
// See spec at http://avalon/layout/Specs/Star%20LengthUnit.mht
//
// History:
// 09/24/2003 : olego - Created (in griddy prototype branch);
// 10/27/2003 : olego - Ported from griddy prototype branch;
//
//---------------------------------------------------------------------------
using MS.Internal;
using System.ComponentModel;
using System.Globalization;
namespace System.Windows
{
///
/// GridUnitType enum is used to indicate what kind of value the
/// GridLength is holding.
///
// Note: Keep the GridUnitType enum in [....] with the string representation
// of units (GridLengthConverter._unitString).
public enum GridUnitType
{
///
/// The value indicates that content should be calculated without constraints.
///
Auto = 0,
///
/// The value is expressed as a pixel.
///
Pixel,
///
/// The value is expressed as a weighted proportion of available space.
///
Star,
}
///
/// GridLength is the type used for various length-like properties in the system,
/// that explicitely support Star unit type. For example, "Width", "Height"
/// properties of ColumnDefinition and RowDefinition used by Grid.
///
[TypeConverter(typeof(GridLengthConverter))]
public struct GridLength : IEquatable
{
//-----------------------------------------------------
//
// Constructors
//
//-----------------------------------------------------
#region Constructors
///
/// Constructor, initializes the GridLength as absolute value in pixels.
///
/// Specifies the number of 'device-independent pixels'
/// (96 pixels-per-inch).
///
/// If pixels parameter is double.NaN
/// or pixels parameter is double.NegativeInfinity
/// or pixels parameter is double.PositiveInfinity .
///
public GridLength(double pixels)
: this(pixels, GridUnitType.Pixel)
{
}
///
/// Constructor, initializes the GridLength and specifies what kind of value
/// it will hold.
///
/// Value to be stored by this GridLength
/// instance.
/// Type of the value to be stored by this GridLength
/// instance.
///
/// If the type parameter is GridUnitType.Auto ,
/// then passed in value is ignored and replaced with 0 .
///
///
/// If value parameter is double.NaN
/// or value parameter is double.NegativeInfinity
/// or value parameter is double.PositiveInfinity .
///
public GridLength(double value, GridUnitType type)
{
if (DoubleUtil.IsNaN(value))
{
throw new ArgumentException(SR.Get(SRID.InvalidCtorParameterNoNaN, "value"));
}
if (double.IsInfinity(value))
{
throw new ArgumentException(SR.Get(SRID.InvalidCtorParameterNoInfinity, "value"));
}
if ( type != GridUnitType.Auto
&& type != GridUnitType.Pixel
&& type != GridUnitType.Star )
{
throw new ArgumentException(SR.Get(SRID.InvalidCtorParameterUnknownGridUnitType, "type"));
}
_unitValue = (type == GridUnitType.Auto) ? 0.0 : value;
_unitType = type;
}
#endregion Constructors
//------------------------------------------------------
//
// Public Methods
//
//-----------------------------------------------------
#region Public Methods
///
/// Overloaded operator, compares 2 GridLength's.
///
/// first GridLength to compare.
/// second GridLength to compare.
/// true if specified GridLengths have same value
/// and unit type.
public static bool operator == (GridLength gl1, GridLength gl2)
{
return ( gl1.GridUnitType == gl2.GridUnitType
&& gl1.Value == gl2.Value );
}
///
/// Overloaded operator, compares 2 GridLength's.
///
/// first GridLength to compare.
/// second GridLength to compare.
/// true if specified GridLengths have either different value or
/// unit type.
public static bool operator != (GridLength gl1, GridLength gl2)
{
return ( gl1.GridUnitType != gl2.GridUnitType
|| gl1.Value != gl2.Value );
}
///
/// Compares this instance of GridLength with another object.
///
/// Reference to an object for comparison.
/// true if this GridLength instance has the same value
/// and unit type as oCompare.
override public bool Equals(object oCompare)
{
if(oCompare is GridLength)
{
GridLength l = (GridLength)oCompare;
return (this == l);
}
else
return false;
}
///
/// Compares this instance of GridLength with another instance.
///
/// Grid length instance to compare.
/// true if this GridLength instance has the same value
/// and unit type as gridLength.
public bool Equals(GridLength gridLength)
{
return (this == gridLength);
}
///
///
///
///
public override int GetHashCode()
{
return ((int)_unitValue + (int)_unitType);
}
///
/// Returns true if this GridLength instance holds
/// an absolute (pixel) value.
///
public bool IsAbsolute { get { return (_unitType == GridUnitType.Pixel); } }
///
/// Returns true if this GridLength instance is
/// automatic (not specified).
///
public bool IsAuto { get { return (_unitType == GridUnitType.Auto); } }
///
/// Returns true if this GridLength instance holds weighted propertion
/// of available space.
///
public bool IsStar { get { return (_unitType == GridUnitType.Star); } }
///
/// Returns value part of this GridLength instance.
///
public double Value { get { return ((_unitType == GridUnitType.Auto) ? 1.0 : _unitValue); } }
///
/// Returns unit type of this GridLength instance.
///
public GridUnitType GridUnitType { get { return (_unitType); } }
///
/// Returns the string representation of this object.
///
public override string ToString()
{
return GridLengthConverter.ToString(this, CultureInfo.InvariantCulture);
}
#endregion Public Methods
//------------------------------------------------------
//
// Public Properties
//
//------------------------------------------------------
#region Public Properties
///
/// Returns initialized Auto GridLength value.
///
public static GridLength Auto
{
get { return (s_auto); }
}
#endregion Public Properties
//-----------------------------------------------------
//
// Private Fields
//
//------------------------------------------------------
#region Private Fields
private double _unitValue; // unit value storage
private GridUnitType _unitType; // unit type storage
// static instance of Auto GridLength
private static readonly GridLength s_auto = new GridLength(1.0, GridUnitType.Auto);
#endregion Private Fields
}
}
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
// Copyright (c) Microsoft Corporation. All rights reserved.
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
//
// Description: Grid length implementation
//
// See spec at http://avalon/layout/Specs/Star%20LengthUnit.mht
//
// History:
// 09/24/2003 : olego - Created (in griddy prototype branch);
// 10/27/2003 : olego - Ported from griddy prototype branch;
//
//---------------------------------------------------------------------------
using MS.Internal;
using System.ComponentModel;
using System.Globalization;
namespace System.Windows
{
///
/// GridUnitType enum is used to indicate what kind of value the
/// GridLength is holding.
///
// Note: Keep the GridUnitType enum in [....] with the string representation
// of units (GridLengthConverter._unitString).
public enum GridUnitType
{
///
/// The value indicates that content should be calculated without constraints.
///
Auto = 0,
///
/// The value is expressed as a pixel.
///
Pixel,
///
/// The value is expressed as a weighted proportion of available space.
///
Star,
}
///
/// GridLength is the type used for various length-like properties in the system,
/// that explicitely support Star unit type. For example, "Width", "Height"
/// properties of ColumnDefinition and RowDefinition used by Grid.
///
[TypeConverter(typeof(GridLengthConverter))]
public struct GridLength : IEquatable
{
//-----------------------------------------------------
//
// Constructors
//
//-----------------------------------------------------
#region Constructors
///
/// Constructor, initializes the GridLength as absolute value in pixels.
///
/// Specifies the number of 'device-independent pixels'
/// (96 pixels-per-inch).
///
/// If pixels parameter is double.NaN
/// or pixels parameter is double.NegativeInfinity
/// or pixels parameter is double.PositiveInfinity .
///
public GridLength(double pixels)
: this(pixels, GridUnitType.Pixel)
{
}
///
/// Constructor, initializes the GridLength and specifies what kind of value
/// it will hold.
///
/// Value to be stored by this GridLength
/// instance.
/// Type of the value to be stored by this GridLength
/// instance.
///
/// If the type parameter is GridUnitType.Auto ,
/// then passed in value is ignored and replaced with 0 .
///
///
/// If value parameter is double.NaN
/// or value parameter is double.NegativeInfinity
/// or value parameter is double.PositiveInfinity .
///
public GridLength(double value, GridUnitType type)
{
if (DoubleUtil.IsNaN(value))
{
throw new ArgumentException(SR.Get(SRID.InvalidCtorParameterNoNaN, "value"));
}
if (double.IsInfinity(value))
{
throw new ArgumentException(SR.Get(SRID.InvalidCtorParameterNoInfinity, "value"));
}
if ( type != GridUnitType.Auto
&& type != GridUnitType.Pixel
&& type != GridUnitType.Star )
{
throw new ArgumentException(SR.Get(SRID.InvalidCtorParameterUnknownGridUnitType, "type"));
}
_unitValue = (type == GridUnitType.Auto) ? 0.0 : value;
_unitType = type;
}
#endregion Constructors
//------------------------------------------------------
//
// Public Methods
//
//-----------------------------------------------------
#region Public Methods
///
/// Overloaded operator, compares 2 GridLength's.
///
/// first GridLength to compare.
/// second GridLength to compare.
/// true if specified GridLengths have same value
/// and unit type.
public static bool operator == (GridLength gl1, GridLength gl2)
{
return ( gl1.GridUnitType == gl2.GridUnitType
&& gl1.Value == gl2.Value );
}
///
/// Overloaded operator, compares 2 GridLength's.
///
/// first GridLength to compare.
/// second GridLength to compare.
/// true if specified GridLengths have either different value or
/// unit type.
public static bool operator != (GridLength gl1, GridLength gl2)
{
return ( gl1.GridUnitType != gl2.GridUnitType
|| gl1.Value != gl2.Value );
}
///
/// Compares this instance of GridLength with another object.
///
/// Reference to an object for comparison.
/// true if this GridLength instance has the same value
/// and unit type as oCompare.
override public bool Equals(object oCompare)
{
if(oCompare is GridLength)
{
GridLength l = (GridLength)oCompare;
return (this == l);
}
else
return false;
}
///
/// Compares this instance of GridLength with another instance.
///
/// Grid length instance to compare.
/// true if this GridLength instance has the same value
/// and unit type as gridLength.
public bool Equals(GridLength gridLength)
{
return (this == gridLength);
}
///
///
///
///
public override int GetHashCode()
{
return ((int)_unitValue + (int)_unitType);
}
///
/// Returns true if this GridLength instance holds
/// an absolute (pixel) value.
///
public bool IsAbsolute { get { return (_unitType == GridUnitType.Pixel); } }
///
/// Returns true if this GridLength instance is
/// automatic (not specified).
///
public bool IsAuto { get { return (_unitType == GridUnitType.Auto); } }
///
/// Returns true if this GridLength instance holds weighted propertion
/// of available space.
///
public bool IsStar { get { return (_unitType == GridUnitType.Star); } }
///
/// Returns value part of this GridLength instance.
///
public double Value { get { return ((_unitType == GridUnitType.Auto) ? 1.0 : _unitValue); } }
///
/// Returns unit type of this GridLength instance.
///
public GridUnitType GridUnitType { get { return (_unitType); } }
///
/// Returns the string representation of this object.
///
public override string ToString()
{
return GridLengthConverter.ToString(this, CultureInfo.InvariantCulture);
}
#endregion Public Methods
//------------------------------------------------------
//
// Public Properties
//
//------------------------------------------------------
#region Public Properties
///
/// Returns initialized Auto GridLength value.
///
public static GridLength Auto
{
get { return (s_auto); }
}
#endregion Public Properties
//-----------------------------------------------------
//
// Private Fields
//
//------------------------------------------------------
#region Private Fields
private double _unitValue; // unit value storage
private GridUnitType _unitType; // unit type storage
// static instance of Auto GridLength
private static readonly GridLength s_auto = new GridLength(1.0, GridUnitType.Auto);
#endregion Private Fields
}
}
// 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
- DataGridViewColumnDesignTimeVisibleAttribute.cs
- WebControlParameterProxy.cs
- RoleGroupCollection.cs
- AutoScrollHelper.cs
- TableAdapterManagerHelper.cs
- SpellerInterop.cs
- GenericUriParser.cs
- PointCollectionConverter.cs
- CommandBinding.cs
- AssemblyLoader.cs
- GenericTransactionFlowAttribute.cs
- PreloadedPackages.cs
- DetailsViewDeletedEventArgs.cs
- SafeSystemMetrics.cs
- ModelServiceImpl.cs
- SQLInt16.cs
- MergablePropertyAttribute.cs
- _TimerThread.cs
- ByteAnimationBase.cs
- DocumentViewerBaseAutomationPeer.cs
- PassportAuthentication.cs
- ColorMap.cs
- bidPrivateBase.cs
- HttpStreamXmlDictionaryWriter.cs
- FixedStringLookup.cs
- _TimerThread.cs
- ConditionValidator.cs
- AuthenticationService.cs
- MatrixTransform3D.cs
- ToolStripCodeDomSerializer.cs
- EDesignUtil.cs
- ItemCheckedEvent.cs
- ProvidePropertyAttribute.cs
- TextBoxBase.cs
- ValidatorCollection.cs
- ClientProtocol.cs
- ComNativeDescriptor.cs
- HybridCollection.cs
- XPathMultyIterator.cs
- InvokeMethodDesigner.xaml.cs
- Vector.cs
- OletxResourceManager.cs
- unsafeIndexingFilterStream.cs
- SpoolingTask.cs
- LocatorPart.cs
- ToolStripSplitButton.cs
- StringHandle.cs
- IssuedSecurityTokenParameters.cs
- NodeInfo.cs
- IChannel.cs
- SqlMethods.cs
- MetadataArtifactLoader.cs
- TreeViewItem.cs
- CompensatableSequenceActivity.cs
- BaseConfigurationRecord.cs
- PathGeometry.cs
- HttpServerUtilityBase.cs
- ObjectDataSourceMethodEventArgs.cs
- DesignerForm.cs
- MenuAutomationPeer.cs
- ErrorFormatter.cs
- URI.cs
- _NegotiateClient.cs
- RotateTransform3D.cs
- EventLogEntryCollection.cs
- Crypto.cs
- CriticalFinalizerObject.cs
- XPathPatternParser.cs
- SqlDataSourceSelectingEventArgs.cs
- GroupBoxAutomationPeer.cs
- HtmlInputImage.cs
- XamlReaderHelper.cs
- ControlPaint.cs
- XmlQueryCardinality.cs
- MetadataConversionError.cs
- WindowsStatusBar.cs
- DataBindEngine.cs
- WeakReference.cs
- HttpRequest.cs
- DataSourceView.cs
- SystemEvents.cs
- WindowsToolbar.cs
- ExplicitDiscriminatorMap.cs
- ControlAdapter.cs
- DesignerDataRelationship.cs
- ImmutableCollection.cs
- SmtpNtlmAuthenticationModule.cs
- ResourceWriter.cs
- PerformanceCountersBase.cs
- PtsHost.cs
- _ReceiveMessageOverlappedAsyncResult.cs
- XmlUtf8RawTextWriter.cs
- SystemIPInterfaceProperties.cs
- LinqDataSourceSelectEventArgs.cs
- CodeTypeReference.cs
- ParameterToken.cs
- SafeCryptoKeyHandle.cs
- TreeNodeMouseHoverEvent.cs
- MarkerProperties.cs
- ConfigXmlCDataSection.cs