/* * Author: Needles * https://steamcommunity.com/profiles/76561198026257137/ */ ::Debug.Print("*** MATH_N"); ::MathN <- {}; ::MathN.RAD2DEG <- 180.0/PI; ::MathN.DEG2RAD <- PI/180.0; const SINT8_UPPER = 127; const SINT8_LOWER = -128; const UINT8_UPPER = 255; const SINT16_UPPER = 32767; const SINT16_LOWER = -32768 const UINT16_UPPER = 65535; const SINT32_UPPER = 2147483647; const SINT32_LOWER = -2147483648; const UINT32_UPPER = 4294967295; function MathN::Max(a, b) { if (a > b) return a; return b; } function MathN::Min(a, b) { if (a < b) return a; return b; } function MathN::Clamp(x, min, max) { if (max < min) return max; if (x < min) return min; if (x > max) return max; return x; } function MathN::NormalizeAngle(angle) { angle %= 360.0; if (angle > 180.0) angle -= 360.0; else if (angle < -180.0) angle += 360.0; return angle; } function MathN::ApproachAngle(start, end, t) { end = ::MathN.NormalizeAngle(end); start = ::MathN.NormalizeAngle(start); local delta = ::MathN.NormalizeAngle(end - start); if (delta > t) return start + t; else if (delta < -t) return start - t; return end; } function MathN::NormalToAngles(normal) { return QAngle(-asin(normal.z) * ::MathN.RAD2DEG, atan2(normal.y, normal.x) * ::MathN.RAD2DEG, 0.0); } function MathN::TrajectoryAngleOfReach(origin, target, speed, gravity) { local distance = sqrt(pow(target.x - origin.x, 2) + pow(target.y - origin.y, 2)); return asin((distance * gravity) / (speed * speed)) / 2.0; } function MathN::BuildMatrix(translation, rotation, scale) { local sinyaw = sin(::MathN.DEG2RAD * rotation.Yaw()); local cosyaw = cos(::MathN.DEG2RAD * rotation.Yaw()); local sinpitch = sin(::MathN.DEG2RAD * rotation.Pitch()); local cospitch = cos(::MathN.DEG2RAD * rotation.Pitch()); local sinroll = sin(::MathN.DEG2RAD * rotation.Roll()); local cosroll = cos(::MathN.DEG2RAD * rotation.Roll()); local m = array(16); m[0] = ((cosyaw * cospitch)) * scale.x; m[4] = ((cosyaw * sinpitch * sinroll) - (sinyaw * cosroll)) * scale.y; m[8] = ((cosyaw * sinpitch * cosroll) + (sinyaw * sinroll)) * scale.z; m[12] = translation.x; m[1] = ((sinyaw * cospitch)) * scale.x; m[5] = ((sinyaw * sinpitch * cosroll) + (cosyaw * cosroll)) * scale.y; m[9] = ((sinyaw * sinpitch * cosroll) - (cosyaw * sinroll)) * scale.z; m[13] = translation.y; m[2] = ((-sinpitch)) * scale.x; m[6] = ((cospitch * sinroll)) * scale.y; m[10] = ((cospitch * cosroll)) * scale.z; m[14] = translation.z; m[3] = 0; m[7] = 0; m[11] = 0; m[15] = 1; return m; } function MathN::BuildIdentityMatrix() { local m = array(16); m[0] = 1; m[4] = 0; m[8] = 0; m[12] = 0; m[1] = 0; m[5] = 1; m[9] = 0; m[13] = 0; m[2] = 0; m[6] = 0; m[10] = 1; m[14] = 0; m[3] = 0; m[7] = 0; m[11] = 0; m[15] = 1; return m; } function MathN::MatrixTransformVector(matrix, vector) { local dest = Vector( vector.x * matrix[0] + vector.y * matrix[4] + vector.z * matrix[8] + matrix[12], // X vector.x * matrix[1] + vector.y * matrix[5] + vector.z * matrix[9] + matrix[13], // Y vector.x * matrix[2] + vector.y * matrix[6] + vector.z * matrix[10] + matrix[14] // Z ); return dest; }