From a425b4c9b438973b2b5250318214b1b586cefb63 Mon Sep 17 00:00:00 2001 From: Andrew Lisowski Date: Sun, 1 Sep 2024 22:22:55 -0700 Subject: [PATCH] Make brightness function behave like other implementations (#1312) * Make brightness function behave like other implementations * fix test --- .../src/__snapshots__/callbacks.test.ts.snap | 12 ++-- packages/jimp/src/callbacks.test.ts | 2 +- ...box-blur-matrix-using-convolute-1-snap.png | Bin 0 -> 6551 bytes .../src/__snapshots__/index.test.ts.snap | 56 ++++++++++++++++++ .../plugin-color/src/birghtness.node.test.ts | 18 ++++++ plugins/plugin-color/src/index.test.ts | 24 ++++++++ plugins/plugin-color/src/index.ts | 20 ++----- turbo.json | 4 +- 8 files changed, 111 insertions(+), 25 deletions(-) create mode 100644 plugins/plugin-color/src/__image_snapshots__/birghtness-node-test-ts-src-birghtness-node-test-ts-brightness-3-x-3-box-blur-matrix-using-convolute-1-snap.png create mode 100644 plugins/plugin-color/src/birghtness.node.test.ts diff --git a/packages/jimp/src/__snapshots__/callbacks.test.ts.snap b/packages/jimp/src/__snapshots__/callbacks.test.ts.snap index 5d5df786..4d49dc97 100644 --- a/packages/jimp/src/__snapshots__/callbacks.test.ts.snap +++ b/packages/jimp/src/__snapshots__/callbacks.test.ts.snap @@ -31,15 +31,15 @@ AA-94-3Fᶠ¹ 7E-7E-7Eᶠ¹ 54-69-BFᶠ¹ exports[`Callbacks > with brightness 1`] = ` Visualization: -▫▾4 -2 A -D▦◆ +▴▸▾ +◆▪▰ +▵▹▿ Data: -FF-7F-7Fᶠᶠ 7F-FF-7Fᶠᶠ 7F-7F-FFᶠᶠ -FF-FF-7Fᶠᶠ 7F-FF-FFᶠᶠ FF-7F-FFᶠᶠ -FF-7F-7F⁷ᶠ 7F-FF-7F⁷ᶠ 7F-7F-FF⁷ᶠ +FF-00-00ᶠᶠ 00-FF-00ᶠᶠ 00-00-FFᶠᶠ +FF-FF-00ᶠᶠ 00-FF-FFᶠᶠ FF-00-FFᶠᶠ +FF-00-00⁷ᶠ 00-FF-00⁷ᶠ 00-00-FF⁷ᶠ `; exports[`Callbacks > with composite 1`] = ` diff --git a/packages/jimp/src/callbacks.test.ts b/packages/jimp/src/callbacks.test.ts index 0f4f5c8b..3fb18887 100644 --- a/packages/jimp/src/callbacks.test.ts +++ b/packages/jimp/src/callbacks.test.ts @@ -27,7 +27,7 @@ describe("Callbacks", () => { opacity: { args: [0.5] }, resize: { args: [{ w: 2, h: 2 } as ResizeOptions] }, scale: { args: [0.5] }, - brightness: { args: [0.5] }, + brightness: { args: [1.5] }, contrast: { args: [0.75] }, posterize: { args: [5] }, dither: { args: [] }, diff --git a/plugins/plugin-color/src/__image_snapshots__/birghtness-node-test-ts-src-birghtness-node-test-ts-brightness-3-x-3-box-blur-matrix-using-convolute-1-snap.png b/plugins/plugin-color/src/__image_snapshots__/birghtness-node-test-ts-src-birghtness-node-test-ts-brightness-3-x-3-box-blur-matrix-using-convolute-1-snap.png new file mode 100644 index 0000000000000000000000000000000000000000..01defca2e3c306a58ec5877c6e78b2c0e17b0a9e GIT binary patch literal 6551 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 T< should be able to brighten 1`] = ` +Visualization: + +6666666666 +6666666666 +6666666666 +6666666666 +6666666666 +6666666666 +6666666666 +6666666666 +6666666666 +6666666666 + +Data: + +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ FF-00-00⁸⁸ +`; + +exports[`brightness > should be able to darken 1`] = ` +Visualization: + +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC +CCCCCCCCCC + +Data: + +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ 22-00-00⁸⁸ +`; + exports[`canvas color transformation > brighten 1`] = ` Visualization: diff --git a/plugins/plugin-color/src/birghtness.node.test.ts b/plugins/plugin-color/src/birghtness.node.test.ts new file mode 100644 index 00000000..08c0d7a3 --- /dev/null +++ b/plugins/plugin-color/src/birghtness.node.test.ts @@ -0,0 +1,18 @@ +import { expect, test, describe } from "vitest"; +import png from "@jimp/js-png"; +import jpeg from "@jimp/js-jpeg"; +import { createJimp } from "@jimp/core"; +import "@jimp/test-utils/image-snapshot"; + +import { methods } from "./index.js"; + +const jimp = createJimp({ formats: [png, jpeg], plugins: [methods] }); + +describe("Brightness", function () { + test("3x3 box blur matrix using convolute", async () => { + const image = await jimp.read(__dirname + "/images/tiles.jpg"); + const output = await image.brightness(2).getBuffer("image/png"); + + expect(output).toMatchImageSnapshot(); + }); +}); diff --git a/plugins/plugin-color/src/index.test.ts b/plugins/plugin-color/src/index.test.ts index 70ea200c..2552beae 100644 --- a/plugins/plugin-color/src/index.test.ts +++ b/plugins/plugin-color/src/index.test.ts @@ -37,3 +37,27 @@ describe("canvas color transformation", () => { expect(image.color([{ apply: "hue", params: [150] }])).toMatchSnapshot(); }); }); + +describe("brightness", () => { + test("brightness of 1 should be the same as no change", () => { + const jgd = makeDonutTestImage(0xff000088, 0xff000088, 0xff000088); + const image = jimp.fromBitmap(jgd); + const image2 = jimp.fromBitmap(jgd); + + expect(image.brightness(1).bitmap).toStrictEqual(image2.bitmap); + }); + + test("should be able to brighten", () => { + const jgd = makeDonutTestImage(0xaa000088, 0xaa000088, 0xaa000088); + const image = jimp.fromBitmap(jgd); + + expect(image.brightness(2).bitmap).toMatchSnapshot(); + }); + + test("should be able to darken", () => { + const jgd = makeDonutTestImage(0xaa000088, 0xaa000088, 0xaa000088); + const image = jimp.fromBitmap(jgd); + + expect(image.brightness(0.2).bitmap).toMatchSnapshot(); + }); +}); diff --git a/plugins/plugin-color/src/index.ts b/plugins/plugin-color/src/index.ts index 6ba8ef45..eba72ace 100644 --- a/plugins/plugin-color/src/index.ts +++ b/plugins/plugin-color/src/index.ts @@ -336,7 +336,7 @@ export const methods = { /** * Adjusts the brightness of the image - * @param val the amount to adjust the brightness, a number between -1 and +1 + * @param val the amount to adjust the brightness. * @example * ```ts * import { Jimp } from "jimp"; @@ -351,22 +351,10 @@ export const methods = { throw new Error("val must be numbers"); } - if (val < -1 || val > +1) { - throw new Error("val must be a number between -1 and +1"); - } - image.scan((_, __, idx) => { - if (val < 0.0) { - image.bitmap.data[idx]! *= 1 + val; - image.bitmap.data[idx + 1]! *= 1 + val; - image.bitmap.data[idx + 2]! *= 1 + val; - } else { - image.bitmap.data[idx]! += (255 - image.bitmap.data[idx]!) * val; - image.bitmap.data[idx + 1]! += - (255 - image.bitmap.data[idx + 1]!) * val; - image.bitmap.data[idx + 2]! += - (255 - image.bitmap.data[idx + 2]!) * val; - } + image.bitmap.data[idx]! = limit255(image.bitmap.data[idx]! * val); + image.bitmap.data[idx + 1]! = limit255(image.bitmap.data[idx + 1]! * val); + image.bitmap.data[idx + 2]! = limit255(image.bitmap.data[idx + 2]! * val); }); return image; diff --git a/turbo.json b/turbo.json index 40137713..7f78cdfe 100644 --- a/turbo.json +++ b/turbo.json @@ -13,10 +13,10 @@ "dependsOn": ["^lint"] }, "test": { - "dependsOn": ["^test"] + "dependsOn": ["^build", "^test"] }, "test:browser": { - "dependsOn": ["^test:browser"] + "dependsOn": ["^build", "^test:browser"] }, "dev": { "cache": false,