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 / 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
- DBSchemaTable.cs
- FixedStringLookup.cs
- SiteMapDataSource.cs
- EpmContentDeSerializer.cs
- DebugView.cs
- ListBase.cs
- WorkflowRuntimeEndpoint.cs
- SequenceRange.cs
- cryptoapiTransform.cs
- ViewBase.cs
- WorkflowOperationAsyncResult.cs
- Literal.cs
- InternalControlCollection.cs
- DataGridViewAutoSizeModeEventArgs.cs
- DurableEnlistmentState.cs
- CaseKeyBox.xaml.cs
- DependencyPropertyKind.cs
- ResXBuildProvider.cs
- Automation.cs
- AnimatedTypeHelpers.cs
- RuleSet.cs
- Array.cs
- SmtpException.cs
- SqlServer2KCompatibilityCheck.cs
- TableItemPattern.cs
- ProxyWebPartManager.cs
- SqlUserDefinedAggregateAttribute.cs
- NativeObjectSecurity.cs
- XslTransform.cs
- ModuleBuilder.cs
- QueryOutputWriterV1.cs
- Attributes.cs
- SafeHandle.cs
- CustomTypeDescriptor.cs
- Collection.cs
- TraceEventCache.cs
- InputProcessorProfiles.cs
- QilName.cs
- StrongNameMembershipCondition.cs
- RolePrincipal.cs
- FormClosingEvent.cs
- SchemaNamespaceManager.cs
- UnsafeNativeMethods.cs
- FacetValueContainer.cs
- ObjectContext.cs
- RangeValidator.cs
- ImageCodecInfo.cs
- HtmlFormAdapter.cs
- AsymmetricSignatureDeformatter.cs
- IdentityValidationException.cs
- CompositeDuplexElement.cs
- SignedPkcs7.cs
- Trace.cs
- XmlReaderSettings.cs
- XmlSchemaComplexContentExtension.cs
- QuaternionAnimation.cs
- XmlSchemaAttribute.cs
- TimerEventSubscriptionCollection.cs
- SharedPersonalizationStateInfo.cs
- TextAnchor.cs
- AutomationPatternInfo.cs
- ParentQuery.cs
- AtomParser.cs
- AnimatedTypeHelpers.cs
- ExternalCalls.cs
- WebPartDescription.cs
- ProviderSettingsCollection.cs
- HttpConfigurationSystem.cs
- DataGridColumnHeaderItemAutomationPeer.cs
- WsatAdminException.cs
- WindowsAuthenticationEventArgs.cs
- EntityReference.cs
- CollectionContainer.cs
- UInt32.cs
- HashAlgorithm.cs
- LineBreak.cs
- GregorianCalendar.cs
- CmsInterop.cs
- ComponentCommands.cs
- FontWeight.cs
- TableSectionStyle.cs
- Encoding.cs
- ControlCollection.cs
- RegistrySecurity.cs
- CleanUpVirtualizedItemEventArgs.cs
- regiisutil.cs
- MouseEvent.cs
- shaper.cs
- HttpCookie.cs
- DelegateBodyWriter.cs
- FileLevelControlBuilderAttribute.cs
- SoapExtensionTypeElement.cs
- XmlEncodedRawTextWriter.cs
- ObjectParameterCollection.cs
- ConfigXmlAttribute.cs
- StaticFileHandler.cs
- CodeBinaryOperatorExpression.cs
- KeyNotFoundException.cs
- Overlapped.cs
- _SecureChannel.cs