<canvas id="target" width="200" height="200"></canvas>
var imagebase = "";
var image = document.createElement('img');
image.src = imagebase;
var canvas = document.createElement('canvas');
canvas.width = 200;
canvas.height = 200;
var ctx = canvas.getContext('2d');
var imageloaded = false;
var imageBitmap;
image.onload = async function() {
ctx.drawImage(image, 0, 0);
imageloaded = true;
imageBitmap = await createImageBitmap(image)
};
var drawcanvas = document.getElementById('target');
var drawctx = drawcanvas.getContext('2d');
drawctx.drawImage(image, 50, 50, 120, 120, 5, 5, 120, 120);
drawctx.drawImage(canvas, 50, 50, 120, 120, 5, 5, 120, 120);
drawctx.drawImage(imageBitmap, 50, 50, 120, 120, 5, 5, 120, 120);
--enable-precise-memory-info
flag.
Test case name | Result |
---|---|
copy image section | |
copy canvas section | |
copy imageBitmap |
Test name | Executions per second |
---|---|
copy image section | 457977.1 Ops/sec |
copy canvas section | 700022.6 Ops/sec |
copy imageBitmap | 384117.5 Ops/sec |
A complex benchmarking scenario!
To provide an accurate answer, I'll need to analyze the provided code snippets and compare their performance.
From the RawUAString
field in the latest benchmark result, we can infer that the browser is Chrome 128 on a Windows Desktop.
Now, let's examine the benchmark definitions:
Test 1: "copy image section"
drawctx.drawImage(image, 50, 50, 120, 120, 5, 5, 120, 120);
This code draws an image from image
at coordinates (50, 50) with a size of 120x120 pixels.
Test 2: "copy canvas section"
drawctx.drawImage(canvas, 50, 50, 120, 120, 5, 5, 120, 120);
This code draws an image from canvas
(not the original image
) at coordinates (50, 50) with a size of 120x120 pixels.
Test 3: "copy imageBitmap"
drawctx.drawImage(imageBitmap, 50, 50, 120, 120, 5, 5, 120, 120);
This code draws an image from imageBitmap
(a bitmap representation of the original image
) at coordinates (50, 50) with a size of 120x120 pixels.
The differences between these tests lie in:
image
, canvas
, or imageBitmap
.To provide an accurate answer, I would need more information about the original code that generates these benchmark definitions. However, based on the provided code snippets, here are some general observations:
image
and canvas
might be related to the overhead of creating a new canvas object.imageBitmap
and either image
or canvas
could be due to the complexity of converting an image to a bitmap representation.Without additional context, it's difficult to provide a definitive answer. If you have more information about the original code, I'd be happy to help further!