-
Notifications
You must be signed in to change notification settings - Fork 86
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
CopyEI2T: Cases To Cover Rotated Images (#4111)
Co-authored-by: Kai Ninomiya <[email protected]>
- Loading branch information
1 parent
e99550b
commit 10b66cd
Showing
7 changed files
with
230 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
125 changes: 125 additions & 0 deletions
125
src/webgpu/web_platform/copyToTexture/image_file.spec.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,125 @@ | ||
export const description = ` | ||
copyExternalImageToTexture from ImageFiles like *.png, *.jpg source. | ||
`; | ||
|
||
import { makeTestGroup } from '../../../common/framework/test_group.js'; | ||
import { TextureUploadingUtils } from '../../util/copy_to_texture.js'; | ||
import { | ||
convertToUnorm8, | ||
GetSourceFromImageFile, | ||
kImageNames, | ||
kImageInfo, | ||
kImageExpectedColors, | ||
kObjectTypeFromFiles, | ||
} from '../util.js'; | ||
|
||
export const g = makeTestGroup(TextureUploadingUtils); | ||
|
||
g.test('from_orientation_metadata_file') | ||
.desc( | ||
` | ||
Test HTMLImageElements with rotation metadata can be copied to WebGPU texture correctly. | ||
It creates an ImageBitmap or HTMLImageElement using images in the 'resources' folder. | ||
Then call copyExternalImageToTexture() to do a full copy to the 0 mipLevel | ||
of dst texture, and read one pixel out to compare with the manually documented expected color. | ||
If 'flipY' in 'GPUCopyExternalImageSourceInfo' is set to 'true', copy will ensure the result | ||
is flipped. | ||
The tests covers: | ||
- Image with rotation metadata | ||
- Valid 'flipY' config in 'GPUCopyExternalImageSourceInfo' (named 'srcDoFlipYDuringCopy' in cases) | ||
- TODO: partial copy tests should be added | ||
- TODO: all valid dstColorFormat tests should be added. | ||
- TODO(#4108): Make this work in service workers (see GetSourceFromImageFile) | ||
` | ||
) | ||
.params(u => | ||
u // | ||
.combine('imageName', kImageNames) | ||
.combine('objectTypeFromFile', kObjectTypeFromFiles) | ||
.combine('srcDoFlipYDuringCopy', [true, false]) | ||
) | ||
.fn(async t => { | ||
const { imageName, objectTypeFromFile, srcDoFlipYDuringCopy } = t.params; | ||
const kColorFormat = 'rgba8unorm'; | ||
|
||
// Load image file. | ||
const source = await GetSourceFromImageFile(t, imageName, objectTypeFromFile); | ||
const width = source.width; | ||
const height = source.height; | ||
|
||
const dstTexture = t.createTextureTracked({ | ||
size: { width, height }, | ||
format: kColorFormat, | ||
usage: | ||
GPUTextureUsage.COPY_DST | GPUTextureUsage.COPY_SRC | GPUTextureUsage.RENDER_ATTACHMENT, | ||
}); | ||
|
||
t.device.queue.copyExternalImageToTexture( | ||
{ | ||
source, | ||
flipY: srcDoFlipYDuringCopy, | ||
}, | ||
{ | ||
texture: dstTexture, | ||
}, | ||
{ | ||
width, | ||
height, | ||
} | ||
); | ||
|
||
const expect = kImageInfo[imageName].display; | ||
const presentColors = kImageExpectedColors.srgb; | ||
|
||
if (srcDoFlipYDuringCopy) { | ||
t.expectSinglePixelComparisonsAreOkInTexture({ texture: dstTexture }, [ | ||
// Flipped top-left. | ||
{ | ||
coord: { x: width * 0.25, y: height * 0.25 }, | ||
exp: convertToUnorm8(presentColors[expect.bottomLeftColor]), | ||
}, | ||
// Flipped top-right. | ||
{ | ||
coord: { x: width * 0.75, y: height * 0.25 }, | ||
exp: convertToUnorm8(presentColors[expect.bottomRightColor]), | ||
}, | ||
// Flipped bottom-left. | ||
{ | ||
coord: { x: width * 0.25, y: height * 0.75 }, | ||
exp: convertToUnorm8(presentColors[expect.topLeftColor]), | ||
}, | ||
// Flipped bottom-right. | ||
{ | ||
coord: { x: width * 0.75, y: height * 0.75 }, | ||
exp: convertToUnorm8(presentColors[expect.topRightColor]), | ||
}, | ||
]); | ||
} else { | ||
t.expectSinglePixelComparisonsAreOkInTexture({ texture: dstTexture }, [ | ||
// Top-left. | ||
{ | ||
coord: { x: width * 0.25, y: height * 0.25 }, | ||
exp: convertToUnorm8(presentColors[expect.topLeftColor]), | ||
}, | ||
// Top-right. | ||
{ | ||
coord: { x: width * 0.75, y: height * 0.25 }, | ||
exp: convertToUnorm8(presentColors[expect.topRightColor]), | ||
}, | ||
// Bottom-left. | ||
{ | ||
coord: { x: width * 0.25, y: height * 0.75 }, | ||
exp: convertToUnorm8(presentColors[expect.bottomLeftColor]), | ||
}, | ||
// Bottom-right. | ||
{ | ||
coord: { x: width * 0.75, y: height * 0.75 }, | ||
exp: convertToUnorm8(presentColors[expect.bottomRightColor]), | ||
}, | ||
]); | ||
} | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters