Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / wpf / src / Core / CSharp / System / Windows / Media3D / Generated / Quaternion.cs / 1 / Quaternion.cs
//----------------------------------------------------------------------------
//
//
// Copyright (C) Microsoft Corporation. All rights reserved.
//
//
// This file was generated, please do not edit it directly.
//
// Please see http://wiki/default.aspx/Microsoft.Projects.Avalon/MilCodeGen.html for more information.
//
//---------------------------------------------------------------------------
using MS.Internal;
using MS.Internal.Collections;
using MS.Internal.PresentationCore;
using MS.Utility;
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.Design.Serialization;
using System.Diagnostics;
using System.Globalization;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Text;
using System.Windows.Markup;
using System.Windows.Media.Media3D.Converters;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Media.Composition;
using System.Security;
using System.Security.Permissions;
using SR=MS.Internal.PresentationCore.SR;
using SRID=MS.Internal.PresentationCore.SRID;
using System.Windows.Media.Imaging;
// These types are aliased to match the unamanaged names used in interop
using BOOL = System.UInt32;
using WORD = System.UInt16;
using Float = System.Single;
namespace System.Windows.Media.Media3D
{
[Serializable]
[TypeConverter(typeof(QuaternionConverter))]
[ValueSerializer(typeof(QuaternionValueSerializer))] // Used by MarkupWriter
partial struct Quaternion : IFormattable
{
//-----------------------------------------------------
//
// Public Methods
//
//-----------------------------------------------------
#region Public Methods
///
/// Compares two Quaternion instances for exact equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which are logically equal may fail.
/// Furthermore, using this equality operator, Double.NaN is not equal to itself.
///
///
/// bool - true if the two Quaternion instances are exactly equal, false otherwise
///
/// The first Quaternion to compare
/// The second Quaternion to compare
public static bool operator == (Quaternion quaternion1, Quaternion quaternion2)
{
if (quaternion1.IsDistinguishedIdentity || quaternion2.IsDistinguishedIdentity)
{
return quaternion1.IsIdentity == quaternion2.IsIdentity;
}
else
{
return quaternion1.X == quaternion2.X &&
quaternion1.Y == quaternion2.Y &&
quaternion1.Z == quaternion2.Z &&
quaternion1.W == quaternion2.W;
}
}
///
/// Compares two Quaternion instances for exact inequality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which are logically equal may fail.
/// Furthermore, using this equality operator, Double.NaN is not equal to itself.
///
///
/// bool - true if the two Quaternion instances are exactly unequal, false otherwise
///
/// The first Quaternion to compare
/// The second Quaternion to compare
public static bool operator != (Quaternion quaternion1, Quaternion quaternion2)
{
return !(quaternion1 == quaternion2);
}
///
/// Compares two Quaternion instances for object equality. In this equality
/// Double.NaN is equal to itself, unlike in numeric equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which
/// are logically equal may fail.
///
///
/// bool - true if the two Quaternion instances are exactly equal, false otherwise
///
/// The first Quaternion to compare
/// The second Quaternion to compare
public static bool Equals (Quaternion quaternion1, Quaternion quaternion2)
{
if (quaternion1.IsDistinguishedIdentity || quaternion2.IsDistinguishedIdentity)
{
return quaternion1.IsIdentity == quaternion2.IsIdentity;
}
else
{
return quaternion1.X.Equals(quaternion2.X) &&
quaternion1.Y.Equals(quaternion2.Y) &&
quaternion1.Z.Equals(quaternion2.Z) &&
quaternion1.W.Equals(quaternion2.W);
}
}
///
/// Equals - compares this Quaternion with the passed in object. In this equality
/// Double.NaN is equal to itself, unlike in numeric equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which
/// are logically equal may fail.
///
///
/// bool - true if the object is an instance of Quaternion and if it's equal to "this".
///
/// The object to compare to "this"
public override bool Equals(object o)
{
if ((null == o) || !(o is Quaternion))
{
return false;
}
Quaternion value = (Quaternion)o;
return Quaternion.Equals(this,value);
}
///
/// Equals - compares this Quaternion with the passed in object. In this equality
/// Double.NaN is equal to itself, unlike in numeric equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which
/// are logically equal may fail.
///
///
/// bool - true if "value" is equal to "this".
///
/// The Quaternion to compare to "this"
public bool Equals(Quaternion value)
{
return Quaternion.Equals(this, value);
}
///
/// Returns the HashCode for this Quaternion
///
///
/// int - the HashCode for this Quaternion
///
public override int GetHashCode()
{
if (IsDistinguishedIdentity)
{
return c_identityHashCode;
}
else
{
// Perform field-by-field XOR of HashCodes
return X.GetHashCode() ^
Y.GetHashCode() ^
Z.GetHashCode() ^
W.GetHashCode();
}
}
///
/// Parse - returns an instance converted from the provided string using
/// the culture "en-US"
/// string with Quaternion data
///
public static Quaternion Parse(string source)
{
IFormatProvider formatProvider = CultureInfo.GetCultureInfo("en-us");
TokenizerHelper th = new TokenizerHelper(source, formatProvider);
Quaternion value;
String firstToken = th.NextTokenRequired();
// The token will already have had whitespace trimmed so we can do a
// simple string compare.
if (firstToken == "Identity")
{
value = Identity;
}
else
{
value = new Quaternion(
Convert.ToDouble(firstToken, formatProvider),
Convert.ToDouble(th.NextTokenRequired(), formatProvider),
Convert.ToDouble(th.NextTokenRequired(), formatProvider),
Convert.ToDouble(th.NextTokenRequired(), formatProvider));
}
// There should be no more tokens in this string.
th.LastTokenRequired();
return value;
}
#endregion Public Methods
//------------------------------------------------------
//
// Public Properties
//
//-----------------------------------------------------
#region Public Properties
#endregion Public Properties
//------------------------------------------------------
//
// Protected Methods
//
//------------------------------------------------------
#region Protected Methods
#endregion ProtectedMethods
//-----------------------------------------------------
//
// Internal Methods
//
//------------------------------------------------------
#region Internal Methods
#endregion Internal Methods
//-----------------------------------------------------
//
// Internal Properties
//
//-----------------------------------------------------
#region Internal Properties
///
/// Creates a string representation of this object based on the current culture.
///
///
/// A string representation of this object.
///
public override string ToString()
{
// Delegate to the internal method which implements all ToString calls.
return ConvertToString(null /* format string */, null /* format provider */);
}
///
/// Creates a string representation of this object based on the IFormatProvider
/// passed in. If the provider is null, the CurrentCulture is used.
///
///
/// A string representation of this object.
///
public string ToString(IFormatProvider provider)
{
// Delegate to the internal method which implements all ToString calls.
return ConvertToString(null /* format string */, provider);
}
///
/// Creates a string representation of this object based on the format string
/// and IFormatProvider passed in.
/// If the provider is null, the CurrentCulture is used.
/// See the documentation for IFormattable for more information.
///
///
/// A string representation of this object.
///
string IFormattable.ToString(string format, IFormatProvider provider)
{
// Delegate to the internal method which implements all ToString calls.
return ConvertToString(format, provider);
}
///
/// Creates a string representation of this object based on the format string
/// and IFormatProvider passed in.
/// If the provider is null, the CurrentCulture is used.
/// See the documentation for IFormattable for more information.
///
///
/// A string representation of this object.
///
internal string ConvertToString(string format, IFormatProvider provider)
{
if (IsIdentity)
{
return "Identity";
}
// Helper to get the numeric list separator for a given culture.
char separator = MS.Internal.TokenizerHelper.GetNumericListSeparator(provider);
return String.Format(provider,
"{1:" + format + "}{0}{2:" + format + "}{0}{3:" + format + "}{0}{4:" + format + "}",
separator,
_x,
_y,
_z,
_w);
}
#endregion Internal Properties
//-----------------------------------------------------
//
// Dependency Properties
//
//------------------------------------------------------
#region Dependency Properties
#endregion Dependency Properties
//-----------------------------------------------------
//
// Internal Fields
//
//------------------------------------------------------
#region Internal Fields
#endregion Internal Fields
#region Constructors
//------------------------------------------------------
//
// Constructors
//
//-----------------------------------------------------
#endregion Constructors
}
}
// 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.
//
//
// This file was generated, please do not edit it directly.
//
// Please see http://wiki/default.aspx/Microsoft.Projects.Avalon/MilCodeGen.html for more information.
//
//---------------------------------------------------------------------------
using MS.Internal;
using MS.Internal.Collections;
using MS.Internal.PresentationCore;
using MS.Utility;
using System;
using System.Collections;
using System.Collections.Generic;
using System.ComponentModel;
using System.ComponentModel.Design.Serialization;
using System.Diagnostics;
using System.Globalization;
using System.Reflection;
using System.Runtime.InteropServices;
using System.Text;
using System.Windows.Markup;
using System.Windows.Media.Media3D.Converters;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Media.Composition;
using System.Security;
using System.Security.Permissions;
using SR=MS.Internal.PresentationCore.SR;
using SRID=MS.Internal.PresentationCore.SRID;
using System.Windows.Media.Imaging;
// These types are aliased to match the unamanaged names used in interop
using BOOL = System.UInt32;
using WORD = System.UInt16;
using Float = System.Single;
namespace System.Windows.Media.Media3D
{
[Serializable]
[TypeConverter(typeof(QuaternionConverter))]
[ValueSerializer(typeof(QuaternionValueSerializer))] // Used by MarkupWriter
partial struct Quaternion : IFormattable
{
//-----------------------------------------------------
//
// Public Methods
//
//-----------------------------------------------------
#region Public Methods
///
/// Compares two Quaternion instances for exact equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which are logically equal may fail.
/// Furthermore, using this equality operator, Double.NaN is not equal to itself.
///
///
/// bool - true if the two Quaternion instances are exactly equal, false otherwise
///
/// The first Quaternion to compare
/// The second Quaternion to compare
public static bool operator == (Quaternion quaternion1, Quaternion quaternion2)
{
if (quaternion1.IsDistinguishedIdentity || quaternion2.IsDistinguishedIdentity)
{
return quaternion1.IsIdentity == quaternion2.IsIdentity;
}
else
{
return quaternion1.X == quaternion2.X &&
quaternion1.Y == quaternion2.Y &&
quaternion1.Z == quaternion2.Z &&
quaternion1.W == quaternion2.W;
}
}
///
/// Compares two Quaternion instances for exact inequality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which are logically equal may fail.
/// Furthermore, using this equality operator, Double.NaN is not equal to itself.
///
///
/// bool - true if the two Quaternion instances are exactly unequal, false otherwise
///
/// The first Quaternion to compare
/// The second Quaternion to compare
public static bool operator != (Quaternion quaternion1, Quaternion quaternion2)
{
return !(quaternion1 == quaternion2);
}
///
/// Compares two Quaternion instances for object equality. In this equality
/// Double.NaN is equal to itself, unlike in numeric equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which
/// are logically equal may fail.
///
///
/// bool - true if the two Quaternion instances are exactly equal, false otherwise
///
/// The first Quaternion to compare
/// The second Quaternion to compare
public static bool Equals (Quaternion quaternion1, Quaternion quaternion2)
{
if (quaternion1.IsDistinguishedIdentity || quaternion2.IsDistinguishedIdentity)
{
return quaternion1.IsIdentity == quaternion2.IsIdentity;
}
else
{
return quaternion1.X.Equals(quaternion2.X) &&
quaternion1.Y.Equals(quaternion2.Y) &&
quaternion1.Z.Equals(quaternion2.Z) &&
quaternion1.W.Equals(quaternion2.W);
}
}
///
/// Equals - compares this Quaternion with the passed in object. In this equality
/// Double.NaN is equal to itself, unlike in numeric equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which
/// are logically equal may fail.
///
///
/// bool - true if the object is an instance of Quaternion and if it's equal to "this".
///
/// The object to compare to "this"
public override bool Equals(object o)
{
if ((null == o) || !(o is Quaternion))
{
return false;
}
Quaternion value = (Quaternion)o;
return Quaternion.Equals(this,value);
}
///
/// Equals - compares this Quaternion with the passed in object. In this equality
/// Double.NaN is equal to itself, unlike in numeric equality.
/// Note that double values can acquire error when operated upon, such that
/// an exact comparison between two values which
/// are logically equal may fail.
///
///
/// bool - true if "value" is equal to "this".
///
/// The Quaternion to compare to "this"
public bool Equals(Quaternion value)
{
return Quaternion.Equals(this, value);
}
///
/// Returns the HashCode for this Quaternion
///
///
/// int - the HashCode for this Quaternion
///
public override int GetHashCode()
{
if (IsDistinguishedIdentity)
{
return c_identityHashCode;
}
else
{
// Perform field-by-field XOR of HashCodes
return X.GetHashCode() ^
Y.GetHashCode() ^
Z.GetHashCode() ^
W.GetHashCode();
}
}
///
/// Parse - returns an instance converted from the provided string using
/// the culture "en-US"
/// string with Quaternion data
///
public static Quaternion Parse(string source)
{
IFormatProvider formatProvider = CultureInfo.GetCultureInfo("en-us");
TokenizerHelper th = new TokenizerHelper(source, formatProvider);
Quaternion value;
String firstToken = th.NextTokenRequired();
// The token will already have had whitespace trimmed so we can do a
// simple string compare.
if (firstToken == "Identity")
{
value = Identity;
}
else
{
value = new Quaternion(
Convert.ToDouble(firstToken, formatProvider),
Convert.ToDouble(th.NextTokenRequired(), formatProvider),
Convert.ToDouble(th.NextTokenRequired(), formatProvider),
Convert.ToDouble(th.NextTokenRequired(), formatProvider));
}
// There should be no more tokens in this string.
th.LastTokenRequired();
return value;
}
#endregion Public Methods
//------------------------------------------------------
//
// Public Properties
//
//-----------------------------------------------------
#region Public Properties
#endregion Public Properties
//------------------------------------------------------
//
// Protected Methods
//
//------------------------------------------------------
#region Protected Methods
#endregion ProtectedMethods
//-----------------------------------------------------
//
// Internal Methods
//
//------------------------------------------------------
#region Internal Methods
#endregion Internal Methods
//-----------------------------------------------------
//
// Internal Properties
//
//-----------------------------------------------------
#region Internal Properties
///
/// Creates a string representation of this object based on the current culture.
///
///
/// A string representation of this object.
///
public override string ToString()
{
// Delegate to the internal method which implements all ToString calls.
return ConvertToString(null /* format string */, null /* format provider */);
}
///
/// Creates a string representation of this object based on the IFormatProvider
/// passed in. If the provider is null, the CurrentCulture is used.
///
///
/// A string representation of this object.
///
public string ToString(IFormatProvider provider)
{
// Delegate to the internal method which implements all ToString calls.
return ConvertToString(null /* format string */, provider);
}
///
/// Creates a string representation of this object based on the format string
/// and IFormatProvider passed in.
/// If the provider is null, the CurrentCulture is used.
/// See the documentation for IFormattable for more information.
///
///
/// A string representation of this object.
///
string IFormattable.ToString(string format, IFormatProvider provider)
{
// Delegate to the internal method which implements all ToString calls.
return ConvertToString(format, provider);
}
///
/// Creates a string representation of this object based on the format string
/// and IFormatProvider passed in.
/// If the provider is null, the CurrentCulture is used.
/// See the documentation for IFormattable for more information.
///
///
/// A string representation of this object.
///
internal string ConvertToString(string format, IFormatProvider provider)
{
if (IsIdentity)
{
return "Identity";
}
// Helper to get the numeric list separator for a given culture.
char separator = MS.Internal.TokenizerHelper.GetNumericListSeparator(provider);
return String.Format(provider,
"{1:" + format + "}{0}{2:" + format + "}{0}{3:" + format + "}{0}{4:" + format + "}",
separator,
_x,
_y,
_z,
_w);
}
#endregion Internal Properties
//-----------------------------------------------------
//
// Dependency Properties
//
//------------------------------------------------------
#region Dependency Properties
#endregion Dependency Properties
//-----------------------------------------------------
//
// Internal Fields
//
//------------------------------------------------------
#region Internal Fields
#endregion Internal Fields
#region Constructors
//------------------------------------------------------
//
// Constructors
//
//-----------------------------------------------------
#endregion Constructors
}
}
// 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
- CqlLexerHelpers.cs
- ColumnWidthChangedEvent.cs
- DataTablePropertyDescriptor.cs
- SystemParameters.cs
- AppDomainFactory.cs
- ZoneLinkButton.cs
- HtmlEncodedRawTextWriter.cs
- SqlConnection.cs
- UriSection.cs
- NestPullup.cs
- ManagementObject.cs
- RevocationPoint.cs
- ToolStripContainerActionList.cs
- AvTraceFormat.cs
- TaskbarItemInfo.cs
- ControlAdapter.cs
- LayoutEngine.cs
- ChooseAction.cs
- Certificate.cs
- MetadataArtifactLoaderXmlReaderWrapper.cs
- XsltContext.cs
- SimpleTextLine.cs
- PenThreadWorker.cs
- BrushValueSerializer.cs
- HelpInfo.cs
- OdbcFactory.cs
- WindowProviderWrapper.cs
- SizeFConverter.cs
- RuntimeIdentifierPropertyAttribute.cs
- XmlSchemaComplexContentExtension.cs
- HandlerBase.cs
- OptionUsage.cs
- RealizedColumnsBlock.cs
- RectAnimationClockResource.cs
- DateTimeConstantAttribute.cs
- TdsParserSafeHandles.cs
- WindowsListViewGroupHelper.cs
- GPStream.cs
- SimpleTypeResolver.cs
- GraphicsPath.cs
- DynamicILGenerator.cs
- ActivitySurrogateSelector.cs
- SparseMemoryStream.cs
- XmlFormatMapping.cs
- XmlSchemaSimpleContentRestriction.cs
- Parallel.cs
- NegotiationTokenAuthenticator.cs
- BrowserDefinition.cs
- MetadataItemEmitter.cs
- MenuItemStyle.cs
- SapiRecoContext.cs
- TemplatedMailWebEventProvider.cs
- ApplicationServiceHelper.cs
- SystemWebSectionGroup.cs
- DataGridBoolColumn.cs
- XmlSchemaNotation.cs
- Expander.cs
- QuaternionConverter.cs
- TableLayoutSettingsTypeConverter.cs
- DataGridTextBoxColumn.cs
- PackWebRequest.cs
- SessionState.cs
- TypeBuilder.cs
- Vector.cs
- TextParaClient.cs
- ConstraintEnumerator.cs
- LayoutUtils.cs
- WsdlInspector.cs
- FileRecordSequenceHelper.cs
- PenLineCapValidation.cs
- SEHException.cs
- SqlFacetAttribute.cs
- MetaData.cs
- StorageEntityContainerMapping.cs
- dataprotectionpermissionattribute.cs
- QuaternionAnimationBase.cs
- ResourcesChangeInfo.cs
- ErrorFormatter.cs
- FrugalMap.cs
- ComboBox.cs
- DecimalConstantAttribute.cs
- DataPagerFieldItem.cs
- Animatable.cs
- RemoteWebConfigurationHostServer.cs
- __TransparentProxy.cs
- Vector3DAnimationBase.cs
- Label.cs
- ELinqQueryState.cs
- DataServiceHostWrapper.cs
- HtmlInputImage.cs
- PackWebResponse.cs
- PropertyGroupDescription.cs
- StrokeNodeEnumerator.cs
- UnsafeNativeMethods.cs
- ObfuscateAssemblyAttribute.cs
- BitHelper.cs
- InheritedPropertyChangedEventArgs.cs
- PersonalizationStateInfo.cs
- ConfigPathUtility.cs
- SystemIPGlobalProperties.cs