UNPKG

@xtor/cga.js

Version:

Xtor Compute Geometry Algorithm Libary 计算几何算法库

96 lines (95 loc) 3.06 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.toFixed = exports.radToDeg = exports.degToRad = exports.floorPowerOfTwo = exports.ceilPowerOfTwo = exports.isPowerOfTwo = exports.randFloat = exports.randInt = exports.smootherstep = exports.smoothstep = exports.lerp = exports.clamp = exports.approximateEqual = exports.sign = exports.gPrecision = void 0; exports.gPrecision = 1e-4; var DEG2RAD = Math.PI / 180; var RAD2DEG = 180 / Math.PI; function sign(value) { return value >= 0 ? 1 : -1; } exports.sign = sign; function approximateEqual(v1, v2, precision) { if (precision === void 0) { precision = exports.gPrecision; } return Math.abs(v1 - v2) < precision; } exports.approximateEqual = approximateEqual; function clamp(value, min, max) { return Math.max(min, Math.min(max, value)); } exports.clamp = clamp; function lerp(x, y, t) { return (1 - t) * x + t * y; } exports.lerp = lerp; function smoothstep(x, min, max) { if (x <= min) return 0; if (x >= max) return 1; x = (x - min) / (max - min); return x * x * (3 - 2 * x); } exports.smoothstep = smoothstep; function smootherstep(x, min, max) { if (x <= min) return 0; if (x >= max) return 1; x = (x - min) / (max - min); return x * x * x * (x * (x * 6 - 15) + 10); } exports.smootherstep = smootherstep; // Random integer from <low, high> interval function randInt(low, high) { return low + Math.floor(Math.random() * (high - low + 1)); } exports.randInt = randInt; // Random float from <low, high> interval /** * 生成一个low~high之间的浮点数 * @param {*} low * @param {*} high */ function randFloat(low, high) { return low + Math.random() * (high - low); } exports.randFloat = randFloat; function isPowerOfTwo(value) { return (value & (value - 1)) === 0 && value !== 0; } exports.isPowerOfTwo = isPowerOfTwo; function ceilPowerOfTwo(value) { return Math.pow(2, Math.ceil(Math.log(value) / Math.LN2)); } exports.ceilPowerOfTwo = ceilPowerOfTwo; function floorPowerOfTwo(value) { return Math.pow(2, Math.floor(Math.log(value) / Math.LN2)); } exports.floorPowerOfTwo = floorPowerOfTwo; function degToRad(degrees) { return degrees * DEG2RAD; } exports.degToRad = degToRad; function radToDeg(radians) { return radians * RAD2DEG; } exports.radToDeg = radToDeg; /** * 数字或者向量固定位数 * @param {Object} obj 数字或者向量 * @param {*} fractionDigits */ function toFixed(obj, fractionDigits) { if (obj instanceof Number) return parseFloat(obj.toFixed(fractionDigits)); else { if (obj.x !== undefined) obj.x = parseFloat(obj.x.toFixed(fractionDigits)); if (obj.y !== undefined) obj.y = parseFloat(obj.y.toFixed(fractionDigits)); if (obj.z !== undefined) obj.z = parseFloat(obj.z.toFixed(fractionDigits)); } return obj; } exports.toFixed = toFixed;