PhantomJS - स्क्रीन कैप्चर

PhantomJS एक वेबपेज का स्क्रीनशॉट लेने और एक वेबपेज को एक पीडीएफ में बदलने में बहुत मददगार है। हमने यहां एक सरल उदाहरण दिया है कि यह कैसे प्रदर्शित होता है।

उदाहरण

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

उपरोक्त कार्यक्रम निष्पादित करें और आउटपुट के रूप में सहेजा जाएगा phantom.png

PDF में Webpages कन्वर्ट करें

PhantomJS वेबरेज को PDF में शीर्षक और पाद लेख के साथ बदलने में भी मदद करता है। यह कैसे काम करता है यह समझने के लिए निम्नलिखित उदाहरण पर एक नज़र डालें।

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();     
   } 
});

उपरोक्त कार्यक्रम निम्नलिखित उत्पन्न करता है output

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

एक कैनवास को एक छवि में बदलें

प्रेत आसानी से एक कैनवस को एक छवि में बदल सकते हैं। यह कैसे काम करता है यह समझने के लिए निम्नलिखित उदाहरण पर एक नज़र डालें।

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();

उपरोक्त कार्यक्रम निम्नलिखित उत्पन्न करता है output