Run details:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:104.0) Gecko/20100101 Firefox/104.0
Firefox 104
Mac OS X 10.15
Desktop
2 years ago
Test name Executions per second
DrawImage whole master into di canvas 341335.4 Ops/sec
PutImageData whole master into pid canvas 193720.2 Ops/sec
DrawImage half master into di canvas 221882.2 Ops/sec
PutImageData half master into pid canvas 242717.7 Ops/sec
HTML Preparation code:
AخA
 
1
<canvas id='master' width='100' height='100'></canvas>
2
<canvas id='pid' width='100' height='100'></canvas>
3
<canvas id='di' width='100' height='100'></canvas>
Script Preparation code:
x
 
var master = document.getElementById('master');
var masterctx = master.getContext('2d');
var pid = document.getElementById('pid').getContext('2d');
var di = document.getElementById('di').getContext('2d');
masterctx.fillRect(0,0,50,50);
masterctx.fillStyle = "red";
masterctx.fillRect(50,50,100,100);
var imgDataFull = masterctx.getImageData(0,0,100,100);
var imgDataHalf = masterctx.getImageData(25,0,75,100);
Tests:
  • DrawImage whole master into di canvas

     
    di.drawImage(master,0,0);
  • PutImageData whole master into pid canvas

     
    pid.putImageData(imgDataFull,0,0);
  • DrawImage half master into di canvas

     
    di.drawImage(master,25,0,50,100,25,0,50,100);
  • PutImageData half master into pid canvas

     
    pid.putImageData(imgDataHalf,25,0);