Clone of mesa.
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

tri-unfilled-tri-lit.c 4.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. /*
  2. * Copyright (c) 1991, 1992, 1993 Silicon Graphics, Inc.
  3. *
  4. * Permission to use, copy, modify, distribute, and sell this software and
  5. * its documentation for any purpose is hereby granted without fee, provided
  6. * that (i) the above copyright notices and this permission notice appear in
  7. * all copies of the software and related documentation, and (ii) the name of
  8. * Silicon Graphics may not be used in any advertising or
  9. * publicity relating to the software without the specific, prior written
  10. * permission of Silicon Graphics.
  11. *
  12. * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF
  13. * ANY KIND,
  14. * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
  15. * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
  16. *
  17. * IN NO EVENT SHALL SILICON GRAPHICS BE LIABLE FOR
  18. * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND,
  19. * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
  20. * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF
  21. * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE
  22. * OF THIS SOFTWARE.
  23. */
  24. #include <stdio.h>
  25. #include <string.h>
  26. #include <stdlib.h>
  27. #include <GL/glut.h>
  28. #define CI_OFFSET_1 16
  29. #define CI_OFFSET_2 32
  30. GLenum doubleBuffer;
  31. static void Init(void)
  32. {
  33. fprintf(stderr, "GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER));
  34. fprintf(stderr, "GL_VERSION = %s\n", (char *) glGetString(GL_VERSION));
  35. fprintf(stderr, "GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR));
  36. fflush(stderr);
  37. glEnable(GL_LIGHTING);
  38. glEnable(GL_LIGHT0);
  39. glClearColor(0.0, 0.0, 1.0, 0.0);
  40. }
  41. static void Reshape(int width, int height)
  42. {
  43. glViewport(0, 0, (GLint)width, (GLint)height);
  44. glMatrixMode(GL_PROJECTION);
  45. glLoadIdentity();
  46. /* glOrtho(-1.0, 1.0, -1.0, 1.0, -0.5, 1000.0); */
  47. glMatrixMode(GL_MODELVIEW);
  48. }
  49. static void Key(unsigned char key, int x, int y)
  50. {
  51. switch (key) {
  52. case 27:
  53. exit(1);
  54. default:
  55. return;
  56. }
  57. glutPostRedisplay();
  58. }
  59. static void Draw(void)
  60. {
  61. glClear(GL_COLOR_BUFFER_BIT);
  62. glPolygonMode(GL_FRONT, GL_LINE);
  63. glPolygonMode(GL_BACK, GL_LINE);
  64. glBegin(GL_TRIANGLES);
  65. glNormal3f(0,0,.7);
  66. glVertex3f( 0.9, -0.9, -0.0);
  67. glNormal3f(.8,0,0);
  68. glVertex3f( 0.9, 0.9, -0.0);
  69. glNormal3f(0,.9,0);
  70. glVertex3f(-0.9, 0.0, -0.0);
  71. glEnd();
  72. glPolygonMode(GL_FRONT, GL_FILL);
  73. glPolygonMode(GL_BACK, GL_FILL);
  74. glBegin(GL_TRIANGLES);
  75. glNormal3f(0,0,.7);
  76. glVertex3f( 0.8, -0.8, -0.0);
  77. glNormal3f(.8,0,0);
  78. glVertex3f( 0.8, 0.8, -0.0);
  79. glNormal3f(0,.9,0);
  80. glVertex3f(-0.8, 0.0, -0.0);
  81. glEnd();
  82. glPolygonMode(GL_FRONT, GL_LINE);
  83. glPolygonMode(GL_BACK, GL_LINE);
  84. glBegin(GL_TRIANGLES);
  85. glNormal3f(.8,0,0);
  86. glVertex3f( -0.9, 0.9, -0.0);
  87. glNormal3f(0,0,.7);
  88. glVertex3f( -0.9, -0.9, -0.0);
  89. glNormal3f(0,.9,0);
  90. glVertex3f( 0.9, 0.0, -0.0);
  91. glEnd();
  92. glPolygonMode(GL_FRONT, GL_FILL);
  93. glPolygonMode(GL_BACK, GL_FILL);
  94. glBegin(GL_TRIANGLES);
  95. glNormal3f(.8,0,0);
  96. glVertex3f( -0.8, 0.8, -0.0);
  97. glNormal3f(0,0,.7);
  98. glVertex3f( -0.8, -0.8, -0.0);
  99. glNormal3f(0,.9,0);
  100. glVertex3f( 0.8, 0.0, -0.0);
  101. glEnd();
  102. glFlush();
  103. if (doubleBuffer) {
  104. glutSwapBuffers();
  105. }
  106. }
  107. static GLenum Args(int argc, char **argv)
  108. {
  109. GLint i;
  110. doubleBuffer = GL_FALSE;
  111. for (i = 1; i < argc; i++) {
  112. if (strcmp(argv[i], "-sb") == 0) {
  113. doubleBuffer = GL_FALSE;
  114. } else if (strcmp(argv[i], "-db") == 0) {
  115. doubleBuffer = GL_TRUE;
  116. } else {
  117. fprintf(stderr, "%s (Bad option).\n", argv[i]);
  118. return GL_FALSE;
  119. }
  120. }
  121. return GL_TRUE;
  122. }
  123. int main(int argc, char **argv)
  124. {
  125. GLenum type;
  126. glutInit(&argc, argv);
  127. if (Args(argc, argv) == GL_FALSE) {
  128. exit(1);
  129. }
  130. glutInitWindowPosition(0, 0); glutInitWindowSize( 250, 250);
  131. type = GLUT_RGB | GLUT_ALPHA;
  132. type |= (doubleBuffer) ? GLUT_DOUBLE : GLUT_SINGLE;
  133. glutInitDisplayMode(type);
  134. if (glutCreateWindow(*argv) == GL_FALSE) {
  135. exit(1);
  136. }
  137. Init();
  138. glutReshapeFunc(Reshape);
  139. glutKeyboardFunc(Key);
  140. glutDisplayFunc(Draw);
  141. glutMainLoop();
  142. return 0;
  143. }