2022年4月12日 星期二

AhFatKr的電腦圖學筆記week08

jsyeh.org/3dcg10=>下載win32 data

windows.zip => 下載windows => 解壓縮到桌面 => Light Material

data.zip => windows => data => 模型

File-New-Project,GLUT專案,偷他的程式放在Notepad++

//期中考試題

glPushMatrix();//備份矩陣

    glTranslatef(x,y,z);//移動

    glRotatef(角度,x,y,z);//旋轉

    glScalef(x,y,z);//縮放

glPopMatrix();//還原矩陣

git下載上周的程式

在專案開啟 把week06_light\main.cpp開啟,copy看到黃色茶壺


lightmaterial.cpp拿裡面的程式來用,便能讀入3d模型



#ifdef __APPLE__

#include <GLUT/glut.h>

#else

#include <GL/glut.h>

#endif


#include <stdlib.h>


static int slices = 16;

static int stacks = 16;


/* GLUT callback Handlers */


static void resize(int width, int height)

{

    const float ar = (float) width / (float) height;


    glViewport(0, 0, width, height);

    glMatrixMode(GL_PROJECTION);

    glLoadIdentity();

    glFrustum(-ar, ar, -1.0, 1.0, 2.0, 100.0);


    glMatrixMode(GL_MODELVIEW);

    glLoadIdentity() ;

}


static void display(void)

{

    const double t = glutGet(GLUT_ELAPSED_TIME) / 1000.0;

    const double a = t*90.0;


    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);

    glColor3d(1,0,0);


    glPushMatrix();

        glTranslated(-2.4,1.2,-6);

        glRotated(60,1,0,0);

        glRotated(a,0,0,1);

        glutSolidSphere(1,slices,stacks);

    glPopMatrix();


    glPushMatrix();

        glTranslated(0,1.2,-6);

        glRotated(60,1,0,0);

        glRotated(a,0,0,1);

        glutSolidCone(1,1,slices,stacks);

    glPopMatrix();


    glPushMatrix();

        glTranslated(2.4,1.2,-6);

        glRotated(60,1,0,0);

        glRotated(a,0,0,1);

        glutSolidTorus(0.2,0.8,slices,stacks);

    glPopMatrix();


    glPushMatrix();

        glTranslated(-2.4,-1.2,-6);

        glRotated(60,1,0,0);

        glRotated(a,0,0,1);

        glutWireSphere(1,slices,stacks);

    glPopMatrix();


    glPushMatrix();

        glTranslated(0,-1.2,-6);

        glRotated(60,1,0,0);

        glRotated(a,0,0,1);

        glutWireCone(1,1,slices,stacks);

    glPopMatrix();


    glPushMatrix();

        glTranslated(2.4,-1.2,-6);

        glRotated(60,1,0,0);

        glRotated(a,0,0,1);

        glutWireTorus(0.2,0.8,slices,stacks);

    glPopMatrix();


    glutSwapBuffers();

}



static void key(unsigned char key, int x, int y)

{

    switch (key)

    {

        case 27 :

        case 'q':

            exit(0);

            break;


        case '+':

            slices++;

            stacks++;

            break;


        case '-':

            if (slices>3 && stacks>3)

            {

                slices--;

                stacks--;

            }

            break;

    }


    glutPostRedisplay();

}


static void idle(void)

{

    glutPostRedisplay();

}


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 };


/* Program entry point */


int main(int argc, char *argv[])

{

    glutInit(&argc, argv);

    glutInitWindowSize(640,480);

    glutInitWindowPosition(10,10);

    glutInitDisplayMode(GLUT_RGB | GLUT_DOUBLE | GLUT_DEPTH);


    glutCreateWindow("GLUT Shapes");


    glutReshapeFunc(resize);

    glutDisplayFunc(display);

    glutKeyboardFunc(key);

    glutIdleFunc(idle);


    glClearColor(1,1,1,1);

    glEnable(GL_CULL_FACE);

    glCullFace(GL_BACK);


    glEnable(GL_DEPTH_TEST);

    glDepthFunc(GL_LESS);


    glEnable(GL_LIGHT0);

    glEnable(GL_NORMALIZE);

    glEnable(GL_COLOR_MATERIAL);

    glEnable(GL_LIGHTING);


    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);


    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_SHININESS, high_shininess);


    glutMainLoop();


    return EXIT_SUCCESS;

}

    GLUT callback?會被GLUT呼叫的函示

    (我們寫的那些display() keyboard() mouse() motion()函示)

 期中考題

glPushMatrix();//備份矩陣

  glTranslatef(x,y,z);//移動

  glRotatef(角度,x,y,z);//轉動

  glScalef(x,y,z);//縮放

glPopMatrix();//還原矩陣

函示呼叫

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 };

函示宣告

 glEnable(GL_DEPTH_TEST);

    glDepthFunc(GL_LESS);


    glEnable(GL_LIGHT0);

    glEnable(GL_NORMALIZE);

    glEnable(GL_COLOR_MATERIAL);

    glEnable(GL_LIGHTING);


    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);


    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_SHININESS, high_shininess);



沒有留言:

張貼留言

VERY BEAUTIFUL, VERY POWERFUL

一.     一樣先安裝且設定好freeglut,OpecCV, 開啟CodeBlocks建立新專案 week11_gundam,                 把 MyGundam.zip下載解壓縮後的data資料夾放到freeglut/bin裡面 把week09_openc...