Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Core / CSharp / System / Windows / Media3D / Size3D.cs / 1 / Size3D.cs
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
//
// Description: 3D size implementation.
//
//
//
// History:
// 06/26/2003 : t-gregr - Created
//
//---------------------------------------------------------------------------
using System.Windows;
using System.Windows.Media.Media3D;
using System;
using SR=MS.Internal.PresentationCore.SR;
using SRID=MS.Internal.PresentationCore.SRID;
namespace System.Windows.Media.Media3D
{
///
/// Size3D - A value type which defined a size in terms of non-negative width,
/// length, and height.
///
public partial struct Size3D
{
#region Constructors
///
/// Constructor which sets the size's initial values. Values must be non-negative.
///
/// X dimension of the new size.
/// Y dimension of the new size.
/// Z dimension of the new size.
public Size3D(double x, double y, double z)
{
if (x < 0 || y < 0 || z < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_x = x;
_y = y;
_z = z;
}
#endregion Constructors
#region Statics
///
/// Empty - a static property which provides an Empty size. X, Y, and Z are
/// negative-infinity. This is the only situation
/// where size can be negative.
///
public static Size3D Empty
{
get
{
return s_empty;
}
}
#endregion Statics
#region Public Methods and Properties
///
/// IsEmpty - this returns true if this size is the Empty size.
/// Note: If size is 0 this Size3D still contains a 0, 1, or 2 dimensional set
/// of points, so this method should not be used to check for 0 volume.
///
public bool IsEmpty
{
get
{
return _x < 0;
}
}
///
/// Size in X dimension. Default is 0, must be non-negative.
///
public double X
{
get
{
return _x;
}
set
{
if (IsEmpty)
{
throw new System.InvalidOperationException(SR.Get(SRID.Size3D_CannotModifyEmptySize));
}
if (value < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_x = value;
}
}
///
/// Size in Y dimension. Default is 0, must be non-negative.
///
public double Y
{
get
{
return _y;
}
set
{
if (IsEmpty)
{
throw new System.InvalidOperationException(SR.Get(SRID.Size3D_CannotModifyEmptySize));
}
if (value < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_y = value;
}
}
///
/// Size in Z dimension. Default is 0, must be non-negative.
///
public double Z
{
get
{
return _z;
}
set
{
if (IsEmpty)
{
throw new System.InvalidOperationException(SR.Get(SRID.Size3D_CannotModifyEmptySize));
}
if (value < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_z = value;
}
}
#endregion Public Methods
#region Public Operators
///
/// Explicit conversion to Vector.
///
/// The size to convert to a vector.
/// A vector equal to this size.
public static explicit operator Vector3D(Size3D size)
{
return new Vector3D(size._x, size._y, size._z);
}
///
/// Explicit conversion to point.
///
/// The size to convert to a point.
/// A point equal to this size.
public static explicit operator Point3D(Size3D size)
{
return new Point3D(size._x, size._y, size._z);
}
#endregion Public Operators
#region Private Methods
private static Size3D CreateEmptySize3D()
{
Size3D empty = new Size3D();
// Can't use setters because they throw on negative values
empty._x = Double.NegativeInfinity;
empty._y = Double.NegativeInfinity;
empty._z = Double.NegativeInfinity;
return empty;
}
#endregion Private Methods
#region Private Fields
private readonly static Size3D s_empty = CreateEmptySize3D();
#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: 3D size implementation.
//
//
//
// History:
// 06/26/2003 : t-gregr - Created
//
//---------------------------------------------------------------------------
using System.Windows;
using System.Windows.Media.Media3D;
using System;
using SR=MS.Internal.PresentationCore.SR;
using SRID=MS.Internal.PresentationCore.SRID;
namespace System.Windows.Media.Media3D
{
///
/// Size3D - A value type which defined a size in terms of non-negative width,
/// length, and height.
///
public partial struct Size3D
{
#region Constructors
///
/// Constructor which sets the size's initial values. Values must be non-negative.
///
/// X dimension of the new size.
/// Y dimension of the new size.
/// Z dimension of the new size.
public Size3D(double x, double y, double z)
{
if (x < 0 || y < 0 || z < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_x = x;
_y = y;
_z = z;
}
#endregion Constructors
#region Statics
///
/// Empty - a static property which provides an Empty size. X, Y, and Z are
/// negative-infinity. This is the only situation
/// where size can be negative.
///
public static Size3D Empty
{
get
{
return s_empty;
}
}
#endregion Statics
#region Public Methods and Properties
///
/// IsEmpty - this returns true if this size is the Empty size.
/// Note: If size is 0 this Size3D still contains a 0, 1, or 2 dimensional set
/// of points, so this method should not be used to check for 0 volume.
///
public bool IsEmpty
{
get
{
return _x < 0;
}
}
///
/// Size in X dimension. Default is 0, must be non-negative.
///
public double X
{
get
{
return _x;
}
set
{
if (IsEmpty)
{
throw new System.InvalidOperationException(SR.Get(SRID.Size3D_CannotModifyEmptySize));
}
if (value < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_x = value;
}
}
///
/// Size in Y dimension. Default is 0, must be non-negative.
///
public double Y
{
get
{
return _y;
}
set
{
if (IsEmpty)
{
throw new System.InvalidOperationException(SR.Get(SRID.Size3D_CannotModifyEmptySize));
}
if (value < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_y = value;
}
}
///
/// Size in Z dimension. Default is 0, must be non-negative.
///
public double Z
{
get
{
return _z;
}
set
{
if (IsEmpty)
{
throw new System.InvalidOperationException(SR.Get(SRID.Size3D_CannotModifyEmptySize));
}
if (value < 0)
{
throw new System.ArgumentException(SR.Get(SRID.Size3D_DimensionCannotBeNegative));
}
_z = value;
}
}
#endregion Public Methods
#region Public Operators
///
/// Explicit conversion to Vector.
///
/// The size to convert to a vector.
/// A vector equal to this size.
public static explicit operator Vector3D(Size3D size)
{
return new Vector3D(size._x, size._y, size._z);
}
///
/// Explicit conversion to point.
///
/// The size to convert to a point.
/// A point equal to this size.
public static explicit operator Point3D(Size3D size)
{
return new Point3D(size._x, size._y, size._z);
}
#endregion Public Operators
#region Private Methods
private static Size3D CreateEmptySize3D()
{
Size3D empty = new Size3D();
// Can't use setters because they throw on negative values
empty._x = Double.NegativeInfinity;
empty._y = Double.NegativeInfinity;
empty._z = Double.NegativeInfinity;
return empty;
}
#endregion Private Methods
#region Private Fields
private readonly static Size3D s_empty = CreateEmptySize3D();
#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
- TreeNodeStyle.cs
- EventLogStatus.cs
- VerticalAlignConverter.cs
- CustomErrorsSection.cs
- storepermissionattribute.cs
- PasswordDeriveBytes.cs
- ProcessModule.cs
- DataGridViewAccessibleObject.cs
- LogStream.cs
- EncoderFallback.cs
- HebrewNumber.cs
- SqlDataSourceCommandEventArgs.cs
- DashStyle.cs
- CardSpaceShim.cs
- SetterBase.cs
- PolygonHotSpot.cs
- SchemeSettingElement.cs
- CodeGen.cs
- SettingsBindableAttribute.cs
- InternalDuplexBindingElement.cs
- ApplicationBuildProvider.cs
- Exceptions.cs
- SqlUserDefinedTypeAttribute.cs
- UrlMappingsSection.cs
- CultureSpecificStringDictionary.cs
- DataGridCellInfo.cs
- SignatureHelper.cs
- AttributeEmitter.cs
- ProjectionPlanCompiler.cs
- DBCSCodePageEncoding.cs
- CultureSpecificCharacterBufferRange.cs
- SystemColors.cs
- BasePattern.cs
- Executor.cs
- ElementProxy.cs
- TableRow.cs
- DuplicateDetector.cs
- initElementDictionary.cs
- DataGridPageChangedEventArgs.cs
- ContentType.cs
- SecurityCriticalDataForSet.cs
- CacheChildrenQuery.cs
- HttpCookieCollection.cs
- OleStrCAMarshaler.cs
- webeventbuffer.cs
- DataFormats.cs
- GridEntry.cs
- Screen.cs
- LockCookie.cs
- Executor.cs
- PageThemeParser.cs
- ProfileInfo.cs
- XmlILCommand.cs
- XmlIncludeAttribute.cs
- CommandDevice.cs
- CodeGroup.cs
- SessionPageStatePersister.cs
- AutoResizedEvent.cs
- AttributeUsageAttribute.cs
- querybuilder.cs
- DtrList.cs
- ProvidersHelper.cs
- SoapElementAttribute.cs
- MessageSmuggler.cs
- WorkflowItemPresenter.cs
- IisTraceWebEventProvider.cs
- ConversionHelper.cs
- ProviderSettingsCollection.cs
- EnumBuilder.cs
- X509ThumbprintKeyIdentifierClause.cs
- HttpServerProtocol.cs
- CfgArc.cs
- OneWayChannelListener.cs
- BrowserCapabilitiesFactoryBase.cs
- OneOfTypeConst.cs
- IdentityValidationException.cs
- DataGridRow.cs
- ContainerParaClient.cs
- MSAANativeProvider.cs
- Mouse.cs
- SrgsElement.cs
- SqlDataSourceTableQuery.cs
- ParallelDesigner.xaml.cs
- MappingMetadataHelper.cs
- QuaternionRotation3D.cs
- mda.cs
- HtmlInputFile.cs
- ListViewUpdateEventArgs.cs
- Label.cs
- StylusPointPropertyInfoDefaults.cs
- TableItemPattern.cs
- SelectedDatesCollection.cs
- ObjectQueryExecutionPlan.cs
- OrderPreservingMergeHelper.cs
- TextEditorCopyPaste.cs
- WorkflowRuntimeService.cs
- MailAddress.cs
- Int32CollectionConverter.cs
- DbModificationClause.cs
- ClickablePoint.cs