// P_2_2_1_02 // // Generative Gestaltung, ISBN: 978-3-87439-759-9 // First Edition, Hermann Schmidt, Mainz, 2009 // Hartmut Bohnacker, Benedikt Gross, Julia Laub, Claudius Lazzeroni // Copyright 2009 Hartmut Bohnacker, Benedikt Gross, Julia Laub, Claudius Lazzeroni // // http://www.generative-gestaltung.de // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. /** * draw the path of a stupid agent * * MOUSE * position x : drawing speed * * KEYS * 1-3 : draw mode of the agent * BACKSPACE : clear display * s : save png * r : start pdf recording * e : stop pdf recording */ var NORTH = 0; var NORTHEAST = 1; var EAST = 2; var SOUTHEAST = 3; var SOUTH = 4; var SOUTHWEST = 5; var WEST = 6; var NORTHWEST= 7; var stepSize = 1; var diameter = 1; var drawMode = 1; var counter = 0; var direction; var posX, posY; function setup() { createCanvas(780, 780); colorMode(HSB, 360, 100, 100, 100); background(360); smooth(); noStroke(); posX = width/2; posY = height/2; } function draw() { colorMode(HSB, 360, 100, 100, 100); for (var i=0; i<=mouseX; i++) { counter++; // random number for the direction of the next step if (drawMode == 2) { direction = round(random(0, 3)); // only NORTH, NORTHEAST, EAST possible } else { direction = int(random(0, 7)); // all directions without NORTHWEST } if (direction == NORTH) { posY -= stepSize; } else if (direction == NORTHEAST) { posX += stepSize; posY -= stepSize; } else if (direction == EAST) { posX += stepSize; } else if (direction == SOUTHEAST) { posX += stepSize; posY += stepSize; } else if (direction == SOUTH) { posY += stepSize; } else if (direction == SOUTHWEST) { posX -= stepSize; posY += stepSize; } else if (direction == WEST) { posX -= stepSize; } else if (direction == NORTHWEST) { posX -= stepSize; posY -= stepSize; } if (posX > width) posX = 0; if (posX < 0) posX = width; if (posY < 0) posY = height; if (posY > height) posY = 0; if (drawMode == 3) { if (counter >= 100){ counter = 0; fill(192, 100, 64, 80); ellipse(posX+stepSize/2, posY+stepSize/2, diameter+7, diameter+7); } } fill(0, 40); ellipse(posX+stepSize/2, posY+stepSize/2, diameter, diameter); } } function keyPressed(){ if (keyCode == DELETE || keyCode == BACKSPACE) background(360); } function keyTyped(){ if (key == 's' || key == 'S') save("P_2_2_1_02.png"); if (key == '1') { drawMode = 1; stepSize = 1; diameter = 1; } if (key == '2') { drawMode = 2; stepSize = 1; diameter = 1; } if (key == '3') { drawMode = 3; stepSize = 10; diameter = 5; } }