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.

quad-tex-pbo.c 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183
  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 <GL/glew.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. static GLuint DrawPBO;
  33. static void Init(void)
  34. {
  35. fprintf(stderr, "GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER));
  36. fprintf(stderr, "GL_VERSION = %s\n", (char *) glGetString(GL_VERSION));
  37. fprintf(stderr, "GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR));
  38. glClearColor(0.0, 0.0, 1.0, 0.0);
  39. #define SIZE 16
  40. {
  41. GLubyte tex2d[SIZE][SIZE][4];
  42. GLint s, t;
  43. for (s = 0; s < SIZE; s++) {
  44. for (t = 0; t < SIZE; t++) {
  45. /* bgra:
  46. */
  47. tex2d[t][s][0] = 0x30;
  48. tex2d[t][s][1] = t*255/(SIZE-1);
  49. tex2d[t][s][2] = s*255/(SIZE-1);
  50. tex2d[t][s][3] = 0xff;
  51. }
  52. }
  53. /* put image into DrawPBO */
  54. glGenBuffersARB(1, &DrawPBO);
  55. glBindBufferARB(GL_PIXEL_PACK_BUFFER_EXT, DrawPBO);
  56. glBufferDataARB(GL_PIXEL_PACK_BUFFER_EXT,
  57. SIZE * SIZE * 4, tex2d, GL_STATIC_DRAW);
  58. glBindBufferARB(GL_PIXEL_PACK_BUFFER_EXT, 0);
  59. glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
  60. glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_WRAP_R, GL_REPEAT);
  61. glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_NEAREST);
  62. glTexParameterf(GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST);
  63. glPixelStorei(GL_UNPACK_ALIGNMENT, 1);
  64. glBindBufferARB(GL_PIXEL_UNPACK_BUFFER_EXT, DrawPBO);
  65. glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, SIZE, SIZE, 0,
  66. GL_BGRA, GL_UNSIGNED_BYTE, NULL);
  67. glBindBufferARB(GL_PIXEL_UNPACK_BUFFER_EXT, 0);
  68. glPixelStorei(GL_UNPACK_ALIGNMENT, 4);
  69. glEnable(GL_TEXTURE_2D);
  70. }
  71. }
  72. static void Reshape(int width, int height)
  73. {
  74. glViewport(0, 0, (GLint)width, (GLint)height);
  75. glMatrixMode(GL_PROJECTION);
  76. glLoadIdentity();
  77. glOrtho(-1.0, 1.0, -1.0, 1.0, -0.5, 1000.0);
  78. glMatrixMode(GL_MODELVIEW);
  79. }
  80. static void Key(unsigned char key, int x, int y)
  81. {
  82. switch (key) {
  83. case 27:
  84. exit(1);
  85. default:
  86. return;
  87. }
  88. glutPostRedisplay();
  89. }
  90. static void Draw(void)
  91. {
  92. glClear(GL_COLOR_BUFFER_BIT);
  93. glBegin(GL_QUADS);
  94. glTexCoord2f(1,0);
  95. glVertex3f( 0.9, -0.9, -30.0);
  96. glTexCoord2f(1,1);
  97. glVertex3f( 0.9, 0.9, -30.0);
  98. glTexCoord2f(0,1);
  99. glVertex3f(-0.9, 0.9, -30.0);
  100. glTexCoord2f(0,0);
  101. glVertex3f(-0.9, -0.9, -30.0);
  102. glEnd();
  103. glFlush();
  104. if (doubleBuffer) {
  105. glutSwapBuffers();
  106. }
  107. }
  108. static GLenum Args(int argc, char **argv)
  109. {
  110. GLint i;
  111. doubleBuffer = GL_FALSE;
  112. for (i = 1; i < argc; i++) {
  113. if (strcmp(argv[i], "-sb") == 0) {
  114. doubleBuffer = GL_FALSE;
  115. } else if (strcmp(argv[i], "-db") == 0) {
  116. doubleBuffer = GL_TRUE;
  117. } else {
  118. fprintf(stderr, "%s (Bad option).\n", argv[i]);
  119. return GL_FALSE;
  120. }
  121. }
  122. return GL_TRUE;
  123. }
  124. int main(int argc, char **argv)
  125. {
  126. GLenum type;
  127. glutInit(&argc, argv);
  128. if (Args(argc, argv) == GL_FALSE) {
  129. exit(1);
  130. }
  131. glutInitWindowPosition(0, 0); glutInitWindowSize( 250, 250);
  132. type = GLUT_RGB;
  133. type |= (doubleBuffer) ? GLUT_DOUBLE : GLUT_SINGLE;
  134. glutInitDisplayMode(type);
  135. if (glutCreateWindow("First Tri") == GL_FALSE) {
  136. exit(1);
  137. }
  138. glewInit();
  139. Init();
  140. glutReshapeFunc(Reshape);
  141. glutKeyboardFunc(Key);
  142. glutDisplayFunc(Draw);
  143. glutMainLoop();
  144. return 0;
  145. }