Introduction to Processing
Emphasis on Maze Generation
P5.js
P5.js
data:image/s3,"s3://crabby-images/5558c/5558c18fa62d710c8cb8ae7cff1db22d9c2f82bf" alt=""
Text
Executes only once
Executes in Loop
approx 60Hz
P5.js
Try
data:image/s3,"s3://crabby-images/033fa/033fa6fe36ea446c10ed101ac8d2ae3c544ce93a" alt=""
P5.js
Axes
data:image/s3,"s3://crabby-images/033fa/033fa6fe36ea446c10ed101ac8d2ae3c544ce93a" alt=""
P5.js
Axes
data:image/s3,"s3://crabby-images/c79a3/c79a3e29ca0076b348a9a7332ba37ffb0df1eecc" alt=""
P5.js
Try
data:image/s3,"s3://crabby-images/e6f2c/e6f2c2e45b19f0a2de467f8a192d028556646d6d" alt=""
P5.js
Try
data:image/s3,"s3://crabby-images/e6f2c/e6f2c2e45b19f0a2de467f8a192d028556646d6d" alt=""
Challenge: Get rid of the trace!?
P5.js
Try
data:image/s3,"s3://crabby-images/e6f2c/e6f2c2e45b19f0a2de467f8a192d028556646d6d" alt=""
Challenge: Get rid of the trace!?
P5.js
Try
Challenge: Get rid of the trace!?
data:image/s3,"s3://crabby-images/aaaf7/aaaf7ad94f5565b1ddac6b8efb2668da9096aee1" alt=""
Reasoning?
P5.js
Try
Draw Rectangle
data:image/s3,"s3://crabby-images/4b989/4b9890aad51ea679afceea9ff32520d1f74ba04e" alt=""
rect(x,y,w,h)
P5.js
Try
"Objectify" It!!
data:image/s3,"s3://crabby-images/c213f/c213f6ff27f7255df3eea5de36b1e406108ed956" alt=""
data:image/s3,"s3://crabby-images/2c5ff/2c5ff33e00f11c812d528313d5d5ba14db7a9400" alt=""
P5.js
Try
Add more "Logic"
data:image/s3,"s3://crabby-images/c213f/c213f6ff27f7255df3eea5de36b1e406108ed956" alt=""
- You might need to add or remove walls
- You might need to highlight rectangles
Before That... How will you fill in a "Grid of Cells"??
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
data:image/s3,"s3://crabby-images/2b17b/2b17b064267e325800077f4c366ac663240552e4" alt=""
ncols,nrows=??
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
data:image/s3,"s3://crabby-images/2b17b/2b17b064267e325800077f4c366ac663240552e4" alt=""
ncols,nrows=??
data:image/s3,"s3://crabby-images/a6ba2/a6ba2b6ed0c81d73f27806b5c4e6bd9ccd777d7a" alt=""
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
data:image/s3,"s3://crabby-images/2b17b/2b17b064267e325800077f4c366ac663240552e4" alt=""
ncols,nrows=??
data:image/s3,"s3://crabby-images/a6ba2/a6ba2b6ed0c81d73f27806b5c4e6bd9ccd777d7a" alt=""
0
1
ncol
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
data:image/s3,"s3://crabby-images/2b17b/2b17b064267e325800077f4c366ac663240552e4" alt=""
ncols,nrows=??
data:image/s3,"s3://crabby-images/a6ba2/a6ba2b6ed0c81d73f27806b5c4e6bd9ccd777d7a" alt=""
0
1
ncol
nrows
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
data:image/s3,"s3://crabby-images/2b17b/2b17b064267e325800077f4c366ac663240552e4" alt=""
ncols,nrows=??
data:image/s3,"s3://crabby-images/a6ba2/a6ba2b6ed0c81d73f27806b5c4e6bd9ccd777d7a" alt=""
0
1
ncol
nrows
for (var x = 0; x < cols; ++x) {
grid[x] = new Array(rows); // add 2d array
for (var y = 0; y < rows; ++y) {
var cell = new Cell(x, y);
grid[x][y] = cell;
//grid[x][y].show();
}
}
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
var w = 50;
var grid = [];
var cols = 0;
var rows = 0;
var canvasHeight = 400+2;
var canvasWidth = 400+2;
function Cell(x, y) {
this.x = x*w;
this.y = y*w;
this.show = function () {
var x = this.x ;
var y = this.y ;
fill(255);
rect(x, y, w, w);
}
}
var cell;
function setup() {
createCanvas(400, 400);
background(0);
cols = floor(canvasWidth / w);
rows = floor(canvasHeight / w);
for (var x = 0; x < cols; ++x) {
grid[x] = new Array(rows); // add 2d array
for (var y = 0; y < rows; ++y) {
var cell = new Cell(x, y);
grid[x][y] = cell;
//grid[x][y].show();
}
}
}
function draw() {
for (var x = 0; x < cols; ++x) {
for (var y = 0; y < rows; ++y) {
grid[x][y].show();
}
}
}
P5.js
Try
Add more "Logic"
Before That... How will you fill in a "Grid of Cells"??
- You might need to add or remove walls
- You might need to highlight rectangles (Based on Visited or not)
data:image/s3,"s3://crabby-images/20a81/20a81c0a5853e52c50df93bb0d791162d64ccd78" alt=""
P5.js
Add more "Logic"
- You might need to add or remove walls
- You might need to highlight rectangles (Based on Visited or not)
data:image/s3,"s3://crabby-images/6fd79/6fd79fbab422088390e0feb129a41f3dd3df52bb" alt=""
Cell(0,0)
Cell(m,n)
All other cells
No fill if cell is not visited
Introduction to P5.js
By Incredeble us
Introduction to P5.js
- 77