Skip to content

Commit

Permalink
fix: align the imageSmoothingQuality behavior with chrome
Browse files Browse the repository at this point in the history
  • Loading branch information
Brooooooklyn committed Nov 15, 2024
1 parent 8686c8b commit 8510d62
Show file tree
Hide file tree
Showing 5 changed files with 29 additions and 21 deletions.
45 changes: 26 additions & 19 deletions __test__/index.spec.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,8 @@
import { join } from 'node:path'

import ava, { TestFn } from 'ava'

import { createCanvas, Path2D, Canvas, SKRSContext2D, DOMMatrix } from '../index'
import { createCanvas, Path2D, Canvas, SKRSContext2D, DOMMatrix, loadImage } from '../index'

import { snapshotImage } from './image-snapshot'

Expand Down Expand Up @@ -54,12 +56,17 @@ test('imageSmoothingEnabled state should be ok', (t) => {
t.is(ctx.imageSmoothingEnabled, false)
})

test('imageSmoothingQuality state should be ok', (t) => {
const { ctx } = t.context
t.is(ctx.imageSmoothingQuality, 'low')
ctx.imageSmoothingQuality = 'high'
t.is(ctx.imageSmoothingQuality, 'high')
})
for (const quality of ['low', 'medium', 'high'] as const) {
test(`draw-image-quality-${quality}`, async (t) => {
const { ctx } = t.context
ctx.imageSmoothingEnabled = true
ctx.imageSmoothingQuality = quality
t.is(ctx.imageSmoothingQuality, quality)
const image = await loadImage(join(__dirname, 'fixtures', 'filter-drop-shadow.jpeg'))
ctx.drawImage(image, 0, 0, 426, 322)
await snapshotImage(t)
})
}

test('lineCap state should be ok', (t) => {
const { ctx } = t.context
Expand Down Expand Up @@ -183,12 +190,12 @@ test('composition-destination-in', async (t) => {
ctx.fillStyle = 'red'
ctx.fillRect(0, 0, 300, 300)
ctx.save()
ctx.globalCompositeOperation = 'destination-in';
ctx.fillStyle = 'green';
ctx.beginPath();
ctx.arc(150, 150, 100, 0, Math.PI * 2);
ctx.closePath();
ctx.fill();
ctx.globalCompositeOperation = 'destination-in'
ctx.fillStyle = 'green'
ctx.beginPath()
ctx.arc(150, 150, 100, 0, Math.PI * 2)
ctx.closePath()
ctx.fill()
ctx.restore()

await snapshotImage(t, t.context, 'png')
Expand All @@ -201,12 +208,12 @@ test('composition-source-in', async (t) => {
ctx.fillStyle = 'red'
ctx.fillRect(0, 0, 300, 300)
ctx.save()
ctx.globalCompositeOperation = 'source-in';
ctx.fillStyle = 'green';
ctx.beginPath();
ctx.arc(150, 150, 100, 0, Math.PI * 2);
ctx.closePath();
ctx.fill();
ctx.globalCompositeOperation = 'source-in'
ctx.fillStyle = 'green'
ctx.beginPath()
ctx.arc(150, 150, 100, 0, Math.PI * 2)
ctx.closePath()
ctx.fill()
ctx.restore()

await snapshotImage(t, t.context, 'png')
Expand Down
Binary file added __test__/snapshots/draw-image-quality-high.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added __test__/snapshots/draw-image-quality-low.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added __test__/snapshots/draw-image-quality-medium.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
5 changes: 3 additions & 2 deletions skia-c/skia_c.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -44,15 +44,16 @@ extern "C"
}
}

// https://source.chromium.org/chromium/chromium/src/+/refs/tags/131.0.6778.9:cc/paint/paint_flags.cc;l=171
static SkSamplingOptions SamplingOptionsFromFQ(int fq)
{
switch (fq)
{
case 3:
return SkSamplingOptions(SkCubicResampler{1 / 3.0f, 1 / 3.0f});
return SkSamplingOptions(SkCubicResampler::Mitchell());
case 2:
return SkSamplingOptions(SkFilterMode::kLinear,
SkMipmapMode::kNearest);
SkMipmapMode::kNearest);
case 1:
return SkSamplingOptions(SkFilterMode::kLinear, SkMipmapMode::kNone);
case 0:
Expand Down

0 comments on commit 8510d62

Please sign in to comment.