2021年6月14日 星期一

張淳雅_Week05

 老師示範 - 萬花尺

程式碼位址: https://github.com/jsyeh/processing/tree/gh-pages/spirograph

PImage imgBG;
PGraphics pg;
//https://gentlejourneysbirthing.com/home/colorful_watercolor_texture_by_connyduck-d6o409f/
ArrayList<PVector> points;
void setup(){
  size(800,600,P2D);  
  stroke(255);
  noFill();
  points = new ArrayList<PVector>();
  angle = atan2(-cy, -cx);//一開始mouseX,mouseY為0,所以角度向左上角
  imgBG=loadImage("watercolor_texture.png");
  pg = createGraphics(800,600);
  drawPG();
}//之後可引導 mousePressed 在小齒輪後, 才能開始控制轉動
float r0=225, r1=57, r2=37.3;
float cx=320, cy=240;
float angle;
void drawPG(){
  pg.beginDraw();
  pg.noFill();
  pg.strokeWeight(2);
  pg.stroke(255);
  pg.beginShape();
  int a = points.size();
  if(a>2){
    pg.vertex(points.get(a-2).x, points.get(a-2).y);
    pg.vertex(points.get(a-1).x, points.get(a-1).y);
  }//只畫最後的點,前面不用再畫,可能會快一點
/*  for( PVector pt : points ){
    pg.vertex(pt.x, pt.y);//之後可變彩色漸層色彩
  }*/
  pg.endShape();
  pg.endDraw();
}
void draw(){
  background(0);
  imgBG.mask(pg);
  image(imgBG,0,0);
  colorMode(RGB);
  stroke(128);
  strokeWeight(1);
  ellipse(cx,cy, r0*2, r0*2);
  angle += deltaAngle();
  float angle2= -angle * r0 / r1;
  float x=cx+(r0-r1)*cos(angle), y=cy+(r0-r1)*sin(angle);
  //line(cx,cy, x, y);//不要畫線,比較好看
  circle2(x,y, r1, angle2);
  //if(mousePressed) saveFrame();
}
void circle2(float cx, float cy, float r, float angle){
  ellipse(cx,cy, r*2, r*2);
  for(float a=angle; a<angle+PI*2;a+=PI/4){
    line(cx,cy, cx+r*cos(a), cy+r*sin(a));
  }
}
float deltaAngle(){
  float angleNow=atan2(mouseY-cy,mouseX-cx);
  float angleOld=atan2(pmouseY-cy,pmouseX-cx);
  float delta = angleNow - angleOld;
  if( abs(delta)> PI ){
    if(delta>0) delta-=PI*2;
    else delta += PI*2;
  }
  return delta;
}
void mouseDragged(){//按下mouse才開始記錄點
  float angle2= -angle * r0 / r1;
  float x=cx+(r0-r1)*cos(angle), y=cy+(r0-r1)*sin(angle);  
  float x2=x+r2*cos(angle2), y2=y+r2*sin(angle2); 
  points.add( new PVector(x2,y2) );
  drawPG();
}
圖片位址: https://camo.githubusercontent.com/7baa323c94bd643fc72b4f9ff7dce28b4b1869f9087442e2d45b817c75b032a1/68747470733a2f2f6a2e676966732e636f6d2f6d4f4c5767392e676966

期中考 - OpenGL必背10函式

1. glPushMatrix();//備份矩陣
2. glTranslatef( x, y, z );//移動
3. glRotatef(角度,x, y, z );//轉動
4. glScalef( x, y, z );//縮放
5. glBegin(GL_POLYGON);//開始畫
6. glTexCoord2f(tx,ty);//貼圖座標
7. glNormal3f(nx,ny,nz);// 打光的法向量
8. glColor3f( r, g, b); //色彩
9. glVertex3f( x, y, z );//頂點
10. glEnd();//結束畫
11. glPopMatrix();//還原矩陣

轉動圖畫

1.沿用上週程式碼,並修改
#include <GL/glut.h>
int N=0, vx[3000], vy[3000];
float angle=0;
void display()
{
    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);

    glPushMatrix();///備份矩陣
        glRotatef(angle, 0, 0, 1);///旋轉,對z軸轉
        glBegin(GL_LINE_LOOP);
        for (int i=0; i<N; i++)
        {
            glVertex2f((vx[i]-150)/150.0, -(vy[i]-150)/150.0);
        }
        glEnd();
    glPopMatrix();///還原矩陣
    glutSwapBuffers();///交換兩倍的buffers
}

void keyboard( unsigned char key, int x, int y)
{
    angle++;
    display();
}

void motion(int x, int y)
{
    vx[N]=x; vy[N]=y;
    N++;
    display();
}

int main(int argc, char ** argv)
{
    glutInit( &argc, argv );
    glutInitDisplayMode(GLUT_DOUBLE | GLUT_DEPTH);
    glutCreateWindow("08160173張淳雅O.O");

    glutDisplayFunc(display);
    glutKeyboardFunc(keyboard);///按按鍵就會轉動
    glutMotionFunc(motion);

    glutMainLoop();
}



沒有留言:

張貼留言

距地表面160 Week11

 #include "glm.h" GLMmodel* pmodel = NULL; void drawmodel(void) {     if (!pmodel) { pmodel = glmReadOBJ("data/porsche.obj...