PhantomJS - Capture d'écran

PhantomJS est très utile pour prendre une capture d'écran d'une page Web et convertir une page Web en PDF. Nous avons donné ici un exemple simple pour montrer comment cela fonctionne.

Exemple

var page = require('webpage').create();
page.open('http://phantom.org/',function(status){
   page.render('phantom.png');
   phantom.exit();
});

Exécutez le programme ci-dessus et la sortie sera enregistrée sous phantom.png.

Convertir des pages Web en PDF

PhantomJS aide également à convertir des pages Web en PDF avec en-tête et pied de page ajoutés. Jetez un œil à l'exemple suivant pour comprendre comment cela fonctionne.

var wpage = require('webpage').create(); 
var url = "https://en.wikipedia.org/wiki/Main_Page"; 
var output = "test.pdf"; 

wpage.paperSize = { 
   width: screen.width+'px', 
   height: '1500px', 
   
   margin: {
      'top':'50px', 
      'left':'50px', 
      'rigtht':'50px' 
   }, 
   orientation:'portrait', 
   header: { 
      height: "1cm", 
      contents: phantom.callback(function(pageNumber, nPages) { 
         return "<h5>Header <b>" + pageNumber + " / " + nPages + "</b></h5>"; 
      }) 
   }, 
   footer: { 
      height: "1cm", 
      contents: phantom.callback(function(pageNumber, nPages) {   
         return "<h5>Footer <b>" + pageNumber + " / " + nPages + "</b></h5>"; 
      }) 
   } 
} 
wpage.open(url, function (status) { 
   if (status !== 'success') { 
      console.log('Page is not opening'); 
      phantom.exit(); 
   } else { 
      wpage.render(output); 
      phantom.exit();     
   } 
});

Le programme ci-dessus génère les éléments suivants output.

The above will convert the page into pdf and will be saved in test.pdf

Convertir un canevas en image

Phantomjs peut facilement convertir un canevas en image. Jetez un œil à l'exemple suivant pour comprendre comment cela fonctionne.

var page = require('webpage').create(); 
page.content = '<html><body><canvas id="surface" width="400" height="400"></canvas></body></html>'; 

page.evaluate(function() {
   var context,e1; 
   el = document.getElementById('surface'); 
   
   context = el.getContext('2d'); 
   context.font = "30px Comic Sans MS"; 
   context.fillStyle = "red"; 
   context.textAlign = "center"; 
   context.fillText("Welcome to PhantomJS ", 200, 200); 
   
   document.body.style.backgroundColor = 'white'; 
   document.body.style.margin = '0px'; 
}); 
page.render('canvas.png'); 
phantom.exit();

Le programme ci-dessus génère les éléments suivants output.