leaferjs / ui

一款好用的 Canvas 渲染引擎,革新的体验。高效绘图 、UI 交互(小游戏、互动应用、组态)、图形编辑。
https://www.leaferjs.com
MIT License
2.32k stars 81 forks source link

请教一个问题 #176

Open rojer95 opened 1 month ago

rojer95 commented 1 month ago

就是我用@leafer-draw/node在服务端进行渲染一些动态的海报 因为是需要生成打印物料。尺寸比较大 有的尺寸类似 8504 * 5669 但是现在渲染导出一张图片内存会飚到1-2个G的情况, 这种应该如何优化呢

leaferjs commented 1 month ago
  1. 需要提供个JSON数据结构,能复现才能看得出原因。

  2. node导出图片会另外再创建一张画布,所以初始化的画布可以宽高设置的小一些(不影响导出,可以节省内存)。

rojer95 commented 1 month ago

你好,这个是完整的DEMO代码:

const { Leafer, UI, useCanvas } = require("@leafer-ui/node");
const napi = require("@napi-rs/canvas");
const http = require("http");

useCanvas("napi", napi); // must

setInterval(() => {
  const memoryUsage = process.memoryUsage();
  console.log(
    [
      `RSS: ${(memoryUsage.rss / 1024 / 1024).toFixed(2)} MB`,
      `Heap total: ${(memoryUsage.heapTotal / 1024 / 1024).toFixed(2)} MB`,
      `Heap used: ${(memoryUsage.heapUsed / 1024 / 1024).toFixed(2)} MB`,
      `External: ${(memoryUsage.external / 1024 / 1024).toFixed(2)} MB`,
    ].join("/")
  );
}, 500);

http
  .createServer(function (req, res) {
    // console.log('data ----> ', JSON.stringify(data, null, 2));
    console.log("start render .....");
    const data = {
      x: 0,
      y: 0,
      id: "stage",
      tag: "Frame",
      data: { pixelRatio: 15, defaultFontSize: 14 },
      fill: [
        { type: "solid", color: "#FFFFFF" },
        {
          url: "http://cdn.eqistu.cn/huizhan_test/m0/20240726/143e1d4e73234612b03205e0c32cb6b4.jpeg",
          type: "image",
        },
      ],
      width: 500,
      height: 333,
      scaleX: 1,
      scaleY: 1,
      shadow: { x: 0, y: 0, blur: 6, color: "#dcdcdc" },
      children: [
        {
          x: 88.29568295836316,
          y: 9.900325705003596,
          id: "9ae65926-4871-4e32-a772-dd01e9e9cf52",
          tag: "Text",
          fill: [{ type: "solid", color: "#000000" }],
          text: "Entry Permit Number: {{uid}}\n\nEntry Permit\n{{exhiName}}\n{{exhiTime}}\n{{name}}\n{{company}}",
          skewX: 0,
          skewY: 0,
          width: 374.62646560925873,
          height: 375.6441570748247,
          stroke: [{ type: "solid", color: "#e3e3e3" }],
          editable: true,
          fontSize: 12,
          rotation: 0,
          textAlign: "center",
          fontFamily: "alibaba-puhui",
          fontWeight: "normal",
          lineHeight: { type: "percent", value: 1.5 },
          strokeWidth: 0,
          letterSpacing: { type: "px", value: 0 },
          textDecoration: "none",
        },
        {
          x: 291.11491990092554,
          y: 133.72768276811547,
          id: "7f19ab68-b670-4d08-90c6-98cdca4171dc",
          tag: "Rect",
          fill: {
            url: "",
            mode: "fit",
            type: "image",
          },
          text: "文字",
          skewX: 0,
          skewY: 0,
          width: 155.32713731176898,
          height: 148.74114435585363,
          margin: 1,
          editable: true,
          rotation: 0,
          colorDark: "#000000ff",
          colorLight: "#ffffff00",
          errorCorrectionLevel: "H",
        },
      ],
      overflow: "hide",
      hitChildren: true,
    };
    const leafer = new Leafer({
      width: data.width,
      height: data.height,
    });

    leafer.add(UI.one(data));

    leafer
      .export("webp", {
        screenshot: {
          x: data.x,
          y: data.y,
          width: data.width,
          height: data.height,
        },
        pixelRatio: data?.data?.pixelRatio || 1,
      })
      .then(function (result) {
        leafer.clear();
        leafer.destroy(true);
        res.writeHead(200, { "Content-Type": "text/html" });
        res.write(`<img src="${result.data}" />`);
        res.end();
        console.log("start end .....");
      });
  })
  .listen(3100, function () {
    console.log(
      "\x1B[36m%s\x1B[0m",
      "server is running at http://localhost:3100"
    );
  });

image