Clone of mesa.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

line-smooth.c 4.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  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 <math.h>
  25. #include <stdio.h>
  26. #include <string.h>
  27. #include <stdlib.h>
  28. #include <GL/glut.h>
  29. #define CI_OFFSET_1 16
  30. #define CI_OFFSET_2 32
  31. GLenum doubleBuffer;
  32. GLboolean smooth = GL_TRUE;
  33. GLfloat width = 1.0;
  34. static void Init(void)
  35. {
  36. float range[2], aarange[2];
  37. fprintf(stderr, "GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER));
  38. fprintf(stderr, "GL_VERSION = %s\n", (char *) glGetString(GL_VERSION));
  39. fprintf(stderr, "GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR));
  40. fflush(stderr);
  41. glGetFloatv(GL_LINE_WIDTH_RANGE, aarange);
  42. glGetFloatv(GL_ALIASED_LINE_WIDTH_RANGE, range);
  43. printf("Non-AA line width range: %f .. %f\n", range[0], range[1]);
  44. printf("AA line width range: %f .. %f\n", aarange[0], aarange[1]);
  45. fflush(stdout);
  46. }
  47. static void Reshape(int width, int height)
  48. {
  49. glViewport(0, 0, (GLint)width, (GLint)height);
  50. glMatrixMode(GL_PROJECTION);
  51. glLoadIdentity();
  52. glOrtho(-1.0, 1.0, -1.0, 1.0, -0.5, 1000.0);
  53. glMatrixMode(GL_MODELVIEW);
  54. glLoadIdentity();
  55. glTranslatef(0, 0, -30);
  56. }
  57. static void Key(unsigned char key, int x, int y)
  58. {
  59. switch (key) {
  60. case 'w':
  61. width -= 0.5;
  62. if (width < 0.5)
  63. width = 0.5;
  64. break;
  65. case 'W':
  66. width += 0.5;
  67. break;
  68. case 's':
  69. smooth = !smooth;
  70. break;
  71. case 27:
  72. exit(1);
  73. default:
  74. return;
  75. }
  76. printf("LineWidth: %g\n", width);
  77. glutPostRedisplay();
  78. }
  79. static void Draw(void)
  80. {
  81. float a;
  82. glClear(GL_COLOR_BUFFER_BIT);
  83. glLineWidth(width);
  84. if (smooth) {
  85. glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
  86. glEnable(GL_BLEND);
  87. glEnable(GL_LINE_SMOOTH);
  88. }
  89. glColor3f(1, 1, 1);
  90. glBegin(GL_LINES);
  91. for (a = 0; a < 3.14159; a += 0.2) {
  92. float x = .9 * cos(a);
  93. float y = .9 * sin(a);
  94. glVertex2f(-x, -y);
  95. glVertex2f( x, y);
  96. }
  97. glEnd();
  98. glDisable(GL_LINE_SMOOTH);
  99. glDisable(GL_BLEND);
  100. glFlush();
  101. if (doubleBuffer) {
  102. glutSwapBuffers();
  103. }
  104. }
  105. static GLenum Args(int argc, char **argv)
  106. {
  107. GLint i;
  108. doubleBuffer = GL_FALSE;
  109. for (i = 1; i < argc; i++) {
  110. if (strcmp(argv[i], "-sb") == 0) {
  111. doubleBuffer = GL_FALSE;
  112. } else if (strcmp(argv[i], "-db") == 0) {
  113. doubleBuffer = GL_TRUE;
  114. } else {
  115. fprintf(stderr, "%s (Bad option).\n", argv[i]);
  116. return GL_FALSE;
  117. }
  118. }
  119. return GL_TRUE;
  120. }
  121. int main(int argc, char **argv)
  122. {
  123. GLenum type;
  124. glutInit(&argc, argv);
  125. if (Args(argc, argv) == GL_FALSE) {
  126. exit(1);
  127. }
  128. glutInitWindowPosition(0, 0); glutInitWindowSize( 250, 250);
  129. type = GLUT_RGB;
  130. type |= (doubleBuffer) ? GLUT_DOUBLE : GLUT_SINGLE;
  131. glutInitDisplayMode(type);
  132. if (glutCreateWindow(argv[0]) == GL_FALSE) {
  133. exit(1);
  134. }
  135. Init();
  136. glutReshapeFunc(Reshape);
  137. glutKeyboardFunc(Key);
  138. glutDisplayFunc(Draw);
  139. glutMainLoop();
  140. return 0;
  141. }