sketch = function( p ) {
consoleHook;
let button;
let clickCount = 0;
const axiom = "F";
let len = 250;
let angle;
let sentence = axiom;
var rules = [{
a: "F",
b: "FF+[+F-F-F]-[-F+F+F]"
}];
p.setup = () => {
p.createCanvas(p.windowWidth, 800);
p.background(0);
angle = p.radians(25);
p.createP(axiom);
turtle();
button = p.createButton('generate');
button.position(20, p.height-50 - 20);
button.style('width', '100px');
button.style('height','50px');
button.mousePressed(generate);
}
const generate = () => {
clickCount++;
if(clickCount>5) return;
p.strokeWeight(1);
len *= 0.5;
let nextSentence = "";
for (let i = 0; i < sentence.length; i++) {
let current = sentence.charAt(i);
let found = false;
for (let j = 0; j < rules.length; j++) {
if (current == rules[j].a) {
found = true;
nextSentence += rules[j].b;
break;
}
}
if (!found) {
nextSentence += current;
}
}
sentence = nextSentence;
console.log(sentence);
turtle();
}
const turtle = () => {
p.background(51);
p.resetMatrix();
p.translate(p.width / 3, p.height);
p.stroke(255);
for (let i = 0; i < sentence.length; i++) {
let c = p.map(i, sentence.length, 0, 255, 100);
p.strokeWeight(1);
p.stroke(c);
var current = sentence.charAt(i);
if (current == "F") {
p.line(0, 0, 0, -len);
p.translate(0, -len);
} else if (current == "+") {
p.rotate(angle);
} else if (current == "-") {
p.rotate(-angle)
} else if (current == "[") {
p.push();
} else if (current == "]") {
p.pop();
}
}
}
}