// Copyright (c) Xenko contributors (https://xenko.com) and Silicon Studio Corp. (https://www.siliconstudio.co.jp) // Distributed under the MIT license. See the LICENSE.md file in the project root for more information. // // Copyright (c) 2010-2011 SharpDX - Alexandre Mutel // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. using System; using System.ComponentModel; using System.Runtime.InteropServices; using System.Runtime.Serialization; namespace math { /// /// Represents a two dimensional mathematical vector with half-precision floats. /// [DataContract] [StructLayout( LayoutKind.Sequential, Pack = 2 )] public struct Half2 : IEquatable { /// /// Gets or sets the X component of the vector. /// /// The X component of the vector. public Half X; /// /// Gets or sets the Y component of the vector. /// /// The Y component of the vector. public Half Y; /// /// Initializes a new instance of the structure. /// /// The X component. /// The Y component. public Half2( Half x, Half y ) { this.X = x; this.Y = y; } /// /// Initializes a new instance of the structure. /// /// The value to set for both the X and Y components. public Half2( Half value ) { this.X = value; this.Y = value; } /// /// Initializes a new instance of the structure. /// /// The X component. /// The Y component. public Half2( float x, float y ) { this.X = (Half)x; this.Y = (Half)y; } /// /// Initializes a new instance of the structure. /// /// The value to set for both the X and Y components. public Half2( float value ) { this.X = (Half)value; this.Y = (Half)value; } /// /// Tests for equality between two objects. /// /// The first value to compare. /// The second value to compare. /// /// true if has the same value as ; otherwise, false. public static bool operator ==( Half2 left, Half2 right ) { return Equals( ref left, ref right ); } /// /// Tests for inequality between two objects. /// /// The first value to compare. /// The second value to compare. /// /// true if has a different value than ; otherwise, false. [return: MarshalAs( UnmanagedType.U1 )] public static bool operator !=( Half2 left, Half2 right ) { return !Equals( ref left, ref right ); } /// /// Returns the hash code for this instance. /// /// A 32-bit signed integer hash code. public override int GetHashCode() { return ( this.Y.GetHashCode() + this.X.GetHashCode() ); } /// /// Determines whether the specified object instances are considered equal. /// /// The first value. /// The second value. /// /// true if is the same instance as or /// if both are null references or if value1.Equals(value2) returns true; otherwise, false. public static bool Equals( ref Half2 value1, ref Half2 value2 ) { return ( ( value1.X == value2.X ) && ( value1.Y == value2.Y ) ); } /// /// Returns a value that indicates whether the current instance is equal to the specified object. /// /// Object to make the comparison with. /// /// true if the current instance is equal to the specified object; false otherwise. public bool Equals( Half2 other ) { return ( ( this.X == other.X ) && ( this.Y == other.Y ) ); } /// /// Returns a value that indicates whether the current instance is equal to a specified object. /// /// Object to make the comparison with. /// /// true if the current instance is equal to the specified object; false otherwise. public override bool Equals( object obj ) { if( obj == null ) { return false; } if( obj.GetType() != GetType() ) { return false; } return this.Equals( (Half2)obj ); } /// /// Performs an explicit conversion from to . /// /// The value. /// The result of the conversion. public static explicit operator Half2( Vec2 value ) { return new Half2( (Half)value.X, (Half)value.Y ); } /// /// Performs an explicit conversion from to . /// /// The value. /// The result of the conversion. public static explicit operator Vec2( Half2 value ) { return new Vec2( value.X, value.Y ); } } }