[work 42] Noisy circles
Movie
Source code
about
- z軸方向にノイズを加えた円をランダム方向に回転させる
file
- 上部にあるファイル名が表示されているボタンを押すと、表示されるファイルが切り替わります
- 別ウィンドウ表示したい時や行番号などが無いRawMode表示したい時は、コード内右上のボタンを押してください(ボタンはマウスオーバーすると表示されます)
#include "ofMain.h" #include "ofApp.h" //================================ int main( ){ // 4K:4096x2160 // 2K:2048x1080 // FullHD:1920x1080 // HD:1440x1080 // HD720p:1280x720 // DVD:720x480 // setup the GL context ofSetupOpenGL(1280,720, OF_WINDOW); // this kicks off the running of my app // can be OF_WINDOW or OF_FULLSCREEN // pass in width and height too: ofRunApp( new ofApp()); }
#pragma once #include "ofMain.h" class ofApp : public ofBaseApp{ public: ofApp(); ~ofApp(); void setup(); void update(); void draw(); void keyPressed(int key); void keyReleased(int key); void mouseMoved(int x, int y); void mouseDragged(int x, int y, int button); void mousePressed(int x, int y, int button); void mouseReleased(int x, int y, int button); void mouseEntered(int x, int y); void mouseExited(int x, int y); void windowResized(int w, int h); void dragEvent(ofDragInfo dragInfo); void gotMessage(ofMessage msg); private: // ofCamera cam; ofEasyCam cam; float rotateDeg; float zoff; ofVec2f center; std::array<std::vector<float>, 10> points; };
#include "ofApp.h" ofApp::ofApp(){ } ofApp::~ofApp(){ } //-------------------------------------------------------------- void ofApp::setup(){ double fps = 30; ofSetFrameRate(fps); ofBackground(0); ofSetBackgroundAuto(true); ofSetVerticalSync(true); center = ofVec2f(ofRandom(1000), ofRandom(1000)); zoff = 0; rotateDeg = 0; } //-------------------------------------------------------------- void ofApp::update(){ for (int i = 0; i < points.size(); i++) { zoff = ofRandom(1000); points.at(i).clear(); for (int deg = 0; deg < 360; deg+=5) { float angle = TWO_PI * (float)deg / 360.f; float p = ofSignedNoise(center.x + std::cos(angle) * 50, center.y + std::sin(angle) * 50, zoff); points.at(i).push_back(p); } zoff += 0.01; } } //-------------------------------------------------------------- void ofApp::draw(){ cam.begin(); for (int i = 0; i < points.size(); i++) { ofRotateDeg(rotateDeg, ofRandom(1), ofRandom(1), ofRandom(1)); if (i == 0) { ofSetColor(255, 0, 0); } else { ofSetColor(255); } ofNoFill(); ofSetPolyMode(OF_POLY_WINDING_NONZERO); ofSetLineWidth(2); ofBeginShape(); int deg = 0; for (float p : points.at(i)) { float angle = TWO_PI * (float)deg / 360.f; ofCurveVertex(std::cos(angle) * (50 * (i + 1)), std::sin(angle) * (50 * (i + 1)), p * 15); deg+=5; } ofEndShape(); } cam.end(); rotateDeg += 1; }
Link to the reference page
ソースコードで使用したAPIの中から要点になりそうなものをいくつか選んでリストアップしました。
category | API/Lib |
openframeworks | ofRotateDeg |
openframeworks | ofSignedNoise |
openframeworks | ofCurveVertex |
Development environment
- openframeworks 0.10.1
- c++
- macOS
- Xcode