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