Я визуализирую веб-страницу в формате PNG с размерами 7642 на 3815 пикселей.
Загадочно, но при рендеринге полученное изображение имеет немного больше пикселей (PhantomJS добавляет некоторые поля, не знаю почему).
Я пробовал указать метод page.paperSize, но он ничего не делает:
"use strict";
var page = require('webpage').create();
var system = require('system');
var orderId = system.args[1];
var output = "/Users/mac/Desktop" + orderId + ".png"
var url = 'http://localhost:3000/?id=' + orderId
page.viewportSize = { width: 3000, height: 3000 };
page.paperSize = {
width: '7642px',
height: '3815px',
margin: '0px'
};
page.open(url, function (status) {
if (status !== 'success') {
console.info('Ha habido un error');
phantom.exit(1);
} else {
window.setTimeout(function () {
page.render(output, { format: 'png', quality: '100' });
phantom.exit();
}, 5000);
}
});
Есть идеи, пожалуйста?
Спасибо!






Наконец, я нашел этот обходной путь и работает:
page.zoomFactor = 1;
page.open(url, function (status) {
page.evaluate(function(w, h) {
document.body.style.width = w + "px";
document.body.style.height = h + "px";
}, width, height);
page.clipRect = {top: 0, left: 0, width: width, height: height};
if (status !== 'success') {
console.info('Ha habido un error');
phantom.exit(1);
} else {
window.setTimeout(function () {
page.render(output, { format: 'png', quality: '100' });
phantom.exit();
}, 5000);
}
});