home *** CD-ROM | disk | FTP | other *** search
/ OS/2 Shareware BBS: 10 Tools / 10-Tools.zip / newopg.zip / TEAPOT.C < prev    next >
Text File  |  1995-03-04  |  8KB  |  273 lines

  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <stdlib.h>
  4. #include "tk.h"
  5.  
  6.  
  7. GLenum rgb, doubleBuffer, directRender;
  8.  
  9. float rotX = 0.0, rotY = 0.0;
  10. int teaList;
  11.  
  12. long patchData[][16] = {
  13.     {102,103,104,105,4,5,6,7,8,9,10,11,12,13,14,15},
  14.     {12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27},
  15.     {24,25,26,27,29,30,31,32,33,34,35,36,37,38,39,40},
  16.     {96,96,96,96,97,98,99,100,101,101,101,101,0,1,2,3,},
  17.     {0,1,2,3,106,107,108,109,110,111,112,113,114,115,116,117},
  18.     {118,118,118,118,124,122,119,121,123,126,125,120,40,39,38,37},
  19.     {41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56},
  20.     {53,54,55,56,57,58,59,60,61,62,63,64,28,65,66,67},
  21.     {68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83},
  22.     {80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95}
  23. };
  24.  
  25. float cpData[][3] = {
  26.     {0.2,0,2.7},{0.2,-0.112,2.7},{0.112,-0.2,2.7},{0,-0.2,2.7},
  27.     {1.3375,0,2.53125},{1.3375,-0.749,2.53125},{0.749,-1.3375,2.53125},
  28.     {0,-1.3375,2.53125},{1.4375,0,2.53125},{1.4375,-0.805,2.53125},
  29.     {0.805,-1.4375,2.53125},{0,-1.4375,2.53125},{1.5,0,2.4},{1.5,-0.84,2.4},
  30.     {0.84,-1.5,2.4},{0,-1.5,2.4},{1.75,0,1.875},{1.75,-0.98,1.875},
  31.     {0.98,-1.75,1.875},{0,-1.75,1.875},{2,0,1.35},{2,-1.12,1.35},
  32.     {1.12,-2,1.35},{0,-2,1.35},{2,0,0.9},{2,-1.12,0.9},{1.12,-2,0.9},
  33.     {0,-2,0.9},{-2,0,0.9},{2,0,0.45},{2,-1.12,0.45},{1.12,-2,0.45},
  34.     {0,-2,0.45},{1.5,0,0.225},{1.5,-0.84,0.225},{0.84,-1.5,0.225},
  35.     {0,-1.5,0.225},{1.5,0,0.15},{1.5,-0.84,0.15},{0.84,-1.5,0.15},
  36.     {0,-1.5,0.15},{-1.6,0,2.025},{-1.6,-0.3,2.025},{-1.5,-0.3,2.25},
  37.     {-1.5,0,2.25},{-2.3,0,2.025},{-2.3,-0.3,2.025},{-2.5,-0.3,2.25},
  38.     {-2.5,0,2.25},{-2.7,0,2.025},{-2.7,-0.3,2.025},{-3,-0.3,2.25},
  39.     {-3,0,2.25},{-2.7,0,1.8},{-2.7,-0.3,1.8},{-3,-0.3,1.8},{-3,0,1.8},
  40.     {-2.7,0,1.575},{-2.7,-0.3,1.575},{-3,-0.3,1.35},{-3,0,1.35},
  41.     {-2.5,0,1.125},{-2.5,-0.3,1.125},{-2.65,-0.3,0.9375},{-2.65,0,0.9375},
  42.     {-2,-0.3,0.9},{-1.9,-0.3,0.6},{-1.9,0,0.6},{1.7,0,1.425},
  43.     {1.7,-0.66,1.425},{1.7,-0.66,0.6},{1.7,0,0.6},{2.6,0,1.425},
  44.     {2.6,-0.66,1.425},{3.1,-0.66,0.825},{3.1,0,0.825},{2.3,0,2.1},
  45.     {2.3,-0.25,2.1},{2.4,-0.25,2.025},{2.4,0,2.025},{2.7,0,2.4},
  46.     {2.7,-0.25,2.4},{3.3,-0.25,2.4},{3.3,0,2.4},{2.8,0,2.475},
  47.     {2.8,-0.25,2.475},{3.525,-0.25,2.49375},{3.525,0,2.49375},
  48.     {2.9,0,2.475},{2.9,-0.15,2.475},{3.45,-0.15,2.5125},{3.45,0,2.5125},
  49.     {2.8,0,2.4},{2.8,-0.15,2.4},{3.2,-0.15,2.4},{3.2,0,2.4},{0,0,3.15},
  50.     {0.8,0,3.15},{0.8,-0.45,3.15},{0.45,-0.8,3.15},{0,-0.8,3.15},
  51.     {0,0,2.85},{1.4,0,2.4},{1.4,-0.784,2.4},{0.784,-1.4,2.4},{0,-1.4,2.4},
  52.     {0.4,0,2.55},{0.4,-0.224,2.55},{0.224,-0.4,2.55},{0,-0.4,2.55},
  53.     {1.3,0,2.55},{1.3,-0.728,2.55},{0.728,-1.3,2.55},{0,-1.3,2.55},
  54.     {1.3,0,2.4},{1.3,-0.728,2.4},{0.728,-1.3,2.4},{0,-1.3,2.4},{0,0,0},
  55.     {1.425,-0.798,0},{1.5,0,0.075},{1.425,0,0},{0.798,-1.425,0},
  56.     {0,-1.5,0.075},{0,-1.425,0},{1.5,-0.84,0.075},{0.84,-1.5,0.075}
  57. };
  58.  
  59. float tex[2][2][2] = {
  60.     {
  61.     {0, 0},{1, 0}
  62.     },
  63.     {
  64.     {0, 1},{1, 1}
  65.     }
  66. };
  67.  
  68.  
  69. void Teapot(long grid)
  70. {
  71.     float p[4][4][3], q[4][4][3], r[4][4][3], s[4][4][3];
  72.     long i, j, k, l;
  73.  
  74.     teaList = 1;
  75.     glNewList(teaList, GL_COMPILE);
  76.     glPushMatrix();
  77.     glRotatef(270.0, 1.0, 0.0, 0.0);
  78.     for (i = 0; i < 10; i++) {
  79.     for (j = 0; j < 4; j++) {
  80.         for (k = 0; k < 4; k++) {
  81.         for (l = 0; l < 3; l++) {
  82.             p[j][k][l] = cpData[patchData[i][j*4+k]][l];
  83.             q[j][k][l] = cpData[patchData[i][j*4+(3-k)]][l];
  84.             if (l == 1) {
  85.             q[j][k][l] *= -1.0;
  86.             }
  87.             if (i < 6) {
  88.             r[j][k][l] = cpData[patchData[i][j*4+(3-k)]][l];
  89.             if (l == 0) {
  90.                 r[j][k][l] *= -1.0;
  91.             }
  92.             s[j][k][l] = cpData[patchData[i][j*4+k]][l];
  93.             if (l == 0) {
  94.                 s[j][k][l] *= -1.0;
  95.             }
  96.             if (l == 1) {
  97.                 s[j][k][l] *= -1.0;
  98.             }
  99.             }
  100.         }
  101.         }
  102.     }
  103.     glMap2f(GL_MAP2_TEXTURE_COORD_2, 0, 1, 2, 2, 0, 1, 4, 2, &tex[0][0][0]);
  104.     glMap2f(GL_MAP2_VERTEX_3, 0, 1, 3, 4, 0, 1, 12, 4, &p[0][0][0]);
  105.     glEnable(GL_MAP2_VERTEX_3);
  106.     glEnable(GL_MAP2_TEXTURE_COORD_2);
  107.     glMapGrid2f(grid, 0.0, 1.0, grid, 0.0, 1.0);
  108.     glEvalMesh2(GL_FILL, 0, grid, 0, grid);
  109.     glMap2f(GL_MAP2_VERTEX_3, 0, 1, 3, 4, 0, 1, 12, 4, &q[0][0][0]);
  110.     glEvalMesh2(GL_FILL, 0, grid, 0, grid);
  111.     if (i < 6) {
  112.         glMap2f(GL_MAP2_VERTEX_3, 0, 1, 3, 4, 0, 1, 12, 4, &r[0][0][0]);
  113.         glEvalMesh2(GL_FILL, 0, grid, 0, grid);
  114.         glMap2f(GL_MAP2_VERTEX_3, 0, 1, 3, 4, 0, 1, 12, 4, &s[0][0][0]);
  115.         glEvalMesh2(GL_FILL, 0, grid, 0, grid);
  116.     }
  117.     }
  118.     glDisable(GL_MAP2_VERTEX_3);
  119.     glDisable(GL_MAP2_TEXTURE_COORD_2);
  120.     glPopMatrix();
  121.     glEndList();
  122. }
  123.  
  124. static void Init(void)
  125. {
  126.     float position[] = {0.0, 3.0, 3.0, 0.0};
  127.     float local_view[] = {0.0};
  128.     float ambient[] = {0.1745, 0.01175, 0.01175};
  129.     float diffuse[] = {0.61424, 0.04136, 0.04136};
  130.     float specular[] = {0.727811, 0.626959, 0.626959};
  131.  
  132.     glEnable(GL_DEPTH_TEST);
  133.     glDepthFunc(GL_LESS);
  134.  
  135.     glLightfv(GL_LIGHT0, GL_POSITION, position);
  136.     glLightModelfv(GL_LIGHT_MODEL_LOCAL_VIEWER, local_view);
  137.  
  138.     glFrontFace(GL_CW);
  139.     glEnable(GL_LIGHTING);
  140.     glEnable(GL_LIGHT0);
  141.     glEnable(GL_AUTO_NORMAL);
  142.     glEnable(GL_NORMALIZE);
  143.  
  144.     glMaterialfv(GL_FRONT, GL_AMBIENT, ambient);
  145.     glMaterialfv(GL_FRONT, GL_DIFFUSE, diffuse);
  146.     glMaterialfv(GL_FRONT, GL_SPECULAR, specular);
  147.     glMaterialf(GL_FRONT, GL_SHININESS, 0.6*128.0);
  148.  
  149.     glClearColor(0.5, 0.5, 0.5, 1.0);
  150.     glColor3f(1.0, 1.0, 1.0);
  151.  
  152.     Teapot(14);
  153. }
  154.  
  155. static void Reshape(int w, int h)
  156. {
  157.  
  158.     glViewport(0, 0, (GLint)w, (GLint)h);
  159.  
  160.     glMatrixMode(GL_PROJECTION);
  161.     glLoadIdentity();
  162.     glOrtho(-6.0, 6.0, -6.0, 6.0, -1.0, 10.0);
  163.     glMatrixMode(GL_MODELVIEW);
  164.     glLoadIdentity();
  165. }
  166.  
  167. static GLenum Key(int key, GLenum mask)
  168. {
  169.  
  170.     switch (key) {
  171.       case TK_B:
  172.     tkClipBoard();
  173.     break;
  174.       case TK_ESCAPE:
  175.     tkQuit();
  176.       case TK_UP:
  177.     rotX -= 20.0;
  178.     break;
  179.       case TK_DOWN:
  180.     rotX += 20.0;
  181.     break;
  182.       case TK_LEFT:
  183.     rotY -= 20.0;
  184.     break;
  185.       case TK_RIGHT:
  186.     rotY += 20.0;
  187.     break;
  188.       default:
  189.     return GL_FALSE;
  190.     }
  191.     return GL_TRUE;
  192. }
  193.  
  194. static void Draw(void)
  195. {
  196.  
  197.     glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT);
  198.  
  199.     glPushMatrix();
  200.  
  201.     glTranslatef(0.0, 0.0, -5.0);
  202.     glRotatef(rotY, 0.0,1.0,0.0);
  203.     glRotatef(rotX, 1.0,0.0,0.0);
  204.  
  205.     glCallList(teaList);
  206.  
  207.     glPopMatrix();
  208.  
  209.     glFlush();
  210.  
  211.     if (doubleBuffer) {
  212.     tkSwapBuffers();
  213.     }
  214. }
  215.  
  216. static GLenum Args(int argc, char **argv)
  217. {
  218.     GLint i;
  219.  
  220.     rgb = GL_TRUE;
  221.     doubleBuffer = GL_FALSE;
  222.     directRender = GL_TRUE;
  223.  
  224.     for (i = 1; i < argc; i++) {
  225.     if (strcmp(argv[i], "-ci") == 0) {
  226.         rgb = GL_FALSE;
  227.     } else if (strcmp(argv[i], "-rgb") == 0) {
  228.         rgb = GL_TRUE;
  229.     } else if (strcmp(argv[i], "-sb") == 0) {
  230.         doubleBuffer = GL_FALSE;
  231.     } else if (strcmp(argv[i], "-db") == 0) {
  232.         doubleBuffer = GL_TRUE;
  233.     } else if (strcmp(argv[i], "-dr") == 0) {
  234.         directRender = GL_TRUE;
  235.     } else if (strcmp(argv[i], "-ir") == 0) {
  236.         directRender = GL_FALSE;
  237.     } else {
  238.         printf("%s (Bad option).\n", argv[i]);
  239.         return GL_FALSE;
  240.     }
  241.     }
  242.     return GL_TRUE;
  243. }
  244.  
  245. void main(int argc, char **argv)
  246. {
  247.     GLenum type;
  248.  
  249.     if (Args(argc, argv) == GL_FALSE) {
  250.     tkQuit();
  251.     }
  252.  
  253.     tkInitPosition(0, 0, 300, 300);
  254.  
  255.     type = TK_DEPTH;
  256.     type |= (rgb) ? TK_RGB : TK_INDEX;
  257.     type |= (doubleBuffer) ? TK_DOUBLE : TK_SINGLE;
  258.     type |= (directRender) ? TK_DIRECT : TK_INDIRECT;
  259.     tkInitDisplayMode(type);
  260.  
  261.     if (tkInitWindow("TeaPot") == GL_FALSE) {
  262.     tkQuit();
  263.     }
  264.  
  265.     Init();
  266.  
  267.     tkExposeFunc(Reshape);
  268.     tkReshapeFunc(Reshape);
  269.     tkKeyDownFunc(Key);
  270.     tkDisplayFunc(Draw);
  271.     tkExec();
  272. }
  273.