How to Get Image from Canvas Element and Use It in Img Src Tag

Assign a canvas element to the img.src

You need to use the method Canvas#toDataURL method

The HTMLCanvasElement.toDataURL() method returns a data URI containing a representation of the image in the format specified by the type parameter (defaults to PNG). The returned image is in a resolution of 96 dpi.

img.src = document.getElementById("canvas1").toDataURL();

Working Example:

const canvas = document.getElementById("canvas");const img_from_canvas = document.getElementById("img_from_canvas");
const context = canvas.getContext("2d");context.rect(10, 10, 150, 100);context.fill();img_from_canvas.src = canvas.toDataURL();
<p>canvas</p><canvas id="canvas"></canvas><p>image from canvas</p><img id="img_from_canvas"/>

Show a part of canvas image in an img tag

I have solved my problem with the suggestions of everyone. I've used a temporary canvas to hold the part of main canvas and then get the partial image from it.

And my solution is:

var canvas = $('canvas')[0];var ctx = canvas.getContext("2d");
$('#baseImg').load(function() { ctx.drawImage(this, 0, 0);});
$('#full').click(function() { $('div').html(''); var image = new Image(); image.onload = function() { $('div').html(this); }; image.src = canvas.toDataURL();});
$('#partail').click(function() { $('div').html('');
var height = 50, width = 50; var copyCanvas = $('<canvas id="canvas" width="' + width + '" height="' + height + '"></canvas>')[0]; var copyCtx = copyCanvas.getContext("2d"); copyCtx.putImageData(ctx.getImageData(10, 10, width, height), 0, 0);
var image = new Image(); image.onload = function() { $('div').html(this); }; image.src = copyCanvas.toDataURL();});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<h3>Canvas</h3><canvas id="canvas" width="100" height="100" style="border: 1px solid #000000;"></canvas>
<br /><br /><img id="baseImg" style="display: none;" src="" /><input id="full" type="button" value="Show Full Image" /><input id="partail" type="button" value="Show Partial Image" />
<h3>Image from canvas</h3><div style="border: 1px solid #000000; height: 100px; width: 100px;"></div>

Get a canvas object from an IMG element

HTMLImageElement.prototype.getCanvasFromImage = function(){
const canvas = document.createElement('canvas');
canvas.width = this.width;
canvas.height = this.height;
const ctx = canvas.getContext('2d');
ctx.drawImage(this, 0, 0);
return canvas;
};

const img = document.getElementById('myImage');
img.onload = () => {
const canvas = img.getCanvasFromImage();
const dataURL = canvas.toDataURL();

console.log(dataURL);
}
<img id="myImage" crossorigin="anonymous" src="https://dl.dropbox.com/s/zpoxft30lzrr5mg/20201012_102150.jpg" />

Insert an img tag into Canvas element

The canvas drawImage method will accept an html img element as an image source, so you can directly do this:

ctx.drawImage(document.getElementById('picture'),0,0);

Example code and a Demo:

window.onload=function(){    var canvas=document.getElementById("canvas");    var ctx=canvas.getContext("2d");    ctx.drawImage(document.getElementById('picture'),0,0);}
body{ background-color: ivory; }#canvas{border:1px solid red; margin:0 auto; }
<canvas id="canvas" width=300 height=300></canvas><!-- src is for this demo. You can still use your <%...%> --><img src='https://dl.dropboxusercontent.com/u/139992952/multple/sun.png' id='picture' style='max-height:100%'>

How can I use an image on an HTML5 canvas without previously having an image on the page?

Use JS to create an image

If you know the path to the image, or can provide it, you can use the following to create an image. It's important to note the image does take time to load and you cannot use the image successfully before it is loaded.

window.onload = function() {  var c = document.getElementById("myCanvas");  var ctx = c.getContext("2d");
var img = document.createElement("img");
img.onload = function() { ctx.drawImage(img, 10, 10); }
// triggers onload event (after it loads of course) img.src = "//via.placeholder.com/350x150";
}
<p>Canvas:</p><canvas id="myCanvas" width="370" height="170" style="border:1px solid #d3d3d3;">Your browser does not support the HTML5 canvas tag.</canvas>

Get frame from Img tag with a url source in Javascript

Use canvas.
1. Draw img tag contents on canvas
2. get DataUri from canvas (encoded base64 string)

var img = document.getElementById("the_img_1");
var canvas = document.getElementById('myCanvas') // reference to canvas element
var ctx = canvas.getContext('2d'); // get the canvas context;
ctx.drawImage(img, 0, 0, 640,480); //draw image into canvas;
encodedImg = canvas.toDataURL("image/png");

Fabric JS - Can i save canvas as image but with background from img tag?

Assuming your end objective is to convert dom to an image.
May be you could try out dom-to-image https://github.com/tsayen/dom-to-image

domtoimage.toJpeg(document.getElementById('my-node'), { quality: 0.95 })
.then(function (dataUrl) {
var link = document.createElement('a');
link.download = 'my-image-name.jpeg';
link.href = dataUrl;
link.click();
});

Here is the codesandbox demo
https://codesandbox.io/s/dom-node-to-png-10odz2



Related Topics



Leave a reply



Submit