我正在尝试将我为 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?
答案 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);
};
});