This is another example.
Assuming you already have a canvas and want to do some modifications.
for example, you may use html2canvas.js, which will return a canvas for you, but you may want to edit it...
But as an example, I don't want to involve too many unrelated packages, so in my example, I use a simple method to generate a canvas
Example
<img id="original">
<br>
<button>click me</button>
<br>
<script>
window.onload = () => {
// Create a canvas to represent a canvas generated by your programs.
const img = document.querySelector(`#original`)
const orgCanvas = document.createElement(`canvas`)
const orgCanvasCtx = orgCanvas.getContext(`2d`)
img.src = ""
img.onload = e => {
orgCanvasCtx.drawImage(e.target, 0, 0)
}
document.querySelector(`button`).onclick = () => {
// Getting start crop after orgCanvas is ready.
const quality = 1.0
const blobURL = orgCanvas.toDataURL(`image/png`, quality)
const cropImg = new Image()
cropImg.src = blobURL
cropImg.dataset.cropOptions = JSON.stringify({ // like <img data-crop-options="...">
x: 3, y: 10, width: 15, height: 26
})
cropImg.onload = () => {
URL.revokeObjectURL(cropImg.src)
if (cropImg.dataset.cropOptions === "") {
return
}
const {x, y, width, height} = JSON.parse(cropImg.dataset.cropOptions)
const cropCanvas = document.createElement(`canvas`);
[cropCanvas.width, cropCanvas.height] = [width, height]
const cropCanvasCtx = cropCanvas.getContext(`2d`)
cropCanvasCtx.drawImage(cropImg,
x, y, width, height,
0, 0, width, height, // paste it to the left upper corner
)
cropImg.dataset.cropOptions = "" // stop callback
cropImg.src = cropCanvas.toDataURL(`image/png`, quality) // it will do cropImg.onload again ...
}
document.body.append(cropImg)
}
}
</script>