コード例 #1
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Finds the cross product between two vectors (times rows by cols)
 /// </summary>
 /// <param name="vecA"></param>
 /// <param name="vecB"></param>
 /// <returns></returns>
 public ASVECTOR3 CrossProduct(ASVECTOR3 v)
 {
     return(new ASVECTOR3(points[1] * v.points[2] - points[2] * v.points[1],
                          points[2] * v.points[0] - points[0] * v.points[2],
                          points[0] * v.points[1] - points[1] * v.points[0]
                          ));
 }
コード例 #2
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Gets the horizontal angle between two vectors
        /// </summary>
        /// <returns></returns>
        public double GetHorizontalAngle()
        {
            // Catch the case where we have an invalid horizontal angle (x and y planes are at origin)
            if (points[0] == 0 && points[1] == 0 && points[2] != 0)
            {
                return(0);
            }
            // Calculate the horizontal angle
            var normX = new ASVECTOR3(1, 0, 0);
            var normZ = new ASVECTOR3(0, 0, 1);

            var scalarX = ScalarProduct(normX);
            var scalarZ = ScalarProduct(normZ);

            var vecX = new ASVECTOR3(scalarX, 0, 0);
            var vecZ = new ASVECTOR3(0, 0, scalarZ);

            var vecXZ = new ASVECTOR3();

            vecXZ.AddToVector(vecX);
            vecXZ.AddToVector(vecZ);
            vecXZ.Normalise();

            double angle = Math.Acos(normZ.ScalarProduct(vecXZ));

            if (vecX.points[0] < 0)
            {
                return(Math.PI * 2.0f - angle);
            }
            else
            {
                return(angle);
            }
        }
コード例 #3
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Gets the Z angle between two vectors
        /// </summary>
        /// <param name="vecA"></param>
        /// <returns></returns>
        public double GetAngleZ()
        {
            var    vz    = new ASVECTOR3(0, 0, 1);
            double angle = ScalarProduct(vz) / GetMagnitude();

            return(Math.Acos(angle));
        }
コード例 #4
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Gets the Y angle between two vectors
        /// </summary>
        /// <param name="vecA"></param>
        /// <returns></returns>
        public double GetAngleY()
        {
            var    vy    = new ASVECTOR3(0, 1, 0);
            double angle = ScalarProduct(vy) / GetMagnitude();

            return(Math.Acos(angle));
        }
コード例 #5
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Gets the X angle between two vectors
        /// </summary>
        /// <param name="vecA"></param>
        /// <returns></returns>
        public double GetAngleX()
        {
            var    vx    = new ASVECTOR3(1, 0, 0);
            double angle = ScalarProduct(vx) / GetMagnitude();

            return(Math.Acos(angle));
        }
コード例 #6
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Rescales a vector after it has been transformed
        /// </summary>
        /// <returns></returns>
        public ASVECTOR3 ScaleVector()
        {
            ASVECTOR3 output = new ASVECTOR3();

            for (int i = 0; i < 3; i++)
            {
                output.points[i] = points[i] / 1;
            }

            return(output);
        }
コード例 #7
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Rotates the mesh around some plane
        /// </summary>
        /// <param name="axis"></param>
        /// <param name="deg"></param>
        public void RotateAroundOrigin(ASVECTOR3 axis, double deg)
        {
            double xPlane = axis.GetHorizontalAngle();
            double yPlane = axis.GetAngleY();

            // Rotate the viewer about the X,Y plane to give the illusion of smooth rotation
            this.RotateY(-xPlane);
            this.RotateX(-yPlane);
            this.RotateY(deg);
            this.RotateX(yPlane);
            this.RotateY(xPlane);
        }
コード例 #8
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
        /// <summary>
        /// Transform the vector by a matrix
        /// </summary>
        /// <param name="m"></param>
        public ASVECTOR3 TransformVector(ASMATRIX4 m)
        {
            var newPoint = new ASVECTOR3();

            // Multiply rows by cols to get the new vector
            for (var col = 0; col < 3; col++)
            {
                double total = 0;
                for (var row = 0; row < 3; row++)
                {
                    total = total + points[row] * m.Matrix[col].Points[row];
                }
            }

            return(newPoint);
        }
コード例 #9
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Initialise a new vector with a vector
 /// </summary>
 /// <param name="vec"></param>
 public ASVECTOR3(ASVECTOR3 vec)
 {
     points[0] = vec.points[0];
     points[1] = vec.points[1];
     points[2] = vec.points[2];
 }
コード例 #10
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Returns the product of vector A and B
 /// </summary>
 /// <param name="vecA"></param>
 /// <param name="vecB"></param>
 /// <returns></returns>
 public double ScalarProduct(ASVECTOR3 v)
 {
     return(points[0] * v.points[0] + points[1] * v.points[1] + points[2] * v.points[2]);
 }
コード例 #11
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Multiplies the x,y,z components of vectors together
 /// </summary>
 /// <param name="vecA"></param>
 /// <param name="vecB"></param>
 public void MultiplyVector(ASVECTOR3 vecB)
 {
     points[0] *= vecB.points[0];
     points[1] *= vecB.points[1];
     points[2] *= vecB.points[2];
 }
コード例 #12
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Divides the x,y,z components of two vectors by eachother
 /// </summary>
 /// <param name="vecA"></param>
 /// <param name="vecB"></param>
 public void DivideVector(ASVECTOR3 vecB)
 {
     points[0] /= vecB.points[0];
     points[1] /= vecB.points[1];
     points[2] /= vecB.points[2];
 }
コード例 #13
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Substracts the x,y,z components of two vectors from one another
 /// </summary>
 /// <param name="vecA"></param>
 /// <param name="vecB"></param>
 public void MinusFromVector(ASVECTOR3 vecB)
 {
     points[0] -= vecB.points[0];
     points[1] -= vecB.points[1];
     points[2] -= vecB.points[2];
 }
コード例 #14
0
ファイル: ASVector3.cs プロジェクト: alexmk92/ASModelLoader
 /// <summary>
 /// Adds the x,y,z components of two vectors together
 /// </summary>
 /// <param name="vecA"></param>
 /// <param name="vecB"></param>
 public void AddToVector(ASVECTOR3 vecB)
 {
     points[0] += vecB.points[0];
     points[1] += vecB.points[1];
     points[2] += vecB.points[2];
 }