Run with phantomjs rasterize.js URL FILENAME
.
Last active
May 24, 2016 23:15
-
-
Save ismyrnow/eaed8d425649a69efc764f0933791427 to your computer and use it in GitHub Desktop.
PhantomJS script for rendering a webpage to an image
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
var page = require('webpage').create(), | |
system = require('system'), | |
address, output, size; | |
if (system.args.length < 3 || system.args.length > 5) { | |
console.log('Usage: rasterize.js URL filename [paperwidth*paperheight|paperformat] [zoom]'); | |
console.log(' paper (pdf output) examples: "5in*7.5in", "10cm*20cm", "A4", "Letter"'); | |
console.log(' image (png/jpg output) examples: "1920px" entire page, window width 1920px'); | |
console.log(' "800px*600px" window, clipped to 800x600'); | |
phantom.exit(1); | |
} else { | |
address = system.args[1]; | |
output = system.args[2]; | |
page.viewportSize = { width: 600, height: 600 }; | |
if (system.args.length > 3 && system.args[2].substr(-4) === ".pdf") { | |
size = system.args[3].split('*'); | |
page.paperSize = size.length === 2 ? { width: size[0], height: size[1], margin: '0px' } | |
: { format: system.args[3], orientation: 'portrait', margin: '1cm' }; | |
} else if (system.args.length > 3 && system.args[3].substr(-2) === "px") { | |
size = system.args[3].split('*'); | |
if (size.length === 2) { | |
pageWidth = parseInt(size[0], 10); | |
pageHeight = parseInt(size[1], 10); | |
page.viewportSize = { width: pageWidth, height: pageHeight }; | |
page.clipRect = { top: 0, left: 0, width: pageWidth, height: pageHeight }; | |
} else { | |
console.log("size:", system.args[3]); | |
pageWidth = parseInt(system.args[3], 10); | |
pageHeight = parseInt(pageWidth * 3/4, 10); // it's as good an assumption as any | |
console.log ("pageHeight:",pageHeight); | |
page.viewportSize = { width: pageWidth, height: pageHeight }; | |
} | |
} | |
if (system.args.length > 4) { | |
page.zoomFactor = system.args[4]; | |
} | |
page.open(address, function (status) { | |
if (status !== 'success') { | |
console.log('Unable to load the address!'); | |
phantom.exit(1); | |
} else { | |
window.setTimeout(function () { | |
page.render(output); | |
phantom.exit(); | |
}, 200); | |
} | |
}); | |
page.onConsoleMessage = function(msg, lineNum, sourceId) { | |
console.log('CONSOLE: ' + msg + ' (from line #' + lineNum + ' in "' + sourceId + '")'); | |
}; | |
page.onError = function (msg) { | |
console.error(msg); | |
}; | |
// Add shim for `bind`. | |
page.onInitialized = function() { | |
page.evaluate(function() { | |
Function.prototype.bind = Function.prototype.bind || function (thisp) { | |
var fn = this; | |
return function () { | |
return fn.apply(thisp, arguments); | |
}; | |
}; | |
}); | |
}; | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment