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