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 <GL/glew.h>
2632001f49Smrg#include <math.h>
2732001f49Smrg#include <stdio.h>
2832001f49Smrg#include <string.h>
2932001f49Smrg#include <stdlib.h>
3032001f49Smrg#include "glut_wrap.h"
3132001f49Smrg
3232001f49Smrg
3332001f49Smrg
3432001f49SmrgGLenum doubleBuffer;
3532001f49Smrg
3632001f49Smrgstatic void Init(void)
3732001f49Smrg{
3832001f49Smrg   fprintf(stderr, "GL_RENDERER   = %s\n", (char *) glGetString(GL_RENDERER));
3932001f49Smrg   fprintf(stderr, "GL_VERSION    = %s\n", (char *) glGetString(GL_VERSION));
4032001f49Smrg   fprintf(stderr, "GL_VENDOR     = %s\n", (char *) glGetString(GL_VENDOR));
4132001f49Smrg   fflush(stderr);
4232001f49Smrg
4332001f49Smrg   glClearColor(0.0, 0.0, 1.0, 0.0);
4432001f49Smrg}
4532001f49Smrg
4632001f49Smrgstatic void Reshape(int width, int height)
4732001f49Smrg{
4832001f49Smrg    glViewport(0, 0, (GLint)width, (GLint)height);
4932001f49Smrg
5032001f49Smrg    glMatrixMode(GL_PROJECTION);
5132001f49Smrg    glLoadIdentity();
5232001f49Smrg    glOrtho(-1.0, 1.0, -1.0, 1.0, 0, 100.0);
5332001f49Smrg    glMatrixMode(GL_MODELVIEW);
5432001f49Smrg}
5532001f49Smrg
5632001f49Smrgstatic void Key(unsigned char key, int x, int y)
5732001f49Smrg{
5832001f49Smrg    switch (key) {
5932001f49Smrg    case 27:
6032001f49Smrg	exit(1);
6132001f49Smrg    default:
6232001f49Smrg	break;
6332001f49Smrg    }
6432001f49Smrg    glutPostRedisplay();
6532001f49Smrg}
6632001f49Smrg
6732001f49Smrg
6832001f49Smrgstatic float
6932001f49Smrgexpected(float z, float size, const float atten[3])
7032001f49Smrg{
7132001f49Smrg   float dist = fabs(z);
7232001f49Smrg   const GLfloat q = atten[0] + dist * (atten[1] + dist * atten[2]);
7332001f49Smrg   const GLfloat a = sqrt(1.0 / q);
7432001f49Smrg   return size * a;
7532001f49Smrg}
7632001f49Smrg
7732001f49Smrg
7832001f49Smrgstatic void Draw(void)
7932001f49Smrg{
8032001f49Smrg   static GLfloat atten[3] = { 0.0, 0.1, .01 };
8132001f49Smrg   float size = 40.0;
8232001f49Smrg   int i;
8332001f49Smrg
8432001f49Smrg   glClear(GL_COLOR_BUFFER_BIT);
8532001f49Smrg
8632001f49Smrg   glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
8732001f49Smrg   glPointSize(size);
8832001f49Smrg   glPointParameterfvARB(GL_POINT_DISTANCE_ATTENUATION_ARB, atten);
8932001f49Smrg
9032001f49Smrg   glColor3f(1,0,0);
9132001f49Smrg
9232001f49Smrg   printf("Expected point sizes:\n");
9332001f49Smrg   glBegin(GL_POINTS);
9432001f49Smrg   for (i = 0; i < 5; i++) {
9532001f49Smrg      float x = -0.8 + i * 0.4;
9632001f49Smrg      float z = -i * 20 - 10;
9732001f49Smrg      glVertex3f( x, 0.0, z);
9832001f49Smrg      printf(" %f\n", expected(z, size, atten));
9932001f49Smrg   }
10032001f49Smrg   glEnd();
10132001f49Smrg
10232001f49Smrg   glFlush();
10332001f49Smrg
10432001f49Smrg   if (doubleBuffer) {
10532001f49Smrg      glutSwapBuffers();
10632001f49Smrg   }
10732001f49Smrg}
10832001f49Smrg
10932001f49Smrg
11032001f49Smrgstatic GLenum Args(int argc, char **argv)
11132001f49Smrg{
11232001f49Smrg    GLint i;
11332001f49Smrg
11432001f49Smrg    doubleBuffer = GL_FALSE;
11532001f49Smrg
11632001f49Smrg    for (i = 1; i < argc; i++) {
11732001f49Smrg        if (strcmp(argv[i], "-sb") == 0) {
11832001f49Smrg	    doubleBuffer = GL_FALSE;
11932001f49Smrg	} else if (strcmp(argv[i], "-db") == 0) {
12032001f49Smrg	    doubleBuffer = GL_TRUE;
12132001f49Smrg	} else {
12232001f49Smrg	    fprintf(stderr, "%s (Bad option).\n", argv[i]);
12332001f49Smrg	    return GL_FALSE;
12432001f49Smrg	}
12532001f49Smrg    }
12632001f49Smrg    return GL_TRUE;
12732001f49Smrg}
12832001f49Smrg
12932001f49Smrg
13032001f49Smrgint main(int argc, char **argv)
13132001f49Smrg{
13232001f49Smrg    GLenum type;
13332001f49Smrg
13432001f49Smrg    glutInit(&argc, argv);
13532001f49Smrg
13632001f49Smrg    if (Args(argc, argv) == GL_FALSE) {
13732001f49Smrg	exit(1);
13832001f49Smrg    }
13932001f49Smrg
14032001f49Smrg    glutInitWindowPosition(0, 0); glutInitWindowSize( 250, 250);
14132001f49Smrg
14232001f49Smrg    type = GLUT_RGB | GLUT_ALPHA;
14332001f49Smrg    type |= (doubleBuffer) ? GLUT_DOUBLE : GLUT_SINGLE;
14432001f49Smrg    glutInitDisplayMode(type);
14532001f49Smrg
14632001f49Smrg    if (glutCreateWindow(argv[0]) == GL_FALSE) {
14732001f49Smrg	exit(1);
14832001f49Smrg    }
14932001f49Smrg
15032001f49Smrg    glewInit();
15132001f49Smrg
15232001f49Smrg    Init();
15332001f49Smrg
15432001f49Smrg    glutReshapeFunc(Reshape);
15532001f49Smrg    glutKeyboardFunc(Key);
15632001f49Smrg    glutDisplayFunc(Draw);
15732001f49Smrg    glutMainLoop();
15832001f49Smrg    return 0;
15932001f49Smrg}
160