2020年5月18日 星期一

0518作業紀錄-藍色寶寶

記得要先照week9的步驟




程式碼



#include <GL/glut.h>
#include "glm.h"
GLMmodel * model=NULL;
GLMmodel * mode2=NULL;
GLMmodel * mode3=NULL;
GLMmodel * mode4=NULL;
GLMmodel * mode5=NULL;
GLMmodel * mode6=NULL;

///打光0 : 宣告陣列,裡面是光的屬性值
const GLfloat light_ambient[]  = { 0.0f, 0.0f, 0.0f, 1.0f };
const GLfloat light_diffuse[]  = { 1.0f, 1.0f, 1.0f, 1.0f };
const GLfloat light_specular[] = { 1.0f, 1.0f, 1.0f, 1.0f };
const GLfloat light_position[] = { 2.0f, 5.0f, -5.0f, 0.0f };

const GLfloat mat_ambient[]    = { 0.7f, 0.7f, 0.7f, 1.0f };
const GLfloat mat_diffuse[]    = { 0.8f, 0.8f, 0.8f, 1.0f };
const GLfloat mat_specular[]   = { 1.0f, 1.0f, 1.0f, 1.0f };
const GLfloat high_shininess[] = { 100.0f };

float angle8=0,angle1=0,angle3=0,angle4=0,angle5=0,angle6=0,angle7=0;
float dx3=1,dx4=1,dx5=1,dx6=1,dx7=1,dx8=1;
void display()
{
    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
    if(model==NULL)///如果沒有複製
    {
        model = glmReadOBJ("headd.obj");///讀入模型
        glmUnitize(model);///Unit單位大小-1...+1
        glmFacetNormals(model);///算面face法向量
        glmVertexNormals(model,90);///在推算出vertex法向量
    }///離開if就有模型了


if(mode2==NULL)///如果沒有複製
    {
        mode2 = glmReadOBJ("body.obj");///讀入模型
        glmUnitize(mode2);///Unit單位大小-1...+1
        glmFacetNormals(mode2);///算面face法向量
        glmVertexNormals(mode2,90);///在推算出vertex法向量
    }///離開if就有模型了

    if(mode3==NULL)///如果沒有複製
    {
        mode3 = glmReadOBJ("l.obj");///讀入模型
        glmUnitize(mode3);///Unit單位大小-1...+1
        glmFacetNormals(mode3);///算面face法向量
        glmVertexNormals(mode3,90);///在推算出vertex法向量
    }///離開if就有模型了





    if(mode4==NULL)///如果沒有複製
    {
        mode4 = glmReadOBJ("r.obj");///讀入模型
        glmUnitize(mode4);///Unit單位大小-1...+1
        glmFacetNormals(mode4);///算面face法向量
        glmVertexNormals(mode4,90);///在推算出vertex法向量
    }///離開if就有模型了



    if(mode5==NULL)///如果沒有複製
    {
        mode5 = glmReadOBJ("le.obj");///讀入模型
        glmUnitize(mode5);///Unit單位大小-1...+1
        glmFacetNormals(mode5);///算面face法向量
        glmVertexNormals(mode5,90);///在推算出vertex法向量
    }///離開if就有模型了

if(mode6==NULL)///如果沒有複製
    {
        mode6 = glmReadOBJ("ri.obj");///讀入模型
        glmUnitize(mode6);///Unit單位大小-1...+1
        glmFacetNormals(mode6);///算面face法向量
        glmVertexNormals(mode6,90);///在推算出vertex法向量
    }///離開if就有模型了














    glPushMatrix();
    glTranslatef(0,0.4,0);///把下面正在轉動的手臂移到右上角
    glRotatef(angle1,0,1,0);///對Z軸轉動,像時針一樣轉動
    glTranslatef(0,0,0);///把關節(旋轉中心)放到畫面正中心
    glScalef(0.5,0.5,0.5);
    glmDraw(model,GLM_SMOOTH | GLM_MATERIAL);
    glPopMatrix();

   glPushMatrix();
    glTranslatef(0,0.05,0);///把下面正在轉動的手臂移到右上角
    glRotatef(180,0,1,0);///對Z軸轉動,像時針一樣轉動
    glTranslatef(0,0,0);///把關節(旋轉中心)放到畫面正中心
    glScalef(0.2,0.2,0.2);
    glmDraw(mode2,GLM_SMOOTH | GLM_MATERIAL);
      glPopMatrix();

       glPushMatrix();
    glTranslatef(0.15,0.25,0);///把下面正在轉動的手臂移到右上角
    glRotatef(angle3,1,0,1);///對Z軸轉動,像時針一樣轉動
    glTranslatef(0.01,0,0);///把關節(旋轉中心)放到畫面正中心
    glScalef(0.3,0.3,0.3);
    glmDraw(mode3,GLM_SMOOTH | GLM_MATERIAL);
      glPopMatrix();



      glPushMatrix();
    glTranslatef(-0.29,0.15,0);///把下面正在轉動的手臂移到右上角
    glRotatef(angle4,0,0,1);///對Z軸轉動,像時針一樣轉動
    glTranslatef(0.1,0,0);///把關節(旋轉中心)放到畫面正中心
    glScalef(0.35,0.35,0.35);
    glmDraw(mode4,GLM_SMOOTH | GLM_MATERIAL);
      glPopMatrix();

       glPushMatrix();
    glTranslatef(0.1,-0.15,0);///把下面正在轉動的手臂移到右上角
    glRotatef(angle5,0,0,1);///對Z軸轉動,像時針一樣轉動
    glTranslatef(0.1,0,0);///把關節(旋轉中心)放到畫面正中心
    glScalef(0.2,0.2,0.2);
    glmDraw(mode5,GLM_SMOOTH | GLM_MATERIAL);
      glPopMatrix();

      glPushMatrix();
    glTranslatef(-0.09,-0.1,0);///把下面正在轉動的手臂移到右上角
    glRotatef(angle6,0,0,1);///對Z軸轉動,像時針一樣轉動
    glTranslatef(-0.1,0,0);///把關節(旋轉中心)放到畫面正中心
    glScalef(0.15,0.15,0.15);
    glmDraw(mode6,GLM_SMOOTH | GLM_MATERIAL);
      glPopMatrix();



    glutSwapBuffers();


angle1++;
angle3+=dx3*0.3;
    if(angle3>60) dx3=-1;
    if(angle3<0) dx3=+1;

    angle4+=dx4*0.3;
    if(angle4>30) dx4=-1;
    if(angle4<0) dx4=+1;


    angle5+=dx5*0.3;
    if(angle5>30) dx5=-1;
    if(angle5<0) dx5=+1;

    angle6+=dx6*0.3;
    if(angle6>30) dx6=-1;
    if(angle6<0) dx6=+1;






}

int main(int argc, char**argv)
{
    glutInit(&argc, argv);
    glutInitDisplayMode(GLUT_DOUBLE | GLUT_DEPTH);
    glutCreateWindow("week11自己寫的喔~!!");

    glutDisplayFunc(display);
    glutIdleFunc(display);


    glEnable(GL_DEPTH_TEST);
    glDepthFunc(GL_LESS);
    ///打光1:要開啟光線
    glEnable(GL_LIGHT0);
    glEnable(GL_NORMALIZE);
    glEnable(GL_COLOR_MATERIAL);
    glEnable(GL_LIGHTING);
    ///打光2:要設定光的設定值
    glLightfv(GL_LIGHT0, GL_AMBIENT, light_ambient);
    glLightfv(GL_LIGHT0, GL_DIFFUSE, light_diffuse);
    glLightfv(GL_LIGHT0, GL_SPECULAR, light_specular);
    glLightfv(GL_LIGHT0, GL_POSITION, light_position);
    ///打光2.2:要把物體也設定好它的matreial
    glMaterialfv(GL_FRONT, GL_AMBIENT, mat_ambient);
    glMaterialfv(GL_FRONT, GL_DIFFUSE, mat_diffuse);
    glMaterialfv(GL_FRONT, GL_SPECULAR, mat_specular);
    glMaterialfv(GL_FRONT, GL_POSITION, high_shininess);

    glutMainLoop();
}





影片

沒有留言:

張貼留言