亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? transformation.c

?? 圖形學課件 圖形學課件 圖形學課件
?? C
?? 第 1 頁 / 共 2 頁
字號:
world_display(void){    GLfloat pos[] = { 0.0, 0.0, 1.0, 0.0 };    double length;    float l[3];        l[0] = at[0] - eye[0];     l[1] = at[0] - eye[1];     l[2] = at[0] - eye[2];    length = normalize(l);        invert(modelview, inverse);        glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);        if (world_draw) {        glEnable(GL_LIGHTING);        glPushMatrix();        glMultMatrixd(inverse);        glLightfv(GL_LIGHT0, GL_POSITION, pos);        glPopMatrix();        drawmodel();        glDisable(GL_LIGHTING);    }        glPushMatrix();        glMultMatrixd(inverse);        glLightfv(GL_LIGHT0, GL_POSITION, pos);        /* draw the axis and eye vector */    glPushMatrix();    glColor3ub(0, 0, 255);    glBegin(GL_LINE_STRIP);    glVertex3f(0.0, 0.0, 0.0);    glVertex3f(0.0, 0.0, -1.0*length);    glVertex3f(0.1, 0.0, -0.9*length);    glVertex3f(-0.1, 0.0, -0.9*length);    glVertex3f(0.0, 0.0, -1.0*length);    glVertex3f(0.0, 0.1, -0.9*length);    glVertex3f(0.0, -0.1, -0.9*length);    glVertex3f(0.0, 0.0, -1.0*length);    glEnd();    glColor3ub(255, 255, 0);    glRasterPos3f(0.0, 0.0, -1.1*length);    glutBitmapCharacter(GLUT_BITMAP_HELVETICA_12, 'e');    glColor3ub(255, 0, 0);    glScalef(0.4, 0.4, 0.4);    drawaxes();    glPopMatrix();        invert(projection, inverse);    glMultMatrixd(inverse);        /* draw the viewing frustum */    glColor3f(0.2, 0.2, 0.2);    glBegin(GL_QUADS);    glVertex3i(1, 1, 1);    glVertex3i(-1, 1, 1);    glVertex3i(-1, -1, 1);    glVertex3i(1, -1, 1);    glEnd();        glColor3ub(128, 196, 128);    glBegin(GL_LINES);    glVertex3i(1, 1, -1);    glVertex3i(1, 1, 1);    glVertex3i(-1, 1, -1);    glVertex3i(-1, 1, 1);    glVertex3i(-1, -1, -1);    glVertex3i(-1, -1, 1);    glVertex3i(1, -1, -1);    glVertex3i(1, -1, 1);    glEnd();        glEnable(GL_BLEND);    glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);    glColor4f(0.2, 0.2, 0.4, 0.5);    glBegin(GL_QUADS);    glVertex3i(1, 1, -1);    glVertex3i(-1, 1, -1);    glVertex3i(-1, -1, -1);    glVertex3i(1, -1, -1);    glEnd();    glDisable(GL_BLEND);        glPopMatrix();    glutSwapBuffers();}voidworld_menu(int value){    switch (value) {    case 'm':        world_draw = !world_draw;        break;    }    redisplay_all();}voidscreen_reshape(int width, int height){    glViewport(0, 0, width, height);    glMatrixMode(GL_PROJECTION);    glLoadIdentity();    gluPerspective(60.0, (float)width/height, 0.5, 8.0);    glGetDoublev(GL_PROJECTION_MATRIX, projection);    glMatrixMode(GL_MODELVIEW);    glLoadIdentity();    gluLookAt(eye[0], eye[1], eye[2], at[0], at[1], at[2], up[0], up[1],up[2]);    if (swapped) {        glRotatef(rotation[0].value, rotation[1].value,             rotation[2].value, rotation[3].value);        glTranslatef(translation[0].value, translation[1].value,            translation[2].value);    } else {        glTranslatef(translation[0].value, translation[1].value,            translation[2].value);        glRotatef(rotation[0].value, rotation[1].value,             rotation[2].value, rotation[3].value);    }    glScalef(scale[0].value, scale[1].value, scale[2].value);    glGetDoublev(GL_MODELVIEW_MATRIX, modelview);    glClearColor(0.2, 0.2, 0.2, 0.0);    glEnable(GL_DEPTH_TEST);    glEnable(GL_LIGHTING);    glEnable(GL_LIGHT0);}voidscreen_display(void){    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);    drawmodel();    glutSwapBuffers();}voidscreen_menu(int value){    char* name = 0;        switch (value) {    case 'a':        name = "data/al.obj";        break;    case 's':        name = "data/soccerball.obj";        break;    case 'd':        name = "data/dolphins.obj";        break;    case 'f':        name = "data/flowers.obj";        break;    case 'j':        name = "data/f-16.obj";        break;    case 'p':        name = "data/porsche.obj";        break;    case 'r':        name = "data/rose+vase.obj";        break;    }        if (name) {        pmodel = glmReadOBJ(name);        if (!pmodel) exit(0);        glmUnitize(pmodel);        glmFacetNormals(pmodel);        glmVertexNormals(pmodel, 90.0);    }        redisplay_all();}voidcommand_reshape(int width, int height){    glViewport(0, 0, width, height);    glMatrixMode(GL_PROJECTION);    glLoadIdentity();    gluOrtho2D(0, width, height, 0);    glMatrixMode(GL_MODELVIEW);    glLoadIdentity();    glClearColor(0.0, 0.0, 0.0, 0.0);}voidcommand_display(void){    glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);        if (swapped) {        translation[0].y = 80;        translation[1].y = 80;        translation[2].y = 80;        rotation[0].y = 40;        rotation[1].y = 40;        rotation[2].y = 40;        rotation[3].y = 40;    } else {        translation[0].y = 40;        translation[1].y = 40;        translation[2].y = 40;        rotation[0].y = 80;        rotation[1].y = 80;        rotation[2].y = 80;        rotation[3].y = 80;    }        glColor3ub(255, 255, 255);    setfont("helvetica", 18);    drawstr(30, rotation[0].y, "glRotatef(");    drawstr(170, rotation[0].y, ",");    drawstr(230, rotation[0].y, ",");     drawstr(290, rotation[0].y, ",");    drawstr(350, rotation[0].y, ");");    drawstr(10, translation[0].y, "glTranslatef(");    drawstr(170, translation[0].y, ",");    drawstr(230, translation[0].y, ",");     drawstr(290, translation[0].y, ");");    drawstr(38, 120, "glScalef(");    drawstr(170, 120, ",");    drawstr(230, 120, ",");     drawstr(290, 120, ");");    drawstr(41, 160, "glBegin(  . . .  );");    drawstr(41, 200, " . . .");        cell_draw(&translation[0]);    cell_draw(&translation[1]);    cell_draw(&translation[2]);        cell_draw(&rotation[0]);    cell_draw(&rotation[1]);    cell_draw(&rotation[2]);    cell_draw(&rotation[3]);        cell_draw(&scale[0]);    cell_draw(&scale[1]);    cell_draw(&scale[2]);        if (!selection) {        glColor3ub(255, 255, 0);        drawstr(10, 240,            "Click on the arguments and move the mouse to modify values.");    }           glutSwapBuffers();}int old_y;voidcommand_mouse(int button, int state, int x, int y){    selection = 0;        if (state == GLUT_DOWN) {    /* mouse should only hit _one_ of the cells, so adding up all        the hits just propagates a single hit. */        selection += cell_hit(&translation[0], x, y);        selection += cell_hit(&translation[1], x, y);        selection += cell_hit(&translation[2], x, y);        selection += cell_hit(&rotation[0], x, y);        selection += cell_hit(&rotation[1], x, y);        selection += cell_hit(&rotation[2], x, y);        selection += cell_hit(&rotation[3], x, y);        selection += cell_hit(&scale[0], x, y);        selection += cell_hit(&scale[1], x, y);        selection += cell_hit(&scale[2], x, y);    }        old_y = y;        redisplay_all();}voidcommand_motion(int x, int y){    cell_update(&translation[0], old_y-y);    cell_update(&translation[1], old_y-y);    cell_update(&translation[2], old_y-y);    cell_update(&rotation[0], old_y-y);    cell_update(&rotation[1], old_y-y);    cell_update(&rotation[2], old_y-y);    cell_update(&rotation[3], old_y-y);    cell_update(&scale[0], old_y-y);    cell_update(&scale[1], old_y-y);    cell_update(&scale[2], old_y-y);        old_y = y;        redisplay_all();}voidcommand_menu(int value){    main_keyboard((unsigned char)value, 0, 0);}voidredisplay_all(void){    glutSetWindow(command);    glutPostRedisplay();    glutSetWindow(world);    world_reshape(sub_width, sub_height);    glutPostRedisplay();    glutSetWindow(screen);    screen_reshape(sub_width, sub_height);    glutPostRedisplay();}intmain(int argc, char** argv){    glutInitDisplayMode(GLUT_RGB | GLUT_DEPTH | GLUT_DOUBLE);    glutInitWindowSize(512+GAP*3, 512+GAP*3);    glutInitWindowPosition(50, 50);    glutInit(&argc, argv);        window = glutCreateWindow("Transformation");    glutReshapeFunc(main_reshape);    glutDisplayFunc(main_display);    glutKeyboardFunc(main_keyboard);        world = glutCreateSubWindow(window, GAP, GAP, 256, 256);    glutReshapeFunc(world_reshape);    glutDisplayFunc(world_display);    glutKeyboardFunc(main_keyboard);    glutCreateMenu(world_menu);    glutAddMenuEntry("Toggle model", 'm');    glutAttachMenu(GLUT_RIGHT_BUTTON);        screen = glutCreateSubWindow(window, GAP+256+GAP, GAP, 256, 256);    glutReshapeFunc(screen_reshape);    glutDisplayFunc(screen_display);    glutKeyboardFunc(main_keyboard);    glutCreateMenu(screen_menu);    glutAddMenuEntry("Models", 0);    glutAddMenuEntry("", 0);    glutAddMenuEntry("Soccerball", 's');    glutAddMenuEntry("Al Capone", 'a');    glutAddMenuEntry("F-16 Jet", 'j');    glutAddMenuEntry("Dolphins", 'd');    glutAddMenuEntry("Flowers", 'f');    glutAddMenuEntry("Porsche", 'p');    glutAddMenuEntry("Rose", 'r');    glutAttachMenu(GLUT_RIGHT_BUTTON);        command = glutCreateSubWindow(window, GAP+256+GAP, GAP+256+GAP, 256, 256);    glutReshapeFunc(command_reshape);    glutDisplayFunc(command_display);    glutMotionFunc(command_motion);    glutMouseFunc(command_mouse);    glutKeyboardFunc(main_keyboard);    glutCreateMenu(command_menu);    glutAddMenuEntry("Projection", 0);    glutAddMenuEntry("", 0);    glutAddMenuEntry("[s]  Swap translate/rotate", 's');    glutAddMenuEntry("[r]  Reset parameters", 'r');    glutAddMenuEntry("", 0);    glutAddMenuEntry("Quit", 27);    glutAttachMenu(GLUT_RIGHT_BUTTON);        redisplay_all();        glutMainLoop();        return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕精品在线不卡| 777a∨成人精品桃花网| 久久se精品一区精品二区| 亚洲影视在线观看| 亚洲精品免费播放| 一区二区三区电影在线播| 亚洲女与黑人做爰| 亚洲一区二区精品3399| 亚洲一区二区欧美激情| 日韩中文字幕1| 狂野欧美性猛交blacked| 久久国产精品99精品国产| 久久精品理论片| 国产麻豆精品久久一二三| 国产成人免费在线观看| 成人毛片视频在线观看| 99久久er热在这里只有精品66| 色哟哟一区二区| 欧美男女性生活在线直播观看| 91精品国产aⅴ一区二区| 日韩欧美一区二区不卡| 国产欧美精品一区| 亚洲与欧洲av电影| 免费成人在线视频观看| 国产剧情在线观看一区二区| 国产ts人妖一区二区| 欧美亚洲国产bt| ww亚洲ww在线观看国产| 国产精品热久久久久夜色精品三区| 亚洲激情图片小说视频| 蜜臀va亚洲va欧美va天堂| 国产成人亚洲精品青草天美| 日本韩国精品在线| 精品国产乱码久久久久久老虎 | 欧美videofree性高清杂交| 欧美电视剧免费观看| 国产女同互慰高潮91漫画| 夜夜精品视频一区二区| 精品中文字幕一区二区小辣椒| 成人午夜电影网站| 制服丝袜在线91| 国产精品免费aⅴ片在线观看| 性做久久久久久久免费看| 成人妖精视频yjsp地址| 欧美一二三四区在线| 亚洲精品乱码久久久久久黑人| 美脚の诱脚舐め脚责91| 欧美视频在线播放| 中文字幕在线不卡| 国产真实乱子伦精品视频| 欧美日韩成人在线| 亚洲视频每日更新| 国产夫妻精品视频| 精品国产乱子伦一区| 视频一区视频二区中文| 在线免费观看日韩欧美| 亚洲欧洲日产国产综合网| 韩国精品一区二区| 日韩免费高清电影| 视频一区二区国产| 欧美日韩午夜影院| 亚洲自拍偷拍av| 在线免费不卡视频| 亚洲日本中文字幕区| 国产凹凸在线观看一区二区| 久久青草欧美一区二区三区| 麻豆精品国产传媒mv男同| 欧美疯狂性受xxxxx喷水图片| 亚洲欧美综合另类在线卡通| 高清国产一区二区| 欧美激情一区二区| www.久久精品| 国产精品久久看| 成人高清视频在线观看| 国产精品久久久久久久久久久免费看 | 视频在线观看91| 欧美久久久一区| 日本成人超碰在线观看| 91精品免费观看| 久久精品国产一区二区三区免费看 | 亚洲欧美一区二区视频| 成人福利视频在线| 亚洲三级久久久| 91福利社在线观看| 亚洲主播在线观看| 制服丝袜日韩国产| 狠狠久久亚洲欧美| 国产精品欧美一区二区三区| 97久久超碰精品国产| 亚洲最大成人网4388xx| 欧美精品在线一区二区| 蜜臀av一级做a爰片久久| 亚洲精品在线电影| 99久久精品免费观看| 亚洲夂夂婷婷色拍ww47| 欧美成人乱码一区二区三区| 国产剧情一区二区| 亚洲欧美日韩精品久久久久| 欧美日韩国产免费一区二区 | 欧美精品电影在线播放| 激情综合一区二区三区| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 国内精品嫩模私拍在线| 国产精品天干天干在观线| 91蝌蚪porny| 午夜精品一区二区三区电影天堂| 日韩视频123| 99久久久久久99| 日韩av电影免费观看高清完整版 | 亚洲午夜免费电影| 日韩欧美的一区二区| av在线播放不卡| 水蜜桃久久夜色精品一区的特点| 国产三级三级三级精品8ⅰ区| 色悠悠久久综合| 国产成人综合网| 视频在线在亚洲| 中文字幕日韩欧美一区二区三区| 91麻豆精品国产综合久久久久久| 国产精品99久| 男男成人高潮片免费网站| 亚洲欧美视频在线观看视频| 日韩一级高清毛片| 欧美中文字幕一二三区视频| 激情综合网激情| 丝瓜av网站精品一区二区| 亚洲欧洲性图库| 久久久影视传媒| 精品视频一区三区九区| 97精品国产露脸对白| 韩国女主播一区| 青青草国产精品97视觉盛宴| 一区二区三区久久| 国产精品的网站| 中文在线资源观看网站视频免费不卡| 91精品国产福利在线观看| 欧美日韩一区二区三区高清| 99视频精品在线| 成人性视频免费网站| 国产一区二区看久久| 久久99久国产精品黄毛片色诱| 亚洲成在线观看| 亚洲午夜一区二区三区| 亚洲精品综合在线| 综合久久久久综合| 国产精品久久久久9999吃药| 国产午夜精品久久久久久久| 久久先锋影音av鲁色资源 | 国产电影一区在线| 韩国女主播成人在线观看| 精品系列免费在线观看| 日本不卡中文字幕| 免费高清成人在线| 极品少妇一区二区| 国产一区二区三区免费在线观看| 久久精品国产澳门| 国产精品综合视频| 风间由美一区二区三区在线观看| 精品综合免费视频观看| 国产成人av一区二区| 成人国产精品免费观看动漫| av中文一区二区三区| 色呦呦一区二区三区| 欧美大片在线观看一区二区| 亚洲欧洲日产国码二区| 久久久久国产一区二区三区四区 | 国产蜜臀97一区二区三区| 日韩欧美一区中文| 欧美大片在线观看一区二区| 久久综合久久综合九色| 久久精品视频免费| 成人欧美一区二区三区在线播放| 中文字幕一区在线观看视频| 亚洲国产精品嫩草影院| 秋霞午夜av一区二区三区| 国产精品自拍在线| 一本大道av伊人久久综合| 色一情一乱一乱一91av| 91精品国产91综合久久蜜臀| 国产欧美一区二区三区在线老狼| 中文字幕在线播放不卡一区| 亚洲国产精品久久久男人的天堂| 奇米一区二区三区| 成人av免费在线| 88在线观看91蜜桃国自产| 久久精品一区八戒影视| 亚洲精品国产无套在线观| 免费久久99精品国产| av毛片久久久久**hd| 欧美理论电影在线| 国产精品久久看| 日韩国产欧美在线播放| 成人av在线一区二区| 欧美日韩一区二区在线观看| 精品999在线播放| 亚洲综合免费观看高清在线观看| 国产在线不卡一区| 在线观看日韩国产| 中文在线一区二区| 韩国女主播一区|