Skip to content

Latest commit

 

History

History
96 lines (80 loc) · 5.52 KB

PRINT.md

File metadata and controls

96 lines (80 loc) · 5.52 KB

IiifPrint

Simple component for printing of documents from IiifViewer to PDF on client side. This component requires jsPDF library. Basic usage:

var doc = new IiifPrint();
doc.addDocument('viewer');
doc.save();

Constructor IiifPrint() accepts two parameters:

page size - paper format (a0-a6), array with values in mm [295, 210] or 'auto' which will detect size of page automatically
orientation - values l (landscape), p (portrait) or 'auto'

Methods

Default position of elements starts from left-top corner. IiifPrint allows to set position from another corner of document using negative values.
For example to add rectangle to bottom. The position will be set on 0, -10 with rectangle height 10.

IiifPrint.addText(text, size, color, posX, posY)
Adds text to folowing position.
Params:
text
size - size of text in mm
color - color in rgb form as array e.g. [50, 0, 0]
posX, posY - position in mm.

IiifPrint.addBase64Image(imgData, posX, posY, sizeX, sizeY)
To document is added image, but the image has to be encoded with base64.

IiifPrint.addDocument(document, posX, posY)
This method will find canvas in element which is passed as first parameter (also div id as string is supported) and it adds image from canvas to document as JPEG with white background. PNG files are not supported by jsPDF.

IiifPrint.addRectangle(posX, posY, width, height, color)
To document adds custom rectangle without borders.

IiifPrint.save(name)
It returns pdf document.

Example

See live example in IiifViewer examples.

<!doctype html>
<html>
  <head>
    <script src="http://parall.ax/parallax/js/jspdf.js"></script>
    <script src="iiifviewer-pdf.js"></script>
    <title>IIIF Viewer</title>
    <style>
      html, body, #viewer{width:100%;height:100%;margin:0;padding:0;}
      #btn-print{position: absolute; top: 20px; right: 20px;}
    </style>
  </head>
  <body>
    <div id="viewer"></div>
    <button id="btn-print" onclick="print();">Print</button>

    <script type="text/javascript">
      //init IiifViewer
      var url = location.hash.toString().substr(1);
      if (url.length < 2) url = 'http://demo.iiifhosting.com/iiif/demo/info.json';
      new IiifViewer('viewer', url, undefined, '');

      function print() {
        var logo = '';

        var doc = new IiifPrint('a4', 'auto');
        //adds document
        doc.addDocument('viewer');

        //Adds image to document
        doc.addBase64Image(logo, 10, 10, 59, 17);
        //Adds text to document
        doc.addText('IiifViewer', 25, [0, 0, 0], 28, 21.5);

        //Draw text to bottom of document
        var rHeight = 8;
        doc.addRectangle(0, -(rHeight), 297, rHeight, [255, 255, 255]);
        //it's possible to draw from another corner using negative values of position
        doc.addText(location.host, 12, [0, 0, 0], 10, -10);

        //Get pdf
        doc.save('mydocument');
      }
    </script>
  </body>
</html>

CORS

If you want to create PDF documents from data on different domains, the tiles needs to have CORS headers set on the remote server (see http://www.enable-cors.org/ for more details). You also need to instruct the IiifViewer how to set the CORS attributes -- the most common way is to pass empty string ('') as fourth parameter to the constructor (see above).