132001f49Smrg/* 232001f49Smrg * Copyright (c) 1991, 1992, 1993 Silicon Graphics, Inc. 332001f49Smrg * 432001f49Smrg * Permission to use, copy, modify, distribute, and sell this software and 532001f49Smrg * its documentation for any purpose is hereby granted without fee, provided 632001f49Smrg * that (i) the above copyright notices and this permission notice appear in 732001f49Smrg * all copies of the software and related documentation, and (ii) the name of 832001f49Smrg * Silicon Graphics may not be used in any advertising or 932001f49Smrg * publicity relating to the software without the specific, prior written 1032001f49Smrg * permission of Silicon Graphics. 1132001f49Smrg * 1232001f49Smrg * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF 1332001f49Smrg * ANY KIND, 1432001f49Smrg * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY 1532001f49Smrg * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. 1632001f49Smrg * 1732001f49Smrg * IN NO EVENT SHALL SILICON GRAPHICS BE LIABLE FOR 1832001f49Smrg * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, 1932001f49Smrg * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, 2032001f49Smrg * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF 2132001f49Smrg * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE 2232001f49Smrg * OF THIS SOFTWARE. 2332001f49Smrg */ 2432001f49Smrg 2532001f49Smrg#include <stdio.h> 2632001f49Smrg#include <string.h> 2732001f49Smrg#include <stdlib.h> 2832001f49Smrg#include <GL/glew.h> 2932001f49Smrg#include "glut_wrap.h" 3032001f49Smrg 3132001f49Smrg 3232001f49Smrg 3332001f49Smrg#define CI_OFFSET_1 16 3432001f49Smrg#define CI_OFFSET_2 32 3532001f49Smrg 3632001f49Smrgstatic GLuint OccQuery; 3732001f49Smrg 3832001f49SmrgGLenum doubleBuffer; 3932001f49Smrg 4032001f49Smrgstatic void Init(void) 4132001f49Smrg{ 4232001f49Smrg if (!glutExtensionSupported("GL_ARB_occlusion_query")) { 4332001f49Smrg fprintf(stderr, "Sorry, this program requires GL_ARB_occlusion_query\n"); 4432001f49Smrg exit(1); 4532001f49Smrg } 4632001f49Smrg 4732001f49Smrg fprintf(stderr, "GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER)); 4832001f49Smrg fprintf(stderr, "GL_VERSION = %s\n", (char *) glGetString(GL_VERSION)); 4932001f49Smrg fprintf(stderr, "GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR)); 5032001f49Smrg fflush(stderr); 5132001f49Smrg 5232001f49Smrg glClearColor(0.0, 0.0, 1.0, 0.0); 5332001f49Smrg 5432001f49Smrg glGenQueriesARB(1, &OccQuery); 5532001f49Smrg} 5632001f49Smrg 5732001f49Smrgstatic void Reshape(int width, int height) 5832001f49Smrg{ 5932001f49Smrg 6032001f49Smrg glViewport(0, 0, (GLint)width, (GLint)height); 6132001f49Smrg 6232001f49Smrg glMatrixMode(GL_PROJECTION); 6332001f49Smrg glLoadIdentity(); 6432001f49Smrg glOrtho(-1.0, 1.0, -1.0, 1.0, -0.5, 1000.0); 6532001f49Smrg glMatrixMode(GL_MODELVIEW); 6632001f49Smrg} 6732001f49Smrg 6832001f49Smrgstatic void Key(unsigned char key, int x, int y) 6932001f49Smrg{ 7032001f49Smrg 7132001f49Smrg switch (key) { 7232001f49Smrg case 27: 7332001f49Smrg exit(1); 7432001f49Smrg default: 7532001f49Smrg break; 7632001f49Smrg } 7732001f49Smrg 7832001f49Smrg glutPostRedisplay(); 7932001f49Smrg} 8032001f49Smrg 8132001f49Smrgstatic void Draw(void) 8232001f49Smrg{ 8332001f49Smrg GLuint passed; 8432001f49Smrg GLint ready; 8532001f49Smrg 8632001f49Smrg glClear(GL_COLOR_BUFFER_BIT|GL_DEPTH_BUFFER_BIT); 8732001f49Smrg 8832001f49Smrg glEnable(GL_DEPTH_TEST); 8932001f49Smrg 9032001f49Smrg glBeginQueryARB(GL_SAMPLES_PASSED_ARB, OccQuery); 9132001f49Smrg 9232001f49Smrg glBegin(GL_TRIANGLES); 9332001f49Smrg glColor3f(0,0,.7); 9432001f49Smrg glVertex3f( 0.9, -0.9, -30.0); 9532001f49Smrg glColor3f(.8,0,0); 9632001f49Smrg glVertex3f( 0.9, 0.9, -30.0); 9732001f49Smrg glColor3f(0,.9,0); 9832001f49Smrg glVertex3f(-0.9, 0.0, -30.0); 9932001f49Smrg glEnd(); 10032001f49Smrg 10132001f49Smrg glEndQueryARB(GL_SAMPLES_PASSED_ARB); 10232001f49Smrg 10332001f49Smrg do { 10432001f49Smrg /* do useful work here, if any */ 10532001f49Smrg glGetQueryObjectivARB(OccQuery, GL_QUERY_RESULT_AVAILABLE_ARB, &ready); 10632001f49Smrg } while (!ready); 10732001f49Smrg glGetQueryObjectuivARB(OccQuery, GL_QUERY_RESULT_ARB, &passed); 10832001f49Smrg 10932001f49Smrg fprintf(stderr, " %d Fragments Visible\n", passed); 11032001f49Smrg 11132001f49Smrg glFlush(); 11232001f49Smrg 11332001f49Smrg if (doubleBuffer) { 11432001f49Smrg glutSwapBuffers(); 11532001f49Smrg } 11632001f49Smrg} 11732001f49Smrg 11832001f49Smrgstatic GLenum Args(int argc, char **argv) 11932001f49Smrg{ 12032001f49Smrg GLint i; 12132001f49Smrg 12232001f49Smrg doubleBuffer = GL_FALSE; 12332001f49Smrg 12432001f49Smrg for (i = 1; i < argc; i++) { 12532001f49Smrg if (strcmp(argv[i], "-sb") == 0) { 12632001f49Smrg doubleBuffer = GL_FALSE; 12732001f49Smrg } else if (strcmp(argv[i], "-db") == 0) { 12832001f49Smrg doubleBuffer = GL_TRUE; 12932001f49Smrg } else { 13032001f49Smrg fprintf(stderr, "%s (Bad option).\n", argv[i]); 13132001f49Smrg return GL_FALSE; 13232001f49Smrg } 13332001f49Smrg } 13432001f49Smrg return GL_TRUE; 13532001f49Smrg} 13632001f49Smrg 13732001f49Smrgint main(int argc, char **argv) 13832001f49Smrg{ 13932001f49Smrg GLenum type; 14032001f49Smrg 14132001f49Smrg glutInit(&argc, argv); 14232001f49Smrg 14332001f49Smrg if (Args(argc, argv) == GL_FALSE) { 14432001f49Smrg exit(1); 14532001f49Smrg } 14632001f49Smrg 14732001f49Smrg glutInitWindowPosition(100, 0); glutInitWindowSize( 250, 250); 14832001f49Smrg 14932001f49Smrg type = GLUT_RGB | GLUT_DEPTH; 15032001f49Smrg type |= (doubleBuffer) ? GLUT_DOUBLE : GLUT_SINGLE; 15132001f49Smrg glutInitDisplayMode(type); 15232001f49Smrg 15332001f49Smrg if (glutCreateWindow(*argv) == GL_FALSE) { 15432001f49Smrg exit(1); 15532001f49Smrg } 15632001f49Smrg 15732001f49Smrg glewInit(); 15832001f49Smrg 15932001f49Smrg Init(); 16032001f49Smrg 16132001f49Smrg glutReshapeFunc(Reshape); 16232001f49Smrg glutKeyboardFunc(Key); 16332001f49Smrg glutDisplayFunc(Draw); 16432001f49Smrg glutMainLoop(); 16532001f49Smrg return 0; 16632001f49Smrg} 167