BioErrorLog Tech Blog

試行錯誤の記録

Generative Art #13 - Processing作品

おはよう。@bioerrorlogです。

ProcessingによるGenerative Art作品
13作目を記録します。

自作品まとめはこちら: www.bioerrorlog.work

Output

f:id:BioErrorLog:20200217220148p:plain f:id:BioErrorLog:20200217220210p:plain f:id:BioErrorLog:20200217220226p:plain

フル解像度/その他出力パターンはこちら:
Generative_13 - BioErrorLog - pixiv


Material

使用言語: Processing 3.5.3

Processingというプログラミング言語に聞き覚えがない、という方は是非こちらをご参考ください:
www.bioerrorlog.work


Source Code

GitHubはこちら

/*
Reference:
ジェネラティブ・アート―Processingによる実践ガイド - マット・ピアソン
*/


int _numChildren = 6; 
int _maxLevels = 6;  

Branch _trunk;

void setup() { 
    size(1920,1080); 
    background(255); 
    noFill(); 
    smooth(); 
    newTree();
}

void newTree() { 
    _trunk = new Branch(1, 0, width/2, height/2); 
    _trunk.drawMe();
}

void draw() { 
    background(255); 
    _trunk.updateMe(width/2, height/2); 
    _trunk.drawMe();

    saveFrame("frames/generative_13_#####.png"); // 各フレームで画像を保存
}

void keyPressed(){
    /*
    BACKSPACEキー押下: リセット
    */
    
    if (keyCode == BACKSPACE){
        setup();
    }
}

class Branch { 
    float level, index; 
    float x, y; 
    float endx, endy;
    float strokeW, alph; 
    float len, lenChange; 
    float rot, rotChange;

    Branch[] children = new Branch[0];

    Branch(float lev, float ind, float ex, float why) {

        level = lev; 
        index = ind;
        strokeW = (1/level) * 3; 
        alph = 5; 
        len = (1/level) * random(1000); 
        rot = random(360); 
        lenChange = random(1) - 1; 
        rotChange = random(0.5) - 0.5;
        
        updateMe(ex, why);

        if (level < _maxLevels) { 
            children = new Branch[_numChildren]; 
            for (int x=0; x<_numChildren; x++) { 
                children[x] = new Branch(level+1, x, endx, endy);
            } 
        } 
    }


    void updateMe(float ex, float why) { 
        x = ex; 
        y = why;

        rot += rotChange; 
        if (rot > 360) { 
            rot = 0; 
        } else if (rot < 0) { 
            rot = 360; 
        }

        len -= lenChange; 
        if (len < 0) { 
            lenChange *= -1; 
        } else if (len > 100) { 
            lenChange *= -1; 
        }

        float radian = radians(rot); 
        endx = x + (len * cos(radian)); 
        endy = y + (len * sin(radian));
        for (int i=0; i<children.length; i++) { 
            children[i].updateMe(endx, endy);
        }
    }

    void drawMe() {
        if (level > 1) { 
            strokeWeight(strokeW); 
            stroke(0, alph); 
            fill(50, alph); 
            ellipse(endx, endy, noise(len)*100, noise(len)*100);
        } 
        
        for (int i=0; i<children.length; i++) { 
            children[i].drawMe();
        } 
    }
}

Discussion

前回同様、マット・ピアソン「ジェネラティブ・アート―Processingによる実践ガイド」7章で紹介されるフラクタル構造のケーススタディを改変して作成。

フラクタル状の「宇宙のゼンマイ時計」の節々に薄く円を描画し、それぞれの円をnoiseで振動させています。

せわしなく動くクラゲの大群のような、あるいは解像度の低い煙のような雰囲気が面白いです。


See also

www.bioerrorlog.work

www.bioerrorlog.work

www.bioerrorlog.work

Reference