home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Micro R&D 1
/
MicroRD-CD-ROM-Vol1-1994.iso
/
more3d
/
3dtools
/
t3dlib_src_r41.lha
/
writevort.c
< prev
Wrap
C/C++ Source or Header
|
1993-12-12
|
14KB
|
520 lines
/* writevort.c - dump the internal database to a Vort input file
* - written by Glenn M. Lewis - 10/11/91
*/
static char rcs_id[] = "$Id: writevort.c,v 1.13 1993/01/30 23:43:03 glewis Exp $";
#include <stdio.h>
#include <ctype.h>
#include "t3dlib.h"
#ifdef __STDC__
#include <stdlib.h>
#include <strings.h>
#include "writevort_protos.h"
#endif
static void process_DESC();
static void process_EXTR();
static void process_INFO();
static void process_OBJ();
/* Two-space tabs */
#define TABSTOP " "
static FILE *out;
static char tab[133];
static int num_OBJ, num_DESC, num_TOBJ;
static int cur_level, cur_objnum;
static int prntline;
static struct save_hier {
int objnum;
struct save_hier *next;
} *root = 0;
typedef struct save_hier HIER;
/* Here are a few necessary utilities */
static void indent()
{
strcat(tab, TABSTOP);
}
static void outdent()
{
register int i = strlen(tab) - strlen(TABSTOP);
if (i<0) {
fprintf(stderr, "Whoa, Glenn! You blew it!\n");
tab[0] = '\0';
return;
}
tab[i] = '\0';
}
static void send_XYZ(f) /* Print a common string */
XYZ_st *f;
{
fprintf(out, " %.12g,%.12g,%.12g ", f->x, f->y, f->z);
}
static void send_RGB(rgb) /* Print a common string */
RGB_st *rgb;
{
fprintf(out, " %.12g,%.12g,%.12g ",
((double)rgb->r)/255.0,
((double)rgb->g)/255.0,
((double)rgb->b)/255.0);
}
/********************/
/* The MAIN section */
/********************/
int write_Vort(world, file)
WORLD *world;
FILE *file;
{
register OBJECT *o;
if (!(out=file) || !world) return(0); /* File not open */
tab[0] = '\0';
num_OBJ = num_DESC = num_TOBJ = 0;
fputs("/* TTDDD library - Written by Glenn M. Lewis - 10/11/91 */\n\n",out);
fputs("maxhitlevel 1\n", out);
fputs("light {\n color 1,1,1\n direction(-1,1,-1)\n}\n", out);
fputs("up(0,0,1)\nlookat(10,-100,100,0,0,0,0)\n", out);
if (world->info) process_INFO(world->info);
for (o=world->object; o; o=o->next)
process_OBJ(o);
return(1);
}
static void process_INFO(info)
INFO *info;
{
fprintf(out, "%s/* INFO Begin */\n", tab);
indent();
/*
for (i=0; i<8; i++)
if (info->brsh[i][0])
fprintf(out, "%sBRSH[%d]=\"%s\"\n", tab, i, info->brsh[i]);
for (i=0; i<8; i++)
if (info->stnc[i][0])
fprintf(out, "%sSTNC[%d]=\"%s\"\n", tab, i, info->stnc[i]);
for (i=0; i<8; i++)
if (info->txtr[i][0])
fprintf(out, "%sTXTR[%d]=\"%s\"\n", tab, i, info->txtr[i]);
*/
if (info->obsv) {
fprintf(out, "%slookat(", tab); send_XYZ(&info->obsv->came);
fprintf(out, "%s/* OBSV Rotate", tab); send_XYZ(&info->obsv->rota);
fprintf(out, "%s focaldist %.12g */\n", tab, info->obsv->foca);
fprintf(out, "%s)", tab);
}
/* if (info->otrk[0]) fprintf(out, "%sOTRK \"%s\"\n", tab, info->otrk); */
/*
if (info->ostr) {
if (info->ostr->path[0])
fprintf(out, "%sOSTR Path \"%s\"\n", tab, info->ostr->path);
fprintf(out, "%sOSTR Translate", tab); send_XYZ(&info->ostr->tran);
fprintf(out, "%sOSTR Rotate ", tab); send_XYZ(&info->ostr->rota);
fprintf(out, "%sOSTR Scale ", tab); send_XYZ(&info->ostr->scal);
i = info->ostr->info;
strin[0] = '\0';
if (i&(1<<0)) strcat(strin, " ABS_TRA");
if (i&(1<<1)) strcat(strin, " ABS_ROT");
if (i&(1<<2)) strcat(strin, " ABS_SCL");
if (i&(1<<4)) strcat(strin, " LOC_TRA");
if (i&(1<<5)) strcat(strin, " LOC_ROT");
if (i&(1<<6)) strcat(strin, " LOC_SCL");
if (i&(1<<8)) strcat(strin, " X_ALIGN");
if (i&(1<<9)) strcat(strin, " Y_ALIGN");
if (i&(1<<10)) strcat(strin, " Z_ALIGN");
if (i&(1<<12)) strcat(strin, " FOLLOW_ME");
fprintf(out, "%sOSTR Info%s\n", tab, strin);
}
*/
if (info->fade) {
fprintf(out, "%s/* FADE FadeAt %.12g*/\n", tab, info->fade->at);
fprintf(out, "%s/* FADE FadeBy %.12g*/\n", tab, info->fade->by);
fprintf(out, "%s/* FADE FadeTo", tab); send_RGB(&info->fade->to);
fprintf(out, "*/\n");
}
if (info->skyc) {
fprintf(out, "%s/* SKYX Horizon", tab); send_RGB(&info->skyc->hori);
fprintf(out, "*/\n");
fprintf(out, "%s/* SKYC Zenith ", tab); send_RGB(&info->skyc->zeni);
fprintf(out, "*/\n");
}
if (info->ambi)
{ fprintf(out, "%sbackground", tab); send_RGB(info->ambi); }
/*
if (info->glb0)
for (i=0; i<8; i++)
fprintf(out, "%sGLB0[%d]=%u\n", tab, i, info->glb0[i]);
*/
outdent();
fprintf(out, "%s/* End INFO */\n", tab);
}
static void process_OBJ(obj)
register OBJECT *obj;
{
register HIER *p;
num_OBJ++;
fprintf(out, "%s/* OBJ Begin \"Hierarchy %d\" */\n", tab, num_OBJ);
num_DESC = num_TOBJ = 0; /* Reset counters */
cur_level = 0;
cur_objnum = 1;
prntline = 1;
if (obj->extr) process_EXTR(obj->extr);
else process_DESC(obj);
while (root) { /* This should happen at most once. */
p = root->next;
free((char *)root); /* Delete this from list */
root = p;
outdent();
}
fprintf(out, "%s/* End OBJ \"Hierarchy %d\" */\n", tab, num_OBJ);
}
static void process_TOBJ()
{
register HIER *p;
if (num_DESC-num_TOBJ < cur_level) { /* Pop old level off HIER */
cur_level--;
cur_objnum = root->objnum;
p = root->next;
free((char *)root); /* Delete from list */
root = p;
outdent(); /* Pretty file formatting */
}
fprintf(out, "%s}\n", tab);
fprintf(out, "%s/* TOBJ \"Object %d at level %d of hierarchy %d\" */\n",
tab, cur_objnum-1, num_DESC-num_TOBJ, num_OBJ);
num_TOBJ++;
prntline = 1;
}
static void process_EXTR(extr)
EXTR *extr;
{
if (!prntline) fprintf(out, "\n"); /* Print one anyway */
indent();
num_DESC++;
fprintf(out, "%s/* EXTR Begin \"Object %d at level %d of hierarchy %d\" */\n",
tab, cur_objnum, num_DESC-num_TOBJ, num_OBJ);
fprintf(out, "%scomposite {\n", tab);
indent();
fprintf(out, "%s/* LOAD \"%s\" */\n", tab, extr->filename);
fprintf(out, "include %s\n", extr->filename);
fprintf(out, "%stranslate(", tab); send_XYZ(&extr->mtrx.tran);
fprintf(out, ")\n%sscale (", tab); send_XYZ(&extr->mtrx.scal);
fprintf(out, "\n%stransform {\n", tab);
indent();
fprintf(out, "%s%.12g,%.12g,%.12g,", tab,
extr->mtrx.rota1.x,
extr->mtrx.rota1.y,
extr->mtrx.rota1.z);
fprintf(out, "%s%.12g,%.12g,%.12g,", tab,
extr->mtrx.rota2.x,
extr->mtrx.rota2.y,
extr->mtrx.rota2.z);
fprintf(out, "%s%.12g,%.12g,%.12g\n", tab,
extr->mtrx.rota3.x,
extr->mtrx.rota3.y,
extr->mtrx.rota3.z);
outdent();
fprintf(out, "%s}\n", tab);
outdent();
fprintf(out, "%s}\n", tab);
fprintf(out, "%s/* End EXTR \"Object %d at level %d of hierarchy %d\" */\n",
tab, cur_objnum, num_DESC-num_TOBJ, num_OBJ);
num_TOBJ++;
cur_objnum++;
outdent();
prntline = 1;
}
static void process_DESC(object)
OBJECT *object;
{
register int i;
register HIER *p;
register OBJECT *obj;
register DESC *desc = object->desc;
register int p1, p2, p3;
num_DESC++;
if (num_DESC-num_TOBJ > cur_level) { /* Push new level in HIER */
if (!prntline) fprintf(out, "\n"); /* Print one anyway */
if (!(p = (HIER*)malloc(sizeof(HIER)))) {
fprintf(stderr, "ERROR! Out of memory.\n*** ABORT ***\n");
exit(20);
}
p->next = root; /* Insert into list */
root = p;
root->objnum = cur_objnum;
cur_level++;
cur_objnum = 1;
indent(); /* Pretty file formatting */
}
fprintf(out, "%s/* DESC Begin \"Object %d at level %d of hierarchy %d\" */\n",
tab, cur_objnum, num_DESC-num_TOBJ, num_OBJ);
/* fprintf(out, "%sgrid 20 20 20\n", tab); */
fprintf(out, "%scomposite {\n", tab);
indent();
if (desc->name[0]) fprintf(out, "%s/* name \"%s\" */\n", tab, desc->name);
if (desc->posi) {
fprintf(out, "%stranslate(", tab);
send_XYZ(desc->posi);
fprintf(out, ")\n");
}
if (desc->colr) {
fprintf(out, "%sambient", tab);
send_RGB(desc->colr);
fprintf(out, "\n");
}
if (desc->refl) {
fprintf(out, "%s/* specular", tab);
send_RGB(desc->refl);
fprintf(out, "*/\n");
}
if (desc->tran) { fprintf(out, "%s/* TRAN", tab); send_RGB(desc->tran);
fprintf(out, "*/\n");
}
#ifdef WRITETTDDD
if (desc->fcount) {
fprintf(out, "%sCLST Count %u\n", tab, i);
for (i=0; i<desc->fcount; i++) {
if (desc->colr) {
if (desc->clst[i*3 ]==desc->colr->r &&
desc->clst[i*3+1]==desc->colr->g &&
desc->clst[i*3+2]==desc->colr->b) continue; /* Skip */
} else {
if (desc->clst[i*3 ]==255 &&
desc->clst[i*3+1]==255 &&
desc->clst[i*3+2]==255) continue; /* Skip this one */
}
fprintf(out, "%sCLST Color[%u]", tab, i);
send_RGB((RGB_st*)&desc->clst[i*3]);
}
fprintf(out, "%sRLST Count %u\n", tab, i);
for (i=0; i<desc->fcount; i++) {
if (desc->refl) {
if (desc->rlst[i*3 ]==desc->refl->r &&
desc->rlst[i*3+1]==desc->refl->g &&
desc->rlst[i*3+2]==desc->refl->b) continue; /* Skip */
} else {
if (desc->rlst[i*3 ]==0 &&
desc->rlst[i*3+1]==0 &&
desc->rlst[i*3+2]==0) continue; /* Skip this one */
}
fprintf(out, "%sRLST Color[%u]", tab, i);
send_RGB((RGB_st*)&desc->rlst[i*3]);
}
fprintf(out, "%sTLST Count %u\n", tab, i);
for (i=0; i<desc->fcount; i++) {
if (desc->tran) {
if (desc->tlst[i*3 ]==desc->tran->r &&
desc->tlst[i*3+1]==desc->tran->g &&
desc->tlst[i*3+2]==desc->tran->b) continue; /* Skip */
} else {
if (desc->tlst[i*3 ]==0 &&
desc->tlst[i*3+1]==0 &&
desc->tlst[i*3+2]==0) continue; /* Skip this one */
}
fprintf(out, "%sTLST Color[%u]", tab, i);
send_RGB((RGB_st*)&desc->tlst[i*3]);
}
}
#endif
if (desc->tpar) {
for (i=0; i<16; i++)
fprintf(out, "%s/* TPAR[%u]=%.12g */\n", tab, i, desc->tpar[i]);
}
if (desc->surf) {
for (i=0; i<5; i++)
fprintf(out, "%s/* SURF[%u]=%d */\n", tab, i, desc->surf[i]);
}
if (desc->mttr) {
fprintf(out, "%s/* MTTR Type =%u */\n", tab, desc->mttr->type);
fprintf(out, "%s/* MTTR Index=%.12g */\n", tab, (double)desc->mttr->indx);
}
if (desc->spec) {
fprintf(out, "%s/* SPEC Spec=%u */\n", tab, desc->spec[0]);
fprintf(out, "%s/* SPEC Hard=%u */\n", tab, desc->spec[1]);
}
if (desc->prp0) {
for (i=0; i<6; i++)
fprintf(out, "%s/* PRP0[%u]=%u */\n", tab, i, desc->prp0[i]);
}
if (desc->ints)
fprintf(out, "%s/* INTS=%.12g */\n", tab, desc->ints);
#ifdef WRITETDDD
if (desc->stry) {
fprintf(out, "%sSTRY Path \"%s\"\n", tab, desc->stry->path);
fprintf(out, "%sSTRY Translate", tab); send_XYZ(&desc->stry->tran);
fprintf(out, "%sSTRY Rotate ", tab); send_XYZ(&desc->stry->rota);
fprintf(out, "%sSTRY Scale ", tab); send_XYZ(&desc->stry->scal);
i = desc->stry->info;
strin[0] = '\0';
if (i&(1<<0)) strcat(strin, " ABS_TRA");
if (i&(1<<1)) strcat(strin, " ABS_ROT");
if (i&(1<<2)) strcat(strin, " ABS_SCL");
if (i&(1<<4)) strcat(strin, " LOC_TRA");
if (i&(1<<5)) strcat(strin, " LOC_ROT");
if (i&(1<<6)) strcat(strin, " LOC_SCL");
if (i&(1<<8)) strcat(strin, " X_ALIGN");
if (i&(1<<9)) strcat(strin, " Y_ALIGN");
if (i&(1<<10)) strcat(strin, " Z_ALIGN");
if (i&(1<<12)) strcat(strin, " FOLLOW_ME");
fprintf(out, "%sSTRY Info%s\n", tab, strin);
}
#endif
if (desc->shap) {
fprintf(out, "%s/* SHAP Shape = %u */\n", tab, desc->shap[0]);
if (desc->shap[0]==0 && !desc->shap[1]) { /* Sphere */
fprintf(out, "%ssphere {\n", tab);
indent();
fprintf(out, "%scenter(", tab);
send_XYZ(desc->posi);
fprintf(out, ")\n%sradius %.12g\n", tab, desc->size->x);
outdent();
fprintf(out, "%s}\n", tab);
goto SKIP_REST;
}
fprintf(out, "%s/* SHAP Lamp = %u */\n", tab, desc->shap[1]);
if (desc->shap[1]<2) {
fprintf(out, "%slight {\n", tab);
indent();
if (desc->colr) {
fprintf(out, "%scolor", tab);
send_RGB(desc->colr);
fprintf(out, "\n");
}
if (desc->shap[1]==1) /* Sunlight */
fprintf(out, "%sdirection(%.12g,%.12g,%.12g)\n", tab,
-(desc->posi->x),
-(desc->posi->y),
-(desc->posi->z));
else /* Like a lamp */
fprintf(out, "%slocation(%.12g,%.12g,%.12g)\n", tab,
desc->posi->x,
desc->posi->y,
desc->posi->z);
outdent();
fprintf(out, "%s}\n", tab);
goto SKIP_REST;
}
}
/*
if (desc->axis) {
fprintf(out, "%sAXIS XAxis", tab); send_XYZ(&desc->axis->xaxi);
fprintf(out, "%sAXIS YAxis", tab); send_XYZ(&desc->axis->yaxi);
fprintf(out, "%sAXIS ZAxis", tab); send_XYZ(&desc->axis->zaxi);
}
if (desc->size)
{ fprintf(out, "%sSIZE", tab); send_XYZ(desc->size); }
if (desc->pcount) {
fprintf(out, "%sPNTS PCount %u\n", tab, desc->pcount);
for (i=0; i<desc->pcount; i++) {
fprintf(out, "%sPNTS Point[%d]", tab, i);
send_XYZ(&desc->pnts[i]);
}
}
if (desc->ecount) {
fprintf(out, "%sEDGE ECount %u\n", tab, desc->ecount);
for (i=0; i<desc->ecount; i++) {
fprintf(out, "%sEDGE Edge[%d] %u %u\n", tab, i,
desc->edge[i<<1], desc->edge[(i<<1)+1]);
}
}
*/
if (desc->fcount && desc->ecount && desc->pcount) {
fprintf(out, "%s/* FACE TCount %u */\n", tab, desc->fcount);
for (i=0; i<desc->fcount; i++) {
/* fprintf(out, "%sFACE Connect[%u] %u %u %u\n", tab, i,
desc->face[i*3], desc->face[i*3+1], desc->face[i*3+2]);
*/
/* First check to make sure that this triangle is real */
p1 = desc->edge[(desc->face[i*3])<<1];
p2 = desc->edge[((desc->face[i*3])<<1)+1];
if (p1 == p2) continue; /* How did *this* happen? */
p3 = desc->edge[(desc->face[i*3+2])<<1];
if (p1 == p3 || p2 == p3)
p3 = desc->edge[((desc->face[i*3+2])<<1)+1];
if (p1 == p3 || p2 == p3) continue; /* How did *this* happen? */
/* Now check the actual points for equality */
if (bcmp(&desc->pnts[p1], &desc->pnts[p2], sizeof(XYZ_st))==0 ||
bcmp(&desc->pnts[p1], &desc->pnts[p3], sizeof(XYZ_st))==0 ||
bcmp(&desc->pnts[p2], &desc->pnts[p3], sizeof(XYZ_st))==0)
continue;
fprintf(out, "%spolygon {\n", tab);
indent();
fprintf(out, "%svertex(", tab); send_XYZ(&desc->pnts[p1]);
fprintf(out, ")\n%svertex(", tab); send_XYZ(&desc->pnts[p2]);
fprintf(out, ")\n%svertex(", tab); send_XYZ(&desc->pnts[p3]);
outdent();
fprintf(out, ")\n%s}\n", tab);
}
}
SKIP_REST:
for (obj=object->child; obj; obj=obj->next) {
if (obj->extr) process_EXTR(obj->extr);
else process_DESC(obj);
}
outdent();
fprintf(out, "%s/* End DESC \"Object %d at level %d of hierarchy %d\" */\n",
tab, cur_objnum, num_DESC-num_TOBJ, num_OBJ);
cur_objnum++;
prntline = 0;
process_TOBJ();
}