ViewVC Help
View File | Revision Log | Show Annotations | Download File | Root Listing
root/radiance/ray/src/common/rgldomat.c
Revision: 3.3
Committed: Tue Feb 25 02:47:22 2003 UTC (21 years, 2 months ago) by greg
Content type: text/plain
Branch: MAIN
CVS Tags: rad3R5
Changes since 3.2: +1 -56 lines
Log Message:
Replaced inline copyright notice with #include "copyright.h"

File Contents

# User Rev Content
1 gwlarson 3.1 #ifndef lint
2 greg 3.2 static const char RCSid[] = "$Id$";
3 gwlarson 3.1 #endif
4     /*
5     * Invocation routines for Radiance -> OpenGL materials.
6     */
7    
8 greg 3.3 #include "copyright.h"
9 greg 3.2
10 gwlarson 3.1 #include "radogl.h"
11    
12    
13 greg 3.2 void
14 gwlarson 3.1 domatobj(mp, cent) /* generate OpenGL material for object */
15     register MATREC *mp;
16     FVECT cent;
17     {
18     GLfloat vec[4];
19    
20     if (mp == NULL | !domats)
21     return;
22     if (islight(mp->type)) {
23     vec[0] = colval(mp->u.l.emission,RED);
24     vec[1] = colval(mp->u.l.emission,GRN);
25     vec[2] = colval(mp->u.l.emission,BLU);
26     vec[3] = 1.;
27     glMaterialfv(GL_FRONT, GL_EMISSION, vec);
28     vec[0] = vec[1] = vec[2] = 0.; vec[3] = 1.;
29     glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE, vec);
30     glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, vec);
31     } else {
32     vec[0] = colval(mp->u.m.ambdiff,RED);
33     vec[1] = colval(mp->u.m.ambdiff,GRN);
34     vec[2] = colval(mp->u.m.ambdiff,BLU);
35     vec[3] = 1.;
36     glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT_AND_DIFFUSE, vec);
37     vec[0] = colval(mp->u.m.specular,RED);
38     vec[1] = colval(mp->u.m.specular,GRN);
39     vec[2] = colval(mp->u.m.specular,BLU);
40     vec[3] = 1.;
41     glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, vec);
42     glMaterialf(GL_FRONT_AND_BACK, GL_SHININESS, mp->u.m.specexp);
43     vec[0] = vec[1] = vec[2] = 0.; vec[3] = 1.;
44     glMaterialfv(GL_FRONT_AND_BACK, GL_EMISSION, vec);
45     }
46     rgl_checkerr("in domatobj");
47     }
48    
49    
50 greg 3.2 void
51 gwlarson 3.1 domatvert(mp, v, n) /* generate OpenGL material for vertex */
52     MATREC *mp;
53     FVECT v, n;
54     {
55 greg 3.2 /* unimplemented */
56 gwlarson 3.1 }