[work 116] Rotate Tetrahedron

[work 116] Rotate Tetrahedron

Movie

Source code

about

  • 正四面体を回転させる
  • 軌跡で球体を描く

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:
    ofMesh mesh;
    std::vector<ofVec3f> points;
    std::vector<ofVec3f> drawPoints;
    float rotX;
    float rotY;
    
    ofEasyCam cam;
};
#include "ofApp.h"


ofApp::ofApp(){
    
}

ofApp::~ofApp(){
    
}

//--------------------------------------------------------------
void ofApp::setup(){
    double fps = 30;
    
    ofSetFrameRate(fps);
    ofBackground(0);
    ofSetBackgroundAuto(true);
    ofSetVerticalSync(true);
    
    ofEnableDepthTest();
    ofEnableSmoothing();
    ofEnableBlendMode(OF_BLENDMODE_SCREEN);
    
    ofVec3f d = ofVec3f(0, 1, 0);
    float size = 200;
    d *= size;
    
    points.push_back(d);
    d.rotate(120, ofVec3f(1, 0, 0));
    for (int i = 0; i < 3; i++) {
        ofVec3f org = d;
        org.rotate(120 * i, ofVec3f(0, 1, 0));
        points.push_back(org);
    }
    
    for (ofVec3f p : points) {
        drawPoints.push_back(p);
    }
    
    rotX = 0;
    rotY = 0;
    
    cam.setPosition(250, 250, 250);
    cam.lookAt(glm::vec3(0, 0, 0));
}

//--------------------------------------------------------------
void ofApp::update(){
    float angle0 = drawPoints.at(0).angle(ofVec3f(0, 1, 0));
    angle0 = ofWrapDegrees(angle0, 0, 360);
    float angle1 = ofWrapDegrees(angle0 + 120, 0, 360);
    
    ofColor c0, c1;
    c0.setHsb(ofMap(angle0, 0, 360, 0, 255), 255, 255);
    c1.setHsb(ofMap(angle1, 0, 360, 0, 255), 255, 255);
    c0.a = 80;
    c1.a = 80;
    
    mesh.setMode(OF_PRIMITIVE_TRIANGLE_STRIP);
    mesh.addVertex(drawPoints.at(0));
    mesh.addColor(c0);
    mesh.addVertex(drawPoints.at(1));
    mesh.addColor(c1);
    mesh.addVertex(drawPoints.at(2));
    mesh.addColor(c1);
    mesh.addVertex(drawPoints.at(3));
    mesh.addColor(c1);
    mesh.addVertex(drawPoints.at(0));
    mesh.addColor(c0);
    mesh.addVertex(drawPoints.at(1));
    mesh.addColor(c1);
    
    rotX += 0.4;
    rotY += 1;
    
    for (int i = 0; i < points.size(); i++) {
        ofVec3f p = points.at(i);
        p.rotate(rotX, ofVec3f(1, 0, 0));
        p.rotate(rotY, ofVec3f(0, 1, 0));
        drawPoints.at(i) = p;
    }
}

//--------------------------------------------------------------
void ofApp::draw(){
    cam.begin();
    ofRotateYDeg(ofGetFrameNum() * 0.2);
    mesh.drawWireframe();
    cam.end();
}

//--------------------------------------------------------------
void ofApp::keyPressed(int key){
    if (key == 's') {
        ofImage img;
        img.grabScreen(0, 0, ofGetWidth(), ofGetHeight());
        img.save("screenshot.png");
    }
}

Link to the reference page

ソースコードで使用したAPIの中から要点になりそうなものをいくつか選んでリストアップしました。

categoryAPI/Lib
openframeworksofMesh
openframeworksofVec3f
openframeworksofColor

Development environment

  • openframeworks 0.10.1
  • c++
  • macOS
  • Xcode