From 6525ae2b5c8258dad95bd8d165b654a100393d3f Mon Sep 17 00:00:00 2001 From: Mike Date: Sun, 24 Mar 2024 12:39:30 -0700 Subject: [PATCH 1/3] vecX: add setLength function --- src/vec2-impl.ts | 13 +++++++++++++ src/vec3-impl.ts | 13 +++++++++++++ src/vec4-impl.ts | 14 ++++++++++++++ test/tests/vec2-test.js | 14 ++++++++++++++ test/tests/vec3-test.js | 15 +++++++++++++++ test/tests/vec4-test.js | 15 +++++++++++++++ 6 files changed, 84 insertions(+) diff --git a/src/vec2-impl.ts b/src/vec2-impl.ts index db45f51..859375d 100644 --- a/src/vec2-impl.ts +++ b/src/vec2-impl.ts @@ -667,3 +667,16 @@ export function rotate(a: Vec2, b: Vec2, rad: number, dst?: Vec2) { return dst; } + +/** + * Treat a 2D vector as a direction and set it's length + * + * @param a The vec2 to length + * @param len The length of the resulting vector + * @returns The lengthened vector + */ +export function setLength(a: Vec2, len: number, dst?: Vec2) { + dst = dst || new VecType(2); + normalize(a, dst); + return mulScalar(dst, len, dst); +} diff --git a/src/vec3-impl.ts b/src/vec3-impl.ts index a8eb263..620057f 100644 --- a/src/vec3-impl.ts +++ b/src/vec3-impl.ts @@ -883,3 +883,16 @@ export function rotateZ(a: Vec3, b: Vec3, rad: number, dst?: Vec3) { return dst; } + +/** + * Treat a 3D vector as a direction and set it's length + * + * @param a The vec3 to length + * @param len The length of the resulting vector + * @returns The lengthened vector + */ +export function setLength(a: Vec3, len: number, dst?: Vec3) { + dst = dst || new VecType(3); + normalize(a, dst); + return mulScalar(dst, len, dst); +} diff --git a/src/vec4-impl.ts b/src/vec4-impl.ts index 043dfa5..3c9dae9 100644 --- a/src/vec4-impl.ts +++ b/src/vec4-impl.ts @@ -632,3 +632,17 @@ export function transformMat4(v: Vec4, m: Mat4, dst?: Vec4): Vec4 { return dst; } + + +/** + * Treat a 4D vector as a direction and set it's length + * + * @param a The vec3 to length + * @param len The length of the resulting vector + * @returns The lengthened vector + */ +export function setLength(a: Vec4, len: number, dst?: Vec4) { + dst = dst || new VecType(4); + normalize(a, dst); + return mulScalar(dst, len, dst); +} diff --git a/test/tests/vec2-test.js b/test/tests/vec2-test.js index 1ca4775..b59d246 100644 --- a/test/tests/vec2-test.js +++ b/test/tests/vec2-test.js @@ -496,5 +496,19 @@ describe('vec2', () => { }); }); + describe('setLength', function() { + describe('set the length of a provided direction vector', function() { + let vecA, result; + beforeEach(function () { + vecA = [1, 1]; + result = vec2.setLength(vecA, 14.6); + }); + it("should return the rotated vector", function () { + assertEqualApproximately(result, [10.323759005323593, 10.323759005323593]); + assertEqualApproximately(vec2.length(result), 14.6); + }); + }); + }); + }); diff --git a/test/tests/vec3-test.js b/test/tests/vec3-test.js index eab266c..1b24cda 100644 --- a/test/tests/vec3-test.js +++ b/test/tests/vec3-test.js @@ -551,5 +551,20 @@ describe('vec3', () => { }); }); }); + + describe('setLength', function() { + describe('set the length of a provided direction vector', function() { + let vecA, result; + beforeEach(function () { + vecA = [1, 1, 1]; + result = vec3.setLength(vecA, 14.6); + }); + it("should return the rotated vector", function () { + assertEqualApproximately(result, [8.429313930168536, 8.429313930168536, 8.429313930168536]); + assertEqualApproximately(vec3.length(result), 14.6); + }); + }); + }); + }); diff --git a/test/tests/vec4-test.js b/test/tests/vec4-test.js index 7a023c0..e2946c5 100644 --- a/test/tests/vec4-test.js +++ b/test/tests/vec4-test.js @@ -7,6 +7,7 @@ import { assertStrictEqual, assertStrictNotEqual, assertIsArray, + assertEqualApproximately, assertTruthy, assertFalsy, } from '../assert.js'; @@ -404,5 +405,19 @@ describe('vec4', () => { check(Float32Array); check(Float64Array); + describe('setLength', function() { + describe('set the length of a provided direction vector', function() { + let vecA, result; + beforeEach(function () { + vecA = [1, 1, 1, 1]; + result = vec4.setLength(vecA, 14.6); + }); + it("should return the rotated vector", function () { + assertEqualApproximately(result, [7.3, 7.3, 7.3, 7.3]); + assertEqualApproximately(vec4.length(result), 14.6); + }); + }); + }); + }); From 543327f2ed9f6a0ba2fb5b6205d3357c83a7870c Mon Sep 17 00:00:00 2001 From: Mike Date: Mon, 25 Mar 2024 09:25:45 -0700 Subject: [PATCH 2/3] fix the test assertion labels for vecX.setLength functions --- src/vec2-impl.ts | 2 +- src/vec3-impl.ts | 2 +- src/vec4-impl.ts | 2 +- test/tests/vec2-test.js | 2 +- test/tests/vec3-test.js | 2 +- test/tests/vec4-test.js | 2 +- 6 files changed, 6 insertions(+), 6 deletions(-) diff --git a/src/vec2-impl.ts b/src/vec2-impl.ts index 859375d..a195b4a 100644 --- a/src/vec2-impl.ts +++ b/src/vec2-impl.ts @@ -671,7 +671,7 @@ export function rotate(a: Vec2, b: Vec2, rad: number, dst?: Vec2) { /** * Treat a 2D vector as a direction and set it's length * - * @param a The vec2 to length + * @param a The vec2 to lengthen * @param len The length of the resulting vector * @returns The lengthened vector */ diff --git a/src/vec3-impl.ts b/src/vec3-impl.ts index 620057f..b584dbe 100644 --- a/src/vec3-impl.ts +++ b/src/vec3-impl.ts @@ -887,7 +887,7 @@ export function rotateZ(a: Vec3, b: Vec3, rad: number, dst?: Vec3) { /** * Treat a 3D vector as a direction and set it's length * - * @param a The vec3 to length + * @param a The vec3 to lengthen * @param len The length of the resulting vector * @returns The lengthened vector */ diff --git a/src/vec4-impl.ts b/src/vec4-impl.ts index 3c9dae9..aefa236 100644 --- a/src/vec4-impl.ts +++ b/src/vec4-impl.ts @@ -637,7 +637,7 @@ export function transformMat4(v: Vec4, m: Mat4, dst?: Vec4): Vec4 { /** * Treat a 4D vector as a direction and set it's length * - * @param a The vec3 to length + * @param a The vec3 to lengthen * @param len The length of the resulting vector * @returns The lengthened vector */ diff --git a/test/tests/vec2-test.js b/test/tests/vec2-test.js index b59d246..6ca981a 100644 --- a/test/tests/vec2-test.js +++ b/test/tests/vec2-test.js @@ -503,7 +503,7 @@ describe('vec2', () => { vecA = [1, 1]; result = vec2.setLength(vecA, 14.6); }); - it("should return the rotated vector", function () { + it("should return the lengthend vector", function () { assertEqualApproximately(result, [10.323759005323593, 10.323759005323593]); assertEqualApproximately(vec2.length(result), 14.6); }); diff --git a/test/tests/vec3-test.js b/test/tests/vec3-test.js index 1b24cda..6b51dd6 100644 --- a/test/tests/vec3-test.js +++ b/test/tests/vec3-test.js @@ -559,7 +559,7 @@ describe('vec3', () => { vecA = [1, 1, 1]; result = vec3.setLength(vecA, 14.6); }); - it("should return the rotated vector", function () { + it("should return the lengthened vector", function () { assertEqualApproximately(result, [8.429313930168536, 8.429313930168536, 8.429313930168536]); assertEqualApproximately(vec3.length(result), 14.6); }); diff --git a/test/tests/vec4-test.js b/test/tests/vec4-test.js index e2946c5..1a33f8d 100644 --- a/test/tests/vec4-test.js +++ b/test/tests/vec4-test.js @@ -412,7 +412,7 @@ describe('vec4', () => { vecA = [1, 1, 1, 1]; result = vec4.setLength(vecA, 14.6); }); - it("should return the rotated vector", function () { + it("should return the lengthened vector", function () { assertEqualApproximately(result, [7.3, 7.3, 7.3, 7.3]); assertEqualApproximately(vec4.length(result), 14.6); }); From 61d91a3b6828095bc5da5a72dae9ed6544cc9c67 Mon Sep 17 00:00:00 2001 From: Mike Date: Mon, 25 Mar 2024 09:28:20 -0700 Subject: [PATCH 3/3] fix copypasta in vec4.lengthen --- src/vec4-impl.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/vec4-impl.ts b/src/vec4-impl.ts index aefa236..f738e55 100644 --- a/src/vec4-impl.ts +++ b/src/vec4-impl.ts @@ -637,7 +637,7 @@ export function transformMat4(v: Vec4, m: Mat4, dst?: Vec4): Vec4 { /** * Treat a 4D vector as a direction and set it's length * - * @param a The vec3 to lengthen + * @param a The vec4 to lengthen * @param len The length of the resulting vector * @returns The lengthened vector */