foliojs / pdfkit

A JavaScript PDF generation library for Node and the browser
http://pdfkit.org/
MIT License
9.9k stars 1.15k forks source link

Draw Border around images #765

Open marco-solare opened 6 years ago

marco-solare commented 6 years ago

Dear @devongovett thanks for the fantastic library!

My Question is:

I am currently trying to add a border to images - so I searched for something like widthOfImage / heighOfImage to get the dimensions of placed / included images within the document that get placed like that:

doc.image( 'image.png', 20, 30, { fit: [400, 300], align: 'center' } );

is there a way to get the image dimensions in order to use them to draw a rectangle over the image or another way to add borders?

Best, Marco.

alafr commented 6 years ago

You can get the image dimensions like this:

var img = doc.openImage('image.png');
var width = img.width;
var height = img.height;
doc.image(img);
javactive commented 5 years ago

alafr, I don't see doc.openImage in the PdfKit API for PDFDocument. I tried and didn't work

alafr commented 5 years ago

It works in the browser demo. The openImage function is not yet documented. It returns a PDFImage object which has width, height properties and can be used in doc.image calls instead of the image path.

var doc = new PDFDocument();
var stream = doc.pipe(blobStream());

var imageUrl = '';
var img = doc.openImage(imageUrl);
var width = img.width;
var height = img.height;
doc.text('The image size is ' + width + 'x' + height + 'px');
var x = doc.x;
var y = doc.y;
doc.image(img, x, y);
doc.rect(x, y, width, height).stroke();

doc.end();

stream.on('finish', function() {
  iframe.src = stream.toBlobURL('application/pdf');
});