2 * Copyright (c) 1991, 1992, 1993 Silicon Graphics, Inc.
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.
12 * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF
14 * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY
15 * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
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
36 static void Init(void)
38 fprintf(stderr
, "GL_RENDERER = %s\n", (char *) glGetString(GL_RENDERER
));
39 fprintf(stderr
, "GL_VERSION = %s\n", (char *) glGetString(GL_VERSION
));
40 fprintf(stderr
, "GL_VENDOR = %s\n", (char *) glGetString(GL_VENDOR
));
43 glClearColor(0.0, 0.0, 1.0, 0.0);
46 static void Reshape(int width
, int height
)
48 glViewport(0, 0, (GLint
)width
, (GLint
)height
);
50 glMatrixMode(GL_PROJECTION
);
52 glOrtho(-1.0, 1.0, -1.0, 1.0, 0, 100.0);
53 glMatrixMode(GL_MODELVIEW
);
56 static void Key(unsigned char key
, int x
, int y
)
69 expected(float z
, float size
, const float atten
[3])
72 const GLfloat q
= atten
[0] + dist
* (atten
[1] + dist
* atten
[2]);
73 const GLfloat a
= sqrt(1.0 / q
);
78 static void Draw(void)
80 static GLfloat atten
[3] = { 0.0, 0.1, .01 };
84 glClear(GL_COLOR_BUFFER_BIT
);
86 glBlendFunc(GL_SRC_ALPHA
, GL_ONE_MINUS_SRC_ALPHA
);
88 glPointParameterfvARB(GL_POINT_DISTANCE_ATTENUATION_ARB
, atten
);
92 printf("Expected point sizes:\n");
94 for (i
= 0; i
< 5; i
++) {
95 float x
= -0.8 + i
* 0.4;
96 float z
= -i
* 20 - 10;
97 glVertex3f( x
, 0.0, z
);
98 printf(" %f\n", expected(z
, size
, atten
));
110 static GLenum
Args(int argc
, char **argv
)
114 doubleBuffer
= GL_FALSE
;
116 for (i
= 1; i
< argc
; i
++) {
117 if (strcmp(argv
[i
], "-sb") == 0) {
118 doubleBuffer
= GL_FALSE
;
119 } else if (strcmp(argv
[i
], "-db") == 0) {
120 doubleBuffer
= GL_TRUE
;
122 fprintf(stderr
, "%s (Bad option).\n", argv
[i
]);
130 int main(int argc
, char **argv
)
134 glutInit(&argc
, argv
);
136 if (Args(argc
, argv
) == GL_FALSE
) {
140 glutInitWindowPosition(0, 0); glutInitWindowSize( 250, 250);
142 type
= GLUT_RGB
| GLUT_ALPHA
;
143 type
|= (doubleBuffer
) ? GLUT_DOUBLE
: GLUT_SINGLE
;
144 glutInitDisplayMode(type
);
146 if (glutCreateWindow(argv
[0]) == GL_FALSE
) {
154 glutReshapeFunc(Reshape
);
155 glutKeyboardFunc(Key
);
156 glutDisplayFunc(Draw
);