Exemplo n.º 1
0
 /// <summary>
 /// Initializes a new instance of the <see cref="Boxf"/> using the specified location and size.
 /// </summary>
 /// <param name="location">The front-lower-left corner of the box.</param>
 /// <param name="size">The size of the box.</param>
 public Boxf(Point3f location, Size3f size)
 {
     X      = location.X;
     Y      = location.Y;
     Z      = location.Z;
     Width  = size.Width;
     Height = size.Height;
     Depth  = size.Depth;
 }
Exemplo n.º 2
0
 /// <summary>
 /// Initializes a new instance of the <see cref="Boxf"/> using the specified location and size.
 /// </summary>
 /// <param name="x">Value for the X component of the box.</param>
 /// <param name="y">Value for the Y component of the box.</param>
 /// <param name="z">Value for the Z component of the box.</param>
 /// <param name="size">The size of the box.</param>
 public Boxf(float x, float y, float z, Size3f size)
 {
     X      = x;
     Y      = y;
     Z      = z;
     Width  = size.Width;
     Height = size.Height;
     Depth  = size.Depth;
 }
Exemplo n.º 3
0
 /// <summary>
 /// Returns a size where each component is rounded to the nearest integral value.
 /// </summary>
 /// <param name="value">A size.</param>
 /// <param name="digits">The number of fractional digits in the return value.</param>
 /// <returns>The result of rounding value.</returns>
 public static Size3f Round(Size3f value, int digits)
 {
     return(new Size3f(Functions.Round(value.Width, digits), Functions.Round(value.Height, digits), Functions.Round(value.Depth, digits)));
 }
Exemplo n.º 4
0
 /// <summary>
 /// Returns a size where each component is rounded to the nearest integral value.
 /// </summary>
 /// <param name="value">A size.</param>
 /// <param name="digits">The number of fractional digits in the return value.</param>
 /// <param name="mode">Specification for how to round value if it is midway between two other numbers.</param>
 /// <returns>The result of rounding value.</returns>
 public static Size3f Round(Size3f value, int digits, MidpointRounding mode)
 {
     return(new Size3f(Functions.Round(value.Width, digits, mode), Functions.Round(value.Height, digits, mode), Functions.Round(value.Depth, digits, mode)));
 }
Exemplo n.º 5
0
 /// <summary>
 /// Returns a size where each component is the fractional part of the specified component.
 /// </summary>
 /// <param name="value">A size.</param>
 /// <returns>The fractional of value.</returns>
 public static Size3f Fractional(Size3f value)
 {
     return(new Size3f(Functions.Fractional(value.Width), Functions.Fractional(value.Height), Functions.Fractional(value.Depth)));
 }
Exemplo n.º 6
0
 /// <summary>
 /// Returns a size where each component is rounded to the nearest integral value.
 /// </summary>
 /// <param name="value">A size.</param>
 /// <returns>The result of rounding value.</returns>
 public static Size3f Round(Size3f value)
 {
     return(new Size3f(Functions.Round(value.Width), Functions.Round(value.Height), Functions.Round(value.Depth)));
 }
Exemplo n.º 7
0
 /// <summary>
 /// Returns a size where each component is the smallest integral value that
 /// is greater than or equal to the specified component.
 /// </summary>
 /// <param name="value">A size.</param>
 /// <returns>The ceiling of value.</returns>
 public static Size3f Ceiling(Size3f value)
 {
     return(new Size3f(Functions.Ceiling(value.Width), Functions.Ceiling(value.Height), Functions.Ceiling(value.Depth)));
 }
Exemplo n.º 8
0
 /// <summary>
 /// Returns a size where each component is the integral part of the specified component.
 /// </summary>
 /// <param name="value">A size.</param>
 /// <returns>The integral of value.</returns>
 public static Size3f Truncate(Size3f value)
 {
     return(new Size3f(Functions.Truncate(value.Width), Functions.Truncate(value.Height), Functions.Truncate(value.Depth)));
 }
Exemplo n.º 9
0
 /// <summary>
 /// Returns a size that contains the highest value from each pair of components.
 /// </summary>
 /// <param name="value1">The first size.</param>
 /// <param name="value2">The second size.</param>
 /// <returns>The highest of each component in left and the matching component in right.</returns>
 public static Size3f Max(Size3f value1, Size3f value2)
 {
     return(new Size3f(Functions.Max(value1.Width, value2.Width), Functions.Max(value1.Height, value2.Height), Functions.Max(value1.Depth, value2.Depth)));
 }
Exemplo n.º 10
0
 /// <summary>
 /// Constrains each component to a given range.
 /// </summary>
 /// <param name="value">A size to constrain.</param>
 /// <param name="min">The minimum values for each component.</param>
 /// <param name="max">The maximum values for each component.</param>
 /// <returns>A size with each component constrained to the given range.</returns>
 public static Size3f Clamp(Size3f value, Size3f min, Size3f max)
 {
     return(new Size3f(Functions.Clamp(value.Width, min.Width, max.Width), Functions.Clamp(value.Height, min.Height, max.Height), Functions.Clamp(value.Depth, min.Depth, max.Depth)));
 }
Exemplo n.º 11
0
 /// <summary>
 /// Transforms the components of a size and returns the result.
 /// </summary>
 /// <param name="value">The size to transform.</param>
 /// <param name="transformer">A transform function to apply to each component.</param>
 /// <returns>The result of transforming each component of value.</returns>
 public static Size3i Transform(Size3f value, Func <float, int> transformer)
 {
     return(new Size3i(transformer(value.Width), transformer(value.Height), transformer(value.Depth)));
 }
Exemplo n.º 12
0
 /// <summary>
 /// Returns a value that indicates whether two sizes are equal.
 /// </summary>
 /// <param name="left">The first size to compare.</param>
 /// <param name="right">The second size to compare.</param>
 /// <returns>true if the left and right are equal; otherwise, false.</returns>
 public static bool Equals(Size3f left, Size3f right)
 {
     return(left == right);
 }
Exemplo n.º 13
0
 /// <summary>
 /// Divides a size by a scalar and returns the result.
 /// </summary>
 /// <param name="size">The size to be divided (the dividend).</param>
 /// <param name="scalar">The scalar to divide by (the divisor).</param>
 /// <returns>The result of dividing left by right (the quotient).</returns>
 public static Size3f Divide(Size3f size, float scalar)
 {
     Contract.Requires(0 <= scalar);
     return(new Size3f(size.Width / scalar, size.Height / scalar, size.Depth / scalar));
 }
Exemplo n.º 14
0
 /// <summary>
 /// Returns the product of a size and scalar.
 /// </summary>
 /// <param name="size">The size to multiply.</param>
 /// <param name="scalar">The scalar to multiply.</param>
 /// <returns>The product of the left and right parameters.</returns>
 public static Size3f Multiply(Size3f size, float scalar)
 {
     Contract.Requires(0 <= scalar);
     return(new Size3f(size.Width * scalar, size.Height * scalar, size.Depth * scalar));
 }
Exemplo n.º 15
0
 /// <summary>
 /// Writes the given <see cref="Size3f"/> to an <see cref="Ibasa.IO.BinaryWriter">.
 /// </summary>
 public static void Write(this Ibasa.IO.BinaryWriter writer, Size3f size)
 {
     writer.Write(size.Width);
     writer.Write(size.Height);
     writer.Write(size.Depth);
 }