// P_2_1_3_04
//
// 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 positions of stapled circles in a grid
*
* MOUSE
* position x : module detail
* position y : module parameter
*
* KEYS
* 1-3 : draw mode
* arrow left/right : number of tiles horizontally
* arrow up/down : number of tiles vertically
* s : save png
*/
var tileCountX = 8;
var tileCountY = 8;
var count = 0;
var drawMode = 1;
function setup() {
createCanvas(780, 780);
}
function draw() {
colorMode(HSB, 360, 100, 100);
rectMode(CENTER);
smooth();
stroke(0);
noFill();
background(360);
count = mouseX/10 + 10;
var para = mouseY/height;
for (var gridY=0; gridY<= tileCountY; gridY++) {
for (var gridX=0; gridX<= tileCountX; gridX++) {
var tileWidth = width / tileCountX;
var tileHeight = height / tileCountY;
var posX = tileWidth*gridX + tileWidth/2;
var posY = tileHeight*gridY + tileHeight/2;
push();
translate(posX, posY);
// switch between modules
switch (drawMode) {
case 1:
for(var i=0; i < count; i++) {
rect(0, 0, tileWidth, tileHeight);
scale(1 - 3.0/count);
rotate(para*0.1);
}
break;
case 2:
colorMode(HSB, 360, 100, 100);
for(var i=0; i< count; i++) {
noStroke();
from = color(0,0,0,0.5);
to = color(52, 100, 71);
gradient = lerpColor(from, to, i/count);
fill(gradient, i/count*200);
rotate(PI/4);
rect(0, 0, tileWidth, tileHeight);
scale(1 - 3.0/count);
rotate(para*1.5);
}
break;
case 3:
colorMode(RGB, 255);
for(var i=0; i< count; i++) {
noStroke();
from = color(0, 130, 164);
to = color(255);
gradient = lerpColor(from, to, i/count);
fill(gradient,170);
push();
translate(4*i,0);
ellipse(0, 0, tileWidth/4, tileHeight/4);
pop();
push();
translate(-4*i,0);
ellipse(0, 0, tileWidth/4, tileHeight/4);
pop();
scale(1 - 1.5/count);
rotate(para*1.5);
}
break;
}
pop();
}
}
}
function keyTyped(){
if (key == 's' || key == 'S') save("P_2_1_3_04.png");
if (key == '1') drawMode = 1;
if (key == '2') drawMode = 2;
if (key == '3') drawMode = 3;
}
function keyPressed(){
if (keyCode == DOWN_ARROW) tileCountY = max(tileCountY-1, 1);
if (keyCode == UP_ARROW) tileCountY += 1;
if (keyCode == LEFT_ARROW) tileCountX = max(tileCountX-1, 1);
if (keyCode == RIGHT_ARROW) tileCountX += 1;
}