mirror of
https://notabug.org/scuti/lib3ddevil1
synced 2024-11-22 22:03:00 +05:30
Merge branch 'a/geometry'
Geometry internals complete, interfaces likely to change
This commit is contained in:
commit
7964563396
5
Makefile
5
Makefile
@ -4,7 +4,7 @@ CFLAGS= -I"include"
|
|||||||
|
|
||||||
all: main
|
all: main
|
||||||
|
|
||||||
main: devil1pld.o devil1tex.o
|
main: devil1pld.o devil1tex.o src/devil1geo.o
|
||||||
$(CC) $^ test/main.c $(CFLAGS) -o $(EX)
|
$(CC) $^ test/main.c $(CFLAGS) -o $(EX)
|
||||||
|
|
||||||
devil1pld.o: src/devil1pld.c
|
devil1pld.o: src/devil1pld.c
|
||||||
@ -13,5 +13,8 @@ devil1pld.o: src/devil1pld.c
|
|||||||
devil1tex.o: src/devil1tex.c
|
devil1tex.o: src/devil1tex.c
|
||||||
$(CC) -c $^ $(CFLAGS)
|
$(CC) -c $^ $(CFLAGS)
|
||||||
|
|
||||||
|
devil1geo.o: src/devil1geo.c
|
||||||
|
$(CC) -c $^ $(CFLAGS)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm *.o $(EX)
|
rm *.o $(EX)
|
||||||
|
@ -2,7 +2,10 @@
|
|||||||
#ifndef DEVIL1GEO_H
|
#ifndef DEVIL1GEO_H
|
||||||
#define DEVIL1GEO_H
|
#define DEVIL1GEO_H
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#pragma pack(1)
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
|
||||||
|
#pragma pack(push, 1)
|
||||||
struct Header {
|
struct Header {
|
||||||
unsigned char numMesh;
|
unsigned char numMesh;
|
||||||
unsigned char unknownNumberB;
|
unsigned char unknownNumberB;
|
||||||
@ -12,7 +15,7 @@ struct Header {
|
|||||||
uint64_t unknownOffset;
|
uint64_t unknownOffset;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct MeshHeaders {
|
struct MeshHeader {
|
||||||
int16_t numBatch;
|
int16_t numBatch;
|
||||||
int16_t numVertex;
|
int16_t numVertex;
|
||||||
uint32_t u; // <format=hex>
|
uint32_t u; // <format=hex>
|
||||||
@ -20,11 +23,7 @@ struct MeshHeaders {
|
|||||||
uint64_t flags;
|
uint64_t flags;
|
||||||
}; // put these in an array of size: [header.numMesh]
|
}; // put these in an array of size: [header.numMesh]
|
||||||
|
|
||||||
struct Positions {
|
struct Coordinate {
|
||||||
float x, y, z;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Normals {
|
|
||||||
float x, y, z;
|
float x, y, z;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -40,9 +39,7 @@ struct BoneWeights {
|
|||||||
uint16_t weights; // <format=hex>
|
uint16_t weights; // <format=hex>
|
||||||
};
|
};
|
||||||
|
|
||||||
// This is where most of the parsing will be.
|
struct BatchData {
|
||||||
// this struct is in-order of what the file format will have.
|
|
||||||
struct Batch {
|
|
||||||
int16_t numVertex;
|
int16_t numVertex;
|
||||||
int16_t uB;
|
int16_t uB;
|
||||||
uint32_t padding; // <format=hex>
|
uint32_t padding; // <format=hex>
|
||||||
@ -52,18 +49,43 @@ struct Batch {
|
|||||||
uint64_t offsetBoneIndexes; // <format=hex>
|
uint64_t offsetBoneIndexes; // <format=hex>
|
||||||
uint64_t offsetBoneWeights; // <format=hex>
|
uint64_t offsetBoneWeights; // <format=hex>
|
||||||
uint64_t offsets[1]; // <format=hex>
|
uint64_t offsets[1]; // <format=hex>
|
||||||
int64_t pos; // set while parsing batch from ftell();
|
};
|
||||||
// following structs should in an array of size numVertex
|
|
||||||
struct Positions *p;
|
struct VertexData {
|
||||||
struct Normals *n;
|
// following structs should in an array of size 'numVertex'
|
||||||
|
struct Coordinate *positions;
|
||||||
|
struct Coordinate *normals;
|
||||||
struct UVs *u;
|
struct UVs *u;
|
||||||
struct BoneIndexes *bi;
|
struct BoneIndexes *bi;
|
||||||
struct BoneWeights *bw;
|
struct BoneWeights *bw;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct Mesh {
|
struct Batch {
|
||||||
struct Batch b;
|
struct BatchData *bd; // pointer to region in file data
|
||||||
|
struct VertexData vd; // collection of pointers to regions in file data
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct Mesh {
|
||||||
|
// array of batches
|
||||||
|
struct Batch *b;
|
||||||
|
};
|
||||||
|
|
||||||
|
#pragma pack(pop)
|
||||||
|
|
||||||
|
void printgheader(struct Header*);
|
||||||
|
|
||||||
|
void printmeshheader(struct MeshHeader*);
|
||||||
|
|
||||||
|
void printmeshbatch(struct Batch*);
|
||||||
|
|
||||||
|
void printcoordinate(struct Coordinate*, unsigned int);
|
||||||
|
|
||||||
|
// ** = 'pass by reference' of a pointer to struct
|
||||||
|
bool getmeshheader(struct MeshHeader**, unsigned int i, const char * const);
|
||||||
|
|
||||||
|
bool getmeshbatch(struct Batch*, unsigned int offset, const char * const);
|
||||||
|
|
||||||
|
bool getmesh(struct Mesh*, unsigned int i, const char* filename);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
115
src/devil1geo.c
Normal file
115
src/devil1geo.c
Normal file
@ -0,0 +1,115 @@
|
|||||||
|
#include "devil1geo.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
void printgheader(struct Header *gh) {
|
||||||
|
if (gh != NULL) {
|
||||||
|
printf("pointer %x\n", gh);
|
||||||
|
printf("number of meshes %x\n", gh -> numMesh);
|
||||||
|
printf("unknown number B %x\n", gh -> unknownNumberB);
|
||||||
|
printf("unknown number C %x\n", gh -> unknownNumberC);
|
||||||
|
printf("unknown number D %x\n", gh -> unknownNumberD);
|
||||||
|
printf("padding %x\n", gh -> padding);
|
||||||
|
printf("unknown offset %x\n", gh -> unknownOffset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void printmeshheader(struct MeshHeader *mh) {
|
||||||
|
if (mh == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
printf("number of batches %x\n", mh -> numBatch);
|
||||||
|
printf("number of vertices %x\n", mh -> numVertex);
|
||||||
|
printf("unknown %x\n", mh -> u);
|
||||||
|
printf("batch offset %x\n", mh -> offsetBatches);
|
||||||
|
printf("flags %x\n\n", mh -> flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
void printmeshbatch(struct Batch *b) {
|
||||||
|
if (b == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
struct BatchData *bd = b -> bd;
|
||||||
|
printf("number of vertices %x\n", bd -> numVertex);
|
||||||
|
printf("unknown byte %x\n", bd -> uB);
|
||||||
|
printf("padding %x\n", bd -> padding);
|
||||||
|
printf("offsetPositions %x\n", bd -> offsetPositions);
|
||||||
|
printf("offsetNormals %x\n", bd -> offsetNormals);
|
||||||
|
printf("offsetUVs %x\n", bd -> offsetUVs);
|
||||||
|
printf("offsetBoneIndexes %x\n", bd -> offsetBoneIndexes);
|
||||||
|
printf("offsetBoneWeights %x\n", bd -> offsetBoneWeights);
|
||||||
|
printf("offsets %x\n\n", bd -> offsets[0]);
|
||||||
|
printcoordinate(b -> vd.positions, 3);
|
||||||
|
}
|
||||||
|
|
||||||
|
void printcoordinate(struct Coordinate *p, unsigned int count) {
|
||||||
|
if (p == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
unsigned int i;
|
||||||
|
for (i = 0; i < count; i++) {
|
||||||
|
printf("(%f, %f, %f)\n", (p[i]).x, (p[i]).y, (p[i]).z);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool getmeshheader(struct MeshHeader **hs,
|
||||||
|
unsigned int i,
|
||||||
|
const char * const filedata) {
|
||||||
|
bool done = false;
|
||||||
|
if (hs == NULL || filedata == NULL) {
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
struct Header *h = (struct Header*)filedata;
|
||||||
|
if (h -> numMesh < i) {
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
unsigned int pos = sizeof(struct MeshHeader) * i + sizeof(struct Header);
|
||||||
|
(*hs) = (struct MeshHeader*)(filedata + pos);
|
||||||
|
done = true;
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool getmeshbatch(struct Batch *b,
|
||||||
|
unsigned int offset,
|
||||||
|
const char * const filedata) {
|
||||||
|
bool done = false;
|
||||||
|
if (b == NULL || filedata == NULL) {
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
struct BatchData *d1 = NULL;
|
||||||
|
struct VertexData d2;
|
||||||
|
d1 = (struct BatchData*) (filedata + offset);
|
||||||
|
d2.positions = (struct Coordinate*) (filedata + (d1 -> offsetPositions));
|
||||||
|
d2.normals = (struct Coordinate*) (filedata + (d1 -> offsetNormals));
|
||||||
|
d2.u = (struct UVs*) (filedata + (d1 -> offsetUVs));
|
||||||
|
d2.bi = (struct BoneIndexes*)(filedata + (d1 -> offsetBoneIndexes));
|
||||||
|
d2.bw = (struct BoneWeights*)(filedata + (d1 -> offsetBoneWeights));
|
||||||
|
b -> bd = d1;
|
||||||
|
b -> vd = d2;
|
||||||
|
done = true;
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
|
||||||
|
// assume client has allocated memory for mesh
|
||||||
|
bool getmesh(struct Mesh *m,
|
||||||
|
unsigned int i,
|
||||||
|
const char * const filedata) {
|
||||||
|
bool done = false;
|
||||||
|
if (m == NULL || filedata == NULL || m -> b == NULL) {
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
struct MeshHeader *mh = NULL;
|
||||||
|
bool ok = getmeshheader(&mh, i, filedata);
|
||||||
|
if (ok) {
|
||||||
|
unsigned int j;
|
||||||
|
struct Batch b;
|
||||||
|
for (j = 0; j < mh -> numBatch; j++) {
|
||||||
|
unsigned int offset = mh->offsetBatches + j * sizeof(struct BatchData);
|
||||||
|
getmeshbatch(&b, offset, filedata);
|
||||||
|
printmeshbatch(&b);
|
||||||
|
m -> b[j] = b;
|
||||||
|
}
|
||||||
|
done = true;
|
||||||
|
}
|
||||||
|
return done;
|
||||||
|
}
|
||||||
|
|
27
test/main.c
27
test/main.c
@ -5,6 +5,7 @@
|
|||||||
|
|
||||||
#include "devil1pld.h"
|
#include "devil1pld.h"
|
||||||
#include "devil1tex.h"
|
#include "devil1tex.h"
|
||||||
|
#include "devil1geo.h"
|
||||||
|
|
||||||
|
|
||||||
#define TYPE_ID_LENGTH 4
|
#define TYPE_ID_LENGTH 4
|
||||||
@ -116,13 +117,37 @@ void exporttextures(const char *filedata,
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void extractmeshes(const char *filedata,
|
||||||
|
unsigned int filesize,
|
||||||
|
const char *filename) {
|
||||||
|
if (filedata == NULL || filesize <= 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
struct Header *h = (struct Header*)filedata;
|
||||||
|
struct MeshHeader *mh = NULL;
|
||||||
|
struct Mesh m;
|
||||||
|
m.b = NULL;
|
||||||
|
unsigned int i;
|
||||||
|
for (i = 0; i < h -> numMesh; i++) {
|
||||||
|
getmeshheader(&mh, i, filedata);
|
||||||
|
m.b = (struct Batch*)malloc(sizeof(struct Batch) * (mh -> numBatch));
|
||||||
|
if (m.b != NULL) {
|
||||||
|
getmesh(&m, i, filedata);
|
||||||
|
// do something with mesh e.g write to file.
|
||||||
|
free(m.b);
|
||||||
|
}
|
||||||
|
} // end for
|
||||||
|
}
|
||||||
|
|
||||||
int main(int argc, char ** argv) {
|
int main(int argc, char ** argv) {
|
||||||
char *f = argv[1];
|
char *f = argv[1];
|
||||||
unsigned int bufsize = 0;
|
unsigned int bufsize = 0;
|
||||||
char *buffer = loadfile(f, &bufsize);
|
char *buffer = loadfile(f, &bufsize);
|
||||||
unpackpld(buffer, bufsize, f);
|
// unpackpld(buffer, bufsize, f);
|
||||||
// exporttextures(buffer, bufsize, f);
|
// exporttextures(buffer, bufsize, f);
|
||||||
|
extractmeshes(buffer, bufsize, f);
|
||||||
free(buffer);
|
free(buffer);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user