mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
597 lines
14 KiB
597 lines
14 KiB
#include "viewer.h"
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <ctype.h>
|
|
#include "trackbal.h"
|
|
|
|
#define Z_DELTA 1.0
|
|
#define Y_DELTA 1.0
|
|
#define X_DELTA 1.0
|
|
/************************************************************************/
|
|
/******************* Function Prototypes ********************************/
|
|
/************************************************************************/
|
|
void Reshape (GLsizei, GLsizei);
|
|
void InitGL(void);
|
|
void DoGlStuff(void);
|
|
void spin(void);
|
|
|
|
void InitMatrix (void);
|
|
void InitLighting(int, int, GLfloat, BOOL, int, int, int, BOOL);
|
|
void InitTexture (void);
|
|
void InitDrawing(void);
|
|
static void SetViewing(GLsizei, GLsizei, BOOL);
|
|
void SetViewWrap(GLsizei, GLsizei);
|
|
|
|
void initlights(void);
|
|
void EnableLighting (void);
|
|
void DisableLighting (void);
|
|
void PrintStuff (void);
|
|
void SetDistance( void );
|
|
void Key_up (void);
|
|
void Key_down (void);
|
|
|
|
void Key_i (void);
|
|
void Key_x (void);
|
|
void Key_X (void);
|
|
void Key_y (void);
|
|
void Key_Y (void);
|
|
void Key_z (void);
|
|
void Key_Z (void);
|
|
/************************************************************************/
|
|
/******************* Globals ********************************************/
|
|
/************************************************************************/
|
|
static unsigned int stipple[32] = {
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555,
|
|
0xAAAAAAAA,
|
|
0x55555555
|
|
};
|
|
|
|
GLfloat zTrans = 0.0;
|
|
|
|
/************************************************************************/
|
|
/******************* Code ***********************************************/
|
|
/************************************************************************/
|
|
void InitGL(void)
|
|
{
|
|
/* Initialize the State */
|
|
if (linesmooth_enable)
|
|
{
|
|
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
|
glEnable(GL_BLEND);
|
|
glEnable(GL_LINE_SMOOTH);
|
|
}
|
|
if (polysmooth_enable)
|
|
{
|
|
glClearColor(0.0F, 0.0F, 0.0F, 0.0F);
|
|
glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
|
|
glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
glBlendFunc(sblendfunc, dblendfunc);
|
|
glEnable(GL_BLEND);
|
|
glEnable(GL_POLYGON_SMOOTH);
|
|
}
|
|
if (blend_enable)
|
|
{
|
|
glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
|
|
glColor4f(1.0F, 1.0F, 1.0F, 0.5F);
|
|
glBlendFunc(sblendfunc, dblendfunc);
|
|
glEnable(GL_BLEND);
|
|
}
|
|
else
|
|
{
|
|
glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_FALSE);
|
|
glColor3f(1.0F, 1.0F, 1.0F);
|
|
}
|
|
if (dither_enable)
|
|
{
|
|
glEnable(GL_DITHER);
|
|
}
|
|
else
|
|
{
|
|
glDisable(GL_DITHER);
|
|
}
|
|
|
|
glPolygonMode(GL_FRONT, polymodefront);
|
|
glPolygonMode(GL_BACK, polymodeback);
|
|
|
|
if (linestipple_enable)
|
|
{
|
|
glLineStipple(1, 0xf0f0);
|
|
glEnable(GL_LINE_STIPPLE);
|
|
}
|
|
|
|
if (polystipple_enable)
|
|
{
|
|
glPolygonStipple((const GLubyte *) stipple);
|
|
glEnable(GL_POLYGON_STIPPLE);
|
|
}
|
|
glShadeModel(shade_model);
|
|
#if 1
|
|
if (depth_mode)
|
|
{
|
|
glEnable(GL_DEPTH_TEST);
|
|
glDepthFunc(GL_LESS);
|
|
glDepthMask(GL_TRUE);
|
|
}
|
|
else
|
|
{
|
|
glDisable(GL_DEPTH_TEST);
|
|
glDepthMask(GL_FALSE);
|
|
}
|
|
#endif
|
|
|
|
glCullFace(cull_face);
|
|
if (cull_enable)
|
|
glEnable(GL_CULL_FACE);
|
|
|
|
if (fog_enable)
|
|
{
|
|
glFogf(GL_FOG_START, 0);
|
|
glFogf(GL_FOG_END, 1);
|
|
glFogf(GL_FOG_MODE, GL_LINEAR);
|
|
glEnable(GL_FOG);
|
|
}
|
|
|
|
InitMatrix ();
|
|
|
|
if (light_enable)
|
|
InitLighting (numInfLights, numLocalLights, localviewmode,
|
|
lighttwoside, cmenable, cmface, cmmode, blend_enable);
|
|
glFrontFace(front_face);
|
|
|
|
glDrawBuffer(GL_BACK);
|
|
glClearColor ((GLfloat)0.0, (GLfloat)0.3, (GLfloat)0.5, (GLfloat)0.0);
|
|
//glClearColor ((GLfloat)0.0, (GLfloat)0.0, (GLfloat)0.0, (GLfloat)0.0);
|
|
|
|
if (tex_enable)
|
|
InitTexture ();
|
|
|
|
InitDrawing();
|
|
SetViewing(g_wi.wSize.cx, g_wi.wSize.cy, TRUE);
|
|
}
|
|
|
|
|
|
void SetViewWrap(GLsizei w, GLsizei h)
|
|
{
|
|
if (!h) return;
|
|
SetViewing( w, h, TRUE);
|
|
}
|
|
|
|
void SetViewing(GLsizei w, GLsizei h, BOOL resize)
|
|
{
|
|
GLfloat l_zoom[3];
|
|
|
|
|
|
if (resize)
|
|
{
|
|
g_wi.wSize.cx = (int) w;
|
|
g_wi.wSize.cy = (int) h;
|
|
|
|
g_wi.wCenter.x = (int) w/2;
|
|
g_wi.wCenter.y = (int) h/2;
|
|
|
|
g_s.aspect_ratio = g_wi.wSize.cx / g_wi.wSize.cy;
|
|
}
|
|
|
|
for (int i=0; i<3; i++)
|
|
l_zoom[i] = (g_s.from[i] - g_s.to[i]) * g_s.zoom + g_s.to[i];
|
|
|
|
glViewport(0, 0, g_wi.wSize.cx, g_wi.wSize.cy);
|
|
glMatrixMode(GL_PROJECTION);
|
|
glLoadIdentity();
|
|
gluPerspective(g_s.fov, g_s.aspect_ratio,
|
|
g_s.hither, g_s.yon * g_s.zoom);
|
|
|
|
glMatrixMode(GL_MODELVIEW);
|
|
glLoadIdentity();
|
|
gluLookAt(l_zoom[0], l_zoom[1], l_zoom[2],
|
|
g_s.to[0], g_s.to[1], g_s.to[2],
|
|
g_s.up[0], g_s.up[1], g_s.up[2]);
|
|
}
|
|
|
|
|
|
void InitDrawing(void)
|
|
{
|
|
initlights();
|
|
if (light_enable) EnableLighting ();
|
|
else DisableLighting();
|
|
//glClearColor ((GLfloat)0.0, (GLfloat)0.3, (GLfloat)0.5, (GLfloat)0.0);
|
|
glClearColor ((GLfloat)0.0, (GLfloat)0.0, (GLfloat)0.0, (GLfloat)0.0);
|
|
glColor3f(0.2, 0.5, 0.8);
|
|
}
|
|
|
|
|
|
void CALLBACK InitMatrix (void)
|
|
{
|
|
glMatrixMode(GL_PROJECTION);
|
|
glLoadIdentity();
|
|
glMatrixMode(GL_MODELVIEW);
|
|
glLoadIdentity();
|
|
}
|
|
|
|
|
|
void CALLBACK InitTexture (void)
|
|
{
|
|
}
|
|
|
|
void PrintStuff (void)
|
|
{
|
|
}
|
|
|
|
|
|
static void ComputeLatestMVMatrix ()
|
|
{
|
|
POINT pt;
|
|
static GLfloat del_x = 0.0, del_y = 0.0;
|
|
float matRot[4][4];
|
|
|
|
if (g_wi.rmouse_down)
|
|
{
|
|
if (GetCursorPos(&pt))
|
|
{
|
|
// Subtract current window center to convert to
|
|
// window coordinates.
|
|
|
|
pt.x -= (g_wi.wPosition.x);
|
|
pt.y -= (g_wi.wPosition.y);
|
|
|
|
if (pt.x != (int)g_wi.rmouseX || pt.y != (int)g_wi.rmouseY)
|
|
{
|
|
del_x = (float) (X_DELTA * (pt.x - (int)g_wi.rmouseX) /
|
|
(float) g_wi.wSize.cx);
|
|
del_y = (float) (Y_DELTA * (pt.y - (int)g_wi.rmouseY) /
|
|
(float) g_wi.wSize.cy);
|
|
}
|
|
|
|
g_s.trans[0] += del_x;
|
|
g_s.trans[1] -= del_y;
|
|
}
|
|
}
|
|
|
|
if (g_wi.lmouse_down)
|
|
{
|
|
// Convert to window coordinates.
|
|
|
|
pt.x -= (g_wi.wPosition.x);
|
|
pt.y -= (g_wi.wPosition.y);
|
|
|
|
if (GetCursorPos(&pt))
|
|
{
|
|
if (pt.x != (int)g_wi.lmouseX || pt.y != (int)g_wi.lmouseY)
|
|
{
|
|
trackball(curquat,
|
|
2.0*(g_wi.lmouseX)/g_wi.wSize.cx-1.0,
|
|
2.0*(g_wi.lmouseY)/g_wi.wSize.cy-1.0,
|
|
2.0*(pt.x)/g_wi.wSize.cx-1.0,
|
|
2.0*(g_wi.wSize.cy-pt.y)/g_wi.wSize.cy-1.0);
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
glTranslatef (g_s.trans[0], g_s.trans[1], g_s.trans[2]);
|
|
build_rotmatrix(matRot, curquat);
|
|
glMultMatrixf(&(matRot[0][0]));
|
|
|
|
//glRotatef(g_s.angle, (GLfloat)0.0, (GLfloat)1.0, (GLfloat)0.0);
|
|
//trackball_CalcRotMatrix( matRot );
|
|
//glMultMatrixf( &(matRot[0][0]) );
|
|
// This defines how far away we're looking from
|
|
//glRotatef(g_s.angle, (GLfloat)1.0, (GLfloat)1.0, (GLfloat)1.0);
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
|
DoGlStuff( void )
|
|
{
|
|
HRESULT hr;
|
|
|
|
glClear (GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
|
|
glPushMatrix ();
|
|
ComputeLatestMVMatrix ();
|
|
|
|
if (!pm_ready)
|
|
{
|
|
if (filled_mode)
|
|
auxSolidTeapot (1.0);
|
|
if (edge_mode)
|
|
auxWireTeapot (1.01);
|
|
}
|
|
else
|
|
{
|
|
hr = pPMeshGL->Render ();
|
|
if (hr != S_OK)
|
|
MessageBox (NULL, "Render failed", "Error",
|
|
MB_OK);
|
|
}
|
|
|
|
glPopMatrix ();
|
|
glFlush ();
|
|
auxSwapBuffers();
|
|
PrintStuff ();
|
|
}
|
|
|
|
|
|
void CALLBACK Reshape(GLsizei w, GLsizei h)
|
|
{
|
|
//trackball_Resize( w, h );
|
|
trackball (curquat, 0.0, 0.0, 0.0, 0.0);
|
|
|
|
#if 1
|
|
glViewport(0, 0, (GLint)w, (GLint)h);
|
|
glMatrixMode(GL_PROJECTION);
|
|
glLoadIdentity();
|
|
glFrustum(-1, 1, -1, 1, -1, 1000);
|
|
// glOrtho(-1, 1, -1, 1, -1, 1000);
|
|
|
|
#else
|
|
if (!h) return;
|
|
glViewport(0, 0, w, h);
|
|
glMatrixMode(GL_PROJECTION);
|
|
glLoadIdentity();
|
|
if (w <= h)
|
|
glOrtho(-5.0, 5.0, -5.0*(GLfloat)h/(GLfloat)w,
|
|
5.0*(GLfloat)h/(GLfloat)w, -5.0, 5.0);
|
|
else
|
|
glOrtho(-5.0*(GLfloat)w/(GLfloat)h,
|
|
5.0*(GLfloat)w/(GLfloat)h, -5.0, 5.0, -5.0, 5.0);
|
|
#endif
|
|
|
|
glMatrixMode(GL_MODELVIEW);
|
|
glLoadIdentity();
|
|
|
|
g_wi.wSize.cx = (int) w;
|
|
g_wi.wSize.cy = (int) h;
|
|
}
|
|
|
|
void spin(void)
|
|
{
|
|
DoGlStuff();
|
|
}
|
|
|
|
|
|
|
|
void
|
|
InitLighting(int infiniteLights, int localLights,
|
|
GLfloat localViewer, BOOL twoSidedLighting,
|
|
int cmenable, int cmface, int cmmode, BOOL blendOn)
|
|
{
|
|
int i;
|
|
GLfloat normFactor;
|
|
|
|
/* Material settings */
|
|
GLfloat materialAmbientColor[4] = {
|
|
0.5F, 0.5F, 0.5F, 1.0F
|
|
};
|
|
|
|
GLfloat materialDiffuseColor[4] = {
|
|
0.7F, 0.7F, 0.7F, 1.0F
|
|
};
|
|
|
|
GLfloat materialSpecularColor[4] = {
|
|
1.0F, 1.0F, 1.0F, 1.0F
|
|
};
|
|
|
|
GLfloat materialShininess[1] = {
|
|
128
|
|
};
|
|
|
|
/* Lighting settings */
|
|
GLfloat lightPosition[8][4] = {
|
|
{ 1.0F, 1.0F, 1.0F, 1.0F },
|
|
{ 1.0F, 0.0F, 1.0F, 1.0F },
|
|
{ 1.0F, -1.0F, 1.0F, 1.0F },
|
|
{ 0.0F, -1.0F, 1.0F, 1.0F },
|
|
{ -1.0F, -1.0F, 1.0F, 1.0F },
|
|
{ -1.0F, 0.0F, 1.0F, 1.0F },
|
|
{ -1.0F, 1.0F, 1.0F, 1.0F },
|
|
{ 0.0F, 1.0F, 1.0F, 1.0F }
|
|
};
|
|
|
|
GLfloat lightDiffuseColor[8][4] = {
|
|
{ 1.0F, 1.0F, 1.0F, 1.0F },
|
|
{ 0.0F, 1.0F, 1.0F, 1.0F },
|
|
{ 1.0F, 0.0F, 1.0F, 1.0F },
|
|
{ 1.0F, 1.0F, 0.0F, 1.0F },
|
|
{ 1.0F, 0.0F, 0.0F, 1.0F },
|
|
{ 0.0F, 1.0F, 0.0F, 1.0F },
|
|
{ 0.0F, 0.0F, 1.0F, 1.0F },
|
|
{ 1.0F, 1.0F, 1.0F, 1.0F }
|
|
};
|
|
|
|
GLfloat lightAmbientColor[4] = {
|
|
0.1F, 0.1F, 0.1F, 1.0F
|
|
};
|
|
|
|
GLfloat lightSpecularColor[4] = {
|
|
1.0F, 1.0F, 1.0F, 1.0F
|
|
};
|
|
|
|
GLfloat lightModelAmbient[4] = {
|
|
0.5F, 0.5F, 0.5F, 1.0F
|
|
};
|
|
|
|
GLfloat alpha = blendOn ? 0.5F : 1.0F;
|
|
|
|
if (infiniteLights + localLights == 0)
|
|
return;
|
|
|
|
normFactor = 1.0F / (GLfloat)(infiniteLights + localLights);
|
|
|
|
materialDiffuseColor[3] = alpha;
|
|
glMaterialfv(GL_FRONT_AND_BACK, GL_DIFFUSE, materialDiffuseColor);
|
|
materialAmbientColor[3] = alpha;
|
|
glMaterialfv(GL_FRONT_AND_BACK, GL_AMBIENT, materialAmbientColor);
|
|
glMaterialfv(GL_FRONT_AND_BACK, GL_SPECULAR, materialSpecularColor);
|
|
glMaterialfv(GL_FRONT_AND_BACK, GL_SHININESS, materialShininess);
|
|
|
|
lightAmbientColor[0] *= normFactor;
|
|
lightAmbientColor[1] *= normFactor;
|
|
lightAmbientColor[2] *= normFactor;
|
|
|
|
for (i = 0; i < localLights + infiniteLights; i++) {
|
|
lightPosition[i][3] = (GLfloat)(i < localLights);
|
|
lightDiffuseColor[i][0] *= normFactor;
|
|
lightDiffuseColor[i][1] *= normFactor;
|
|
lightDiffuseColor[i][2] *= normFactor;
|
|
glLightfv(GL_LIGHT0 + i, GL_POSITION, lightPosition[i]);
|
|
glLightfv(GL_LIGHT0 + i, GL_DIFFUSE, lightDiffuseColor[i]);
|
|
glLightfv(GL_LIGHT0 + i, GL_AMBIENT, lightAmbientColor);
|
|
glLightfv(GL_LIGHT0 + i, GL_SPECULAR, lightSpecularColor);
|
|
glEnable(GL_LIGHT0 + i);
|
|
}
|
|
|
|
glLightModelfv(GL_LIGHT_MODEL_AMBIENT, lightModelAmbient);
|
|
glLightModelf(GL_LIGHT_MODEL_LOCAL_VIEWER, localViewer);
|
|
glLightModeli(GL_LIGHT_MODEL_TWO_SIDE, twoSidedLighting);
|
|
|
|
if (cmenable) {
|
|
glColorMaterial(cmface, cmmode);
|
|
glEnable(GL_COLOR_MATERIAL);
|
|
}
|
|
|
|
glEnable(GL_LIGHTING);
|
|
}
|
|
|
|
void EnableLighting (void)
|
|
{
|
|
glEnable(GL_AUTO_NORMAL);
|
|
glEnable(GL_NORMALIZE);
|
|
// glShadeModel(shade_model);
|
|
|
|
glEnable(GL_LIGHTING);
|
|
glEnable(GL_LIGHT0);
|
|
}
|
|
|
|
void DisableLighting (void)
|
|
{
|
|
glDisable(GL_AUTO_NORMAL);
|
|
glDisable(GL_NORMALIZE);
|
|
// glShadeModel(shade_model);
|
|
|
|
glDisable(GL_LIGHTING);
|
|
glDisable(GL_LIGHT0);
|
|
}
|
|
|
|
|
|
void initlights(void)
|
|
{
|
|
GLfloat ambient[] = { 0.2, 0.2, 0.2, 1.0 };
|
|
GLfloat position[] = { 0.0, 0.0, 2.0, 0.0 };
|
|
GLfloat mat_diffuse[] = { 0.6, 0.6, 0.6, 1.0 };
|
|
GLfloat mat_diffuse1[] = { 0.8, 0.5, 0.2, 1.0 };
|
|
GLfloat mat_specular[] = { 1.0, 1.0, 1.0, 1.0 };
|
|
GLfloat mat_shininess[] = { 30.0 };
|
|
|
|
glLightfv(GL_LIGHT0, GL_AMBIENT, ambient);
|
|
glLightfv(GL_LIGHT0, GL_POSITION, position);
|
|
|
|
glMaterialfv(GL_FRONT, GL_DIFFUSE, mat_diffuse);
|
|
glMaterialfv(GL_BACK, GL_DIFFUSE, mat_diffuse1);
|
|
glMaterialfv(GL_FRONT, GL_SPECULAR, mat_specular);
|
|
glMaterialfv(GL_FRONT, GL_SHININESS, mat_shininess);
|
|
}
|
|
|
|
|
|
|
|
void CALLBACK Key_i (void)
|
|
{
|
|
g_s.trans[0] = 0.0;
|
|
g_s.trans[1] = 0.0;
|
|
g_s.trans[2] = 0.0;
|
|
|
|
g_s.zoom = 1.0;
|
|
SetViewing( g_wi.wSize.cx, g_wi.wSize.cy, FALSE);
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_z (void)
|
|
{
|
|
g_s.trans[2] += Z_DELTA;
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_Z (void)
|
|
{
|
|
g_s.trans[2] -= Z_DELTA;
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_y (void)
|
|
{
|
|
g_s.trans[1] += Y_DELTA;
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_Y (void)
|
|
{
|
|
g_s.trans[1] -= Y_DELTA;
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_x (void)
|
|
{
|
|
g_s.trans[0] += X_DELTA;
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_X (void)
|
|
{
|
|
g_s.trans[0] -= X_DELTA;
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_up (void)
|
|
{
|
|
//zTrans += Z_DELTA;
|
|
g_s.zoom *= .8f;
|
|
if (g_s.zoom < 1.0f && g_s.zoom > .8f)
|
|
g_s.zoom = 1.0f;
|
|
|
|
SetViewing( g_wi.wSize.cx, g_wi.wSize.cy, FALSE);
|
|
DoGlStuff ();
|
|
}
|
|
|
|
void CALLBACK Key_down (void)
|
|
{
|
|
//zTrans -= Z_DELTA;
|
|
|
|
g_s.zoom *= 1.25f;
|
|
if (g_s.zoom > 1.0f && g_s.zoom < 1.25f)
|
|
g_s.zoom = 1.0f;
|
|
|
|
SetViewing( g_wi.wSize.cx, g_wi.wSize.cy, FALSE);
|
|
DoGlStuff ();
|
|
}
|
|
|