缩小无头木偶师屏幕截图的大小

Gab*_*ner 5 node.js google-chrome-headless puppeteer

我正在使用 lambda 函数来启动带有无头镀铬的 puppeteer。我可以拍照并将其保存到 s3 存储桶,但图像太大。我最初将视口设置为默认值,但图像仍然显示为 1520 X 1520。

这是我当前启动无头浏览器并截取屏幕截图的代码。

const browser = await chromium.puppeteer.launch({
  executablePath: await chromium.executablePath,
  headless: chromium.headless,
  args: chromium.args,
  defaultViewport: { width: 800, height: 600, deviceScaleFactor: 2 },
  ignoreHTTPSErrors: true,
});
    
const body = isJson(event.data ? event.data : event.body);
    
const timeStamp = Date.now();
const HandleBars = require("handlebars");
const bucketForTemplates = {
  Bucket: templateBucket,
  Key: `${body.template}.hbs`,
};

const file = await s3.getObject(bucketForTemplates).promise();

const template = HandleBars.compile(file.Body.toString());
const renderedPage = template(body);

const page = await browser.newPage();

await page.setViewport({ deviceScaleFactor: 2 });
await page.setContent(renderedPage);

//wait for page to load
await page.waitForSelector("#image");
const image = await page.$("#image");

const box = await image.boundingBox();
const x = box["x"];
const y = box["y"];
const w = box["width"];
const h = box["height"];

const buffer = await page.screenshot({
  type: "jpeg",
  clip: { x: x, y: y, width: w, height: h },
});
    
await page.close();
await browser.close();
//save image to s3.
Run Code Online (Sandbox Code Playgroud)

我正在拍照的 div 设置宽度为 760px,高度为 760px,但屏幕截图为 1520 X 1520。

如何将图像缩小到不那么大?

Vav*_*off 3

您可以使用视口设置启动 puppeteer deviceScaleFactor: 2

const browser = await chromium.puppeteer.launch({
  defaultViewport: { width: 800, height: 600, deviceScaleFactor: 2 }, // <----
});
Run Code Online (Sandbox Code Playgroud)

根据文档,它“可以被认为是 DPR”,即设备像素比,从而将分辨率提高 2 倍。

此设置的默认值为1,您可以使用它来获取正确尺寸的屏幕截图。

  • 我在这个问题上花了四个小时。谢谢你! (2认同)