home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
gondwana.ecr.mu.oz.au/pub/
/
Graphics.tar
/
Graphics
/
fermiVogle.tar.Z
/
fermiVogle.tar
/
devel
/
src
/
trans.c
< prev
next >
Wrap
C/C++ Source or Header
|
1996-02-07
|
5KB
|
173 lines
#include "vogle.h"
#ifdef TC
extern double cos();
extern double sin();
#else
#include <math.h>
#endif
/*
* translate
*
* Set up a translation matrix and premultiply it and
* the top matrix on the stack.
*
*/
void
translate(float x, float y, float z)
{
Token *tok;
if (!vdevice.initialised)
verror("translate: vogle not initialised");
if (vdevice.inobject) {
tok = newtokens(4);
tok[0].i = TRANSLATE;
tok[1].f = x;
tok[2].f = y;
tok[3].f = z;
return;
}
/*
* Do the operations directly on the top matrix of
* the stack to speed things up.
*/
vdevice.transmat->m[3][0] += x * vdevice.transmat->m[0][0]
+ y * vdevice.transmat->m[1][0]
+ z * vdevice.transmat->m[2][0];
vdevice.transmat->m[3][1] += x * vdevice.transmat->m[0][1]
+ y * vdevice.transmat->m[1][1]
+ z * vdevice.transmat->m[2][1];
vdevice.transmat->m[3][2] += x * vdevice.transmat->m[0][2]
+ y * vdevice.transmat->m[1][2]
+ z * vdevice.transmat->m[2][2];
vdevice.transmat->m[3][3] += x * vdevice.transmat->m[0][3]
+ y * vdevice.transmat->m[1][3]
+ z * vdevice.transmat->m[2][3];
}
/*
* rotate
*
* Set up a rotate matrix and premultiply it with
* the top matrix on the stack.
*
*/
void
rotate(float r, char axis)
{
Token *tok;
register float costheta, sintheta, tmp;
if (!vdevice.initialised)
verror("rotate: vogle not initialised");
if (vdevice.inobject) {
tok = newtokens(3);
tok[0].i = ROTATE;
tok[1].f = r;
tok[2].i = axis;
return;
}
/*
* Do the operations directly on the top matrix of
* the stack to speed things up.
*/
costheta = cos((double)(D2R * r));
sintheta = sin((double)(D2R * r));
switch(axis) {
case 'x':
case 'X':
tmp = vdevice.transmat->m[1][0];
vdevice.transmat->m[1][0] = costheta * tmp
+ sintheta * vdevice.transmat->m[2][0];
vdevice.transmat->m[2][0] = costheta * vdevice.transmat->m[2][0]
- sintheta * tmp;
tmp = vdevice.transmat->m[1][1];
vdevice.transmat->m[1][1] = costheta * tmp
+ sintheta * vdevice.transmat->m[2][1];
vdevice.transmat->m[2][1] = costheta * vdevice.transmat->m[2][1]
- sintheta * tmp;
tmp = vdevice.transmat->m[1][2];
vdevice.transmat->m[1][2] = costheta * tmp
+ sintheta * vdevice.transmat->m[2][2];
vdevice.transmat->m[2][2] = costheta * vdevice.transmat->m[2][2]
- sintheta * tmp;
tmp = vdevice.transmat->m[1][3];
vdevice.transmat->m[1][3] = costheta * tmp
+ sintheta * vdevice.transmat->m[2][3];
vdevice.transmat->m[2][3] = costheta * vdevice.transmat->m[2][3]
- sintheta * tmp;
break;
case 'y':
case 'Y':
tmp = vdevice.transmat->m[0][0];
vdevice.transmat->m[0][0] = costheta * tmp
- sintheta * vdevice.transmat->m[2][0];
vdevice.transmat->m[2][0] = sintheta * tmp
+ costheta * vdevice.transmat->m[2][0];
tmp = vdevice.transmat->m[0][1];
vdevice.transmat->m[0][1] = costheta * tmp
- sintheta * vdevice.transmat->m[2][1];
vdevice.transmat->m[2][1] = sintheta * tmp
+ costheta * vdevice.transmat->m[2][1];
tmp = vdevice.transmat->m[0][2];
vdevice.transmat->m[0][2] = costheta * tmp
- sintheta * vdevice.transmat->m[2][2];
vdevice.transmat->m[2][2] = sintheta * tmp
+ costheta * vdevice.transmat->m[2][2];
tmp = vdevice.transmat->m[0][3];
vdevice.transmat->m[0][3] = costheta * tmp
- sintheta * vdevice.transmat->m[2][3];
vdevice.transmat->m[2][3] = sintheta * tmp
+ costheta * vdevice.transmat->m[2][3];
break;
case 'z':
case 'Z':
tmp = vdevice.transmat->m[0][0];
vdevice.transmat->m[0][0] = costheta * tmp
+ sintheta * vdevice.transmat->m[1][0];
vdevice.transmat->m[1][0] = costheta * vdevice.transmat->m[1][0]
- sintheta * tmp;
tmp = vdevice.transmat->m[0][1];
vdevice.transmat->m[0][1] = costheta * tmp
+ sintheta * vdevice.transmat->m[1][1];
vdevice.transmat->m[1][1] = costheta * vdevice.transmat->m[1][1]
- sintheta * tmp;
tmp = vdevice.transmat->m[0][2];
vdevice.transmat->m[0][2] = costheta * tmp
+ sintheta * vdevice.transmat->m[1][2];
vdevice.transmat->m[1][2] = costheta * vdevice.transmat->m[1][2]
- sintheta * tmp;
tmp = vdevice.transmat->m[0][3];
vdevice.transmat->m[0][3] = costheta * tmp
+ sintheta * vdevice.transmat->m[1][3];
vdevice.transmat->m[1][3] = costheta * vdevice.transmat->m[1][3]
- sintheta * tmp;
break;
default:
verror("rotate: illegal axis of rotation");
}
}