老師示範 - 萬花尺
程式碼位址: 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();
}




沒有留言:
張貼留言