// P_2_1_2_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. /* changing module color and positions in a grid * * MOUSE * position x : offset x * position y : offset y * left click : random position * * KEYS * 1-3 : different sets of colors * 0 : default * arrow up/down : background module size * arrow left/right : foreground module size * s : save png * p : save pdf */ var moduleColorBackground = 0; var moduleColorForeground = 255; var moduleAlphaBackground = 100; var moduleAlphaForeground = 100; var moduleRadiusBackground = 40; var moduleRadiusForeground = 15; var backColor = 255; var tileCount = 20; var actRandomSeed = 0; function setup(){ createCanvas(780, 780); } function draw() { push(); translate(width/tileCount/2, height/tileCount/2); colorMode(HSB, 360, 100, 100, 100); background(backColor); smooth(); noStroke(); randomSeed(actRandomSeed); for (var gridY=0; gridY<tileCount; gridY++) { for (var gridX=0; gridX<tileCount; gridX++) { var posX = width/tileCount * gridX; var posY = height/tileCount * gridY; var shiftX = random(-1, 1) * mouseX/20; var shiftY = random(-1, 1) * mouseY/20; fill(moduleColorBackground, moduleAlphaBackground); ellipse(posX+shiftX, posY+shiftY, moduleRadiusBackground, moduleRadiusBackground); } } for (var gridY=0; gridY<tileCount; gridY++) { for (var gridX=0; gridX<tileCount; gridX++) { var posX = width/tileCount * gridX; var posY = height/tileCount * gridY; fill(moduleColorForeground, moduleAlphaForeground); ellipse(posX, posY, moduleRadiusForeground, moduleRadiusForeground); } } pop(); } function mousePressed() { actRandomSeed = int(random(100000)); } function keyTyped(){ colorMode(HSB, 360, 100, 100, 100); if (key == 's' || key == 'S') save("P_2_1_2_02.png"); if (key == '1'){ moduleColorBackground = color(273, 73, 51); } if (key == '2'){ moduleColorForeground = color(323, 100, 77); } if (key == '3'){ moduleAlphaBackground = 50; moduleAlphaForeground = 50; } if (key == '0'){ moduleColorBackground = 0; moduleColorForeground = 360; moduleAlphaBackground = 100; moduleAlphaForeground = 100; moduleRadiusBackground = 30; moduleRadiusForeground = 15; } } function keyPressed(){ if (keyCode == UP_ARROW) moduleRadiusBackground += 2; if (keyCode == DOWN_ARROW) moduleRadiusBackground = max(moduleRadiusBackground-2, 10); if (keyCode == LEFT_ARROW) moduleRadiusForeground = max(moduleRadiusForeground-2, 5); if (keyCode == RIGHT_ARROW) moduleRadiusForeground += 2; }