如何在不污染全局范围的情况下使用 p5.js?

时间:2021-04-04 17:51:49

标签: javascript p5.js processing.js

我正在尝试将我为 processing.js 编写的一些代码转换为使用 p5.js。在现有代码中,我使用 processing = new Processing(canvas, p => (p.draw = draw_frame)) 之类的语句创建了一个对象,其中画布在 HTML 中定义为 <canvas id="canvas"></canvas>,并且任何处理函数和属性都附加到处理对象上。例如,要绘制一个三角形,我会编写类似 self.processing.triangle(...) 的代码。在 p5.js 中,所有通用函数似乎都是全局定义的。有没有办法以不污染全局范围的方式使用p5.js?

1 个答案:

答案 0 :(得分:2)

听起来您正在寻找instance mode

以下是该页面的示例:

let myp5 = new p5(( sketch ) => {

  let x = 100;
  let y = 100;

  sketch.setup = () => {
    sketch.createCanvas(200, 200);
  };

  sketch.draw = () => {
    sketch.background(0);
    sketch.fill(255);
    sketch.rect(x,y,50,50);
  };
});
相关问题