mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-05 03:21:52 +01:00
Added noDraw parameter to webGL test.
This commit is contained in:
parent
0225f94890
commit
3e3dbf2698
@ -157,6 +157,8 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const drawImage = location.search !== "?noDraw";
|
||||||
|
|
||||||
async function createImageHash(context, hashTable){
|
async function createImageHash(context, hashTable){
|
||||||
return Promise.all([function(){
|
return Promise.all([function(){
|
||||||
const canvas = document.createElement("canvas");
|
const canvas = document.createElement("canvas");
|
||||||
@ -173,8 +175,10 @@
|
|||||||
if (canvas){
|
if (canvas){
|
||||||
const hashCell = createHashRow(hashTable, "image" + (canvas.toDataURL? "": " (offscreen)"));
|
const hashCell = createHashRow(hashTable, "image" + (canvas.toDataURL? "": " (offscreen)"));
|
||||||
try {
|
try {
|
||||||
|
if (drawImage){
|
||||||
const gl = canvas.getContext(context) || canvas.getContext("experimental-" + context);
|
const gl = canvas.getContext(context) || canvas.getContext("experimental-" + context);
|
||||||
fillWebGlContext(gl);
|
fillWebGlContext(gl);
|
||||||
|
}
|
||||||
if (canvas.convertToBlob || canvas.toBlob){
|
if (canvas.convertToBlob || canvas.toBlob){
|
||||||
const blob = await (canvas.convertToBlob? canvas.convertToBlob(): (canvas.toBlob.length?
|
const blob = await (canvas.convertToBlob? canvas.convertToBlob(): (canvas.toBlob.length?
|
||||||
new Promise(function(resolve){canvas.toBlob(resolve);}):
|
new Promise(function(resolve){canvas.toBlob(resolve);}):
|
||||||
@ -195,10 +199,12 @@
|
|||||||
if (window.Worker && window.OffscreenCanvas){
|
if (window.Worker && window.OffscreenCanvas){
|
||||||
const hashCell = createHashRow(hashTable, "image (offscreen worker)");
|
const hashCell = createHashRow(hashTable, "image (offscreen worker)");
|
||||||
const url = new URL("./testAPI.js", location);
|
const url = new URL("./testAPI.js", location);
|
||||||
hashCell.textContent = await testAPI.runInWorker(async function getHash(contextType){
|
hashCell.textContent = await testAPI.runInWorker(async function getHash(contextType, drawImage){
|
||||||
const canvas = new OffscreenCanvas(300, 150);
|
const canvas = new OffscreenCanvas(300, 150);
|
||||||
|
if (drawImage){
|
||||||
const context = canvas.getContext(contextType);
|
const context = canvas.getContext(contextType);
|
||||||
fillWebGlContext(context);
|
fillWebGlContext(context);
|
||||||
|
}
|
||||||
return await testAPI.hash(
|
return await testAPI.hash(
|
||||||
await testAPI.readBlob(
|
await testAPI.readBlob(
|
||||||
canvas.convertToBlob?
|
canvas.convertToBlob?
|
||||||
@ -206,7 +212,7 @@
|
|||||||
await canvas.toBlob()
|
await canvas.toBlob()
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
}, [context], [url, fillWebGlContext]);
|
}, [context, drawImage], [url, fillWebGlContext]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user