2015-06-18 23:05:37 +02:00
|
|
|
#ifndef RW_PS2
|
|
|
|
#include <stdint.h>
|
|
|
|
#endif
|
2016-02-15 10:48:27 +01:00
|
|
|
#include <cmath>
|
2017-07-11 08:18:15 +02:00
|
|
|
#ifndef M_PI
|
|
|
|
#define M_PI 3.14159265358979323846
|
|
|
|
#endif
|
2015-06-18 23:05:37 +02:00
|
|
|
|
2016-06-24 15:24:58 +02:00
|
|
|
#ifdef RW_GL3
|
|
|
|
#define RW_OPENGL
|
2017-08-27 17:13:10 +02:00
|
|
|
#define RWDEVICE gl3
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RW_D3D9
|
|
|
|
#define RWDEVICE d3d
|
2018-05-20 16:55:37 +02:00
|
|
|
#define RWHALFPIXEL
|
2017-08-27 17:13:10 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RW_D3D8
|
|
|
|
#define RWDEVICE d3d
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RW_PS2
|
2018-05-20 16:55:37 +02:00
|
|
|
#define RWHALFPIXEL
|
2017-08-27 17:13:10 +02:00
|
|
|
#define RWDEVICE ps2
|
2016-06-24 15:24:58 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef RW_WDGL
|
|
|
|
#define RW_OPENGL
|
|
|
|
#endif
|
|
|
|
|
2015-01-25 22:27:03 +01:00
|
|
|
namespace rw {
|
2014-12-18 17:26:57 +01:00
|
|
|
|
2015-06-18 23:05:37 +02:00
|
|
|
#ifdef RW_PS2
|
|
|
|
typedef char int8;
|
|
|
|
typedef short int16;
|
|
|
|
typedef int int32;
|
|
|
|
typedef long long int64;
|
|
|
|
typedef unsigned char uint8;
|
|
|
|
typedef unsigned short uint16;
|
|
|
|
typedef unsigned int uint32;
|
|
|
|
typedef unsigned long long uint64;
|
|
|
|
typedef unsigned int uintptr;
|
|
|
|
#else
|
|
|
|
/* get rid of the stupid _t */
|
|
|
|
typedef int8_t int8;
|
|
|
|
typedef int16_t int16;
|
|
|
|
typedef int32_t int32;
|
|
|
|
typedef int64_t int64;
|
|
|
|
typedef uint8_t uint8;
|
|
|
|
typedef uint16_t uint16;
|
|
|
|
typedef uint32_t uint32;
|
|
|
|
typedef uint64_t uint64;
|
|
|
|
typedef uintptr_t uintptr;
|
|
|
|
#endif
|
2015-06-10 22:52:59 +02:00
|
|
|
|
2014-12-18 17:26:57 +01:00
|
|
|
typedef float float32;
|
2014-12-23 11:29:37 +01:00
|
|
|
typedef int32 bool32;
|
2014-12-18 17:26:57 +01:00
|
|
|
typedef uint8 byte;
|
|
|
|
typedef uint32 uint;
|
|
|
|
|
2016-06-17 00:06:37 +02:00
|
|
|
#define nil NULL
|
|
|
|
|
2015-07-11 23:48:11 +02:00
|
|
|
#define nelem(A) (sizeof(A) / sizeof A[0])
|
|
|
|
|
2017-08-29 10:12:56 +02:00
|
|
|
// Lists
|
|
|
|
|
|
|
|
struct LLLink
|
|
|
|
{
|
|
|
|
LLLink *next;
|
|
|
|
LLLink *prev;
|
|
|
|
void init(void){
|
|
|
|
this->next = nil;
|
|
|
|
this->prev = nil;
|
|
|
|
}
|
|
|
|
void remove(void){
|
|
|
|
this->prev->next = this->next;
|
|
|
|
this->next->prev = this->prev;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
#define LLLinkGetData(linkvar,type,entry) \
|
2018-07-13 02:05:00 +02:00
|
|
|
((type*)(((rw::uint8*)(linkvar))-offsetof(type,entry)))
|
2017-08-29 10:12:56 +02:00
|
|
|
|
|
|
|
// Have to be careful since the link might be deleted.
|
|
|
|
#define FORLIST(_link, _list) \
|
|
|
|
for(rw::LLLink *_next = nil, *_link = (_list).link.next; \
|
|
|
|
_next = (_link)->next, (_link) != (_list).end(); \
|
|
|
|
(_link) = _next)
|
|
|
|
|
|
|
|
struct LinkList
|
|
|
|
{
|
|
|
|
LLLink link;
|
|
|
|
void init(void){
|
|
|
|
this->link.next = &this->link;
|
|
|
|
this->link.prev = &this->link;
|
|
|
|
}
|
|
|
|
bool32 isEmpty(void){
|
|
|
|
return this->link.next == &this->link;
|
|
|
|
}
|
|
|
|
void add(LLLink *link){
|
|
|
|
link->next = this->link.next;
|
|
|
|
link->prev = &this->link;
|
|
|
|
this->link.next->prev = link;
|
|
|
|
this->link.next = link;
|
|
|
|
}
|
|
|
|
void append(LLLink *link){
|
|
|
|
link->next = &this->link;
|
|
|
|
link->prev = this->link.prev;
|
|
|
|
this->link.prev->next = link;
|
|
|
|
this->link.prev = link;
|
|
|
|
}
|
|
|
|
LLLink *end(void){
|
|
|
|
return &this->link;
|
|
|
|
}
|
|
|
|
int32 count(void){
|
|
|
|
int32 n = 0;
|
|
|
|
FORLIST(lnk, (*this))
|
|
|
|
n++;
|
|
|
|
return n;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
// Mathematical types
|
|
|
|
|
2016-02-14 20:56:05 +01:00
|
|
|
struct RGBA
|
|
|
|
{
|
|
|
|
uint8 red;
|
|
|
|
uint8 green;
|
|
|
|
uint8 blue;
|
|
|
|
uint8 alpha;
|
|
|
|
};
|
2017-08-29 10:12:56 +02:00
|
|
|
inline RGBA makeRGBA(uint8 r, uint8 g, uint8 b, uint8 a) { RGBA c = { r, g, b, a }; return c; }
|
2017-08-05 01:44:37 +02:00
|
|
|
inline bool32 equal(const RGBA &c1, const RGBA &c2) { return c1.red == c2.red && c1.green == c2.green && c1.blue == c2.blue && c1.alpha == c2.alpha; }
|
2018-05-24 00:53:50 +02:00
|
|
|
#define RWRGBAINT(r, g, b, a) ((uint32)((((a)&0xff)<<24)|(((b)&0xff)<<16)|(((g)&0xff)<<8)|((r)&0xff)))
|
2016-02-14 20:56:05 +01:00
|
|
|
|
|
|
|
struct RGBAf
|
|
|
|
{
|
|
|
|
float32 red;
|
|
|
|
float32 green;
|
|
|
|
float32 blue;
|
|
|
|
float32 alpha;
|
|
|
|
};
|
2017-08-27 17:13:10 +02:00
|
|
|
inline RGBAf makeRGBAf(float32 r, float32 g, float32 b, float32 a) { RGBAf c = { r, g, b, a }; return c; }
|
2017-08-05 01:44:37 +02:00
|
|
|
inline bool32 equal(const RGBAf &c1, const RGBAf &c2) { return c1.red == c2.red && c1.green == c2.green && c1.blue == c2.blue && c1.alpha == c2.alpha; }
|
2017-08-27 17:13:10 +02:00
|
|
|
inline RGBAf add(const RGBAf &a, const RGBAf &b) { return makeRGBAf(a.red+b.red, a.green+b.green, a.blue+b.blue, a.alpha+b.alpha); }
|
|
|
|
inline RGBAf modulate(const RGBAf &a, const RGBAf &b) { return makeRGBAf(a.red*b.red, a.green*b.green, a.blue*b.blue, a.alpha*b.alpha); }
|
|
|
|
inline RGBAf scale(const RGBAf &a, float32 f) { return makeRGBAf(a.red*f, a.green*f, a.blue*f, a.alpha*f); }
|
|
|
|
inline void clamp(RGBAf *a) {
|
|
|
|
if(a->red > 1.0f) a->red = 1.0f;
|
|
|
|
if(a->red < 0.0f) a->red = 0.0f;
|
|
|
|
if(a->green > 1.0f) a->green = 1.0f;
|
|
|
|
if(a->green < 0.0f) a->green = 0.0f;
|
|
|
|
if(a->blue > 1.0f) a->blue = 1.0f;
|
|
|
|
if(a->blue < 0.0f) a->blue = 0.0f;
|
|
|
|
if(a->alpha > 1.0f) a->alpha = 1.0f;
|
|
|
|
if(a->alpha < 0.0f) a->alpha = 0.0f;
|
|
|
|
}
|
2016-02-14 20:56:05 +01:00
|
|
|
|
2016-06-23 16:39:34 +02:00
|
|
|
inline void convColor(RGBA *i, RGBAf *f){
|
|
|
|
int32 c;
|
|
|
|
c = (int32)(f->red*255.0f + 0.5f);
|
|
|
|
i->red = (uint8)c;
|
|
|
|
c = (int32)(f->green*255.0f + 0.5f);
|
|
|
|
i->green = (uint8)c;
|
|
|
|
c = (int32)(f->blue*255.0f + 0.5f);
|
|
|
|
i->blue = (uint8)c;
|
|
|
|
c = (int32)(f->alpha*255.0f + 0.5f);
|
|
|
|
i->alpha = (uint8)c;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void convColor(RGBAf *f, RGBA *i){
|
|
|
|
f->red = i->red/255.0f;
|
|
|
|
f->green = i->green/255.0f;
|
|
|
|
f->blue = i->blue/255.0f;
|
|
|
|
f->alpha = i->alpha/255.0f;
|
|
|
|
}
|
|
|
|
|
2017-08-05 01:44:37 +02:00
|
|
|
struct TexCoords
|
|
|
|
{
|
|
|
|
float32 u, v;
|
|
|
|
};
|
|
|
|
inline bool32 equal(const TexCoords &t1, const TexCoords &t2) { return t1.u == t2.u && t1.v == t2.v; }
|
|
|
|
|
2017-08-04 19:54:03 +02:00
|
|
|
struct V2d;
|
|
|
|
struct V3d;
|
|
|
|
struct Quat;
|
|
|
|
struct Matrix;
|
|
|
|
|
2016-02-14 20:56:05 +01:00
|
|
|
struct V2d
|
|
|
|
{
|
|
|
|
float32 x, y;
|
|
|
|
void set(float32 x, float32 y){
|
|
|
|
this->x = x; this->y = y; }
|
|
|
|
};
|
|
|
|
|
2017-08-04 21:47:15 +02:00
|
|
|
inline V2d makeV2d(float32 x, float32 y) { V2d v = { x, y }; return v; }
|
2017-08-05 01:44:37 +02:00
|
|
|
inline bool32 equal(const V2d &v1, const V2d &v2) { return v1.x == v2.x && v1.y == v2.y; }
|
2017-08-04 21:47:15 +02:00
|
|
|
inline V2d neg(const V2d &a) { return makeV2d(-a.x, -a.y); }
|
|
|
|
inline V2d add(const V2d &a, const V2d &b) { return makeV2d(a.x+b.x, a.y+b.y); }
|
|
|
|
inline V2d sub(const V2d &a, const V2d &b) { return makeV2d(a.x-b.x, a.y-b.y); }
|
|
|
|
inline V2d scale(const V2d &a, float32 r) { return makeV2d(a.x*r, a.y*r); }
|
2016-02-15 10:48:27 +01:00
|
|
|
inline float32 length(const V2d &v) { return sqrt(v.x*v.x + v.y*v.y); }
|
|
|
|
inline V2d normalize(const V2d &v) { return scale(v, 1.0f/length(v)); }
|
|
|
|
|
2016-02-14 20:56:05 +01:00
|
|
|
struct V3d
|
|
|
|
{
|
|
|
|
float32 x, y, z;
|
|
|
|
void set(float32 x, float32 y, float32 z){
|
|
|
|
this->x = x; this->y = y; this->z = z; }
|
2018-05-24 00:53:50 +02:00
|
|
|
static void transformPoints(V3d *out, const V3d *in, int32 n, const Matrix *m);
|
|
|
|
static void transformVectors(V3d *out, const V3d *in, int32 n, const Matrix *m);
|
2016-02-14 20:56:05 +01:00
|
|
|
};
|
|
|
|
|
2017-08-04 21:47:15 +02:00
|
|
|
inline V3d makeV3d(float32 x, float32 y, float32 z) { V3d v = { x, y, z }; return v; }
|
2017-08-05 01:44:37 +02:00
|
|
|
inline bool32 equal(const V3d &v1, const V3d &v2) { return v1.x == v2.x && v1.y == v2.y && v1.z == v2.z; }
|
2017-08-04 21:47:15 +02:00
|
|
|
inline V3d neg(const V3d &a) { return makeV3d(-a.x, -a.y, -a.z); }
|
|
|
|
inline V3d add(const V3d &a, const V3d &b) { return makeV3d(a.x+b.x, a.y+b.y, a.z+b.z); }
|
|
|
|
inline V3d sub(const V3d &a, const V3d &b) { return makeV3d(a.x-b.x, a.y-b.y, a.z-b.z); }
|
|
|
|
inline V3d scale(const V3d &a, float32 r) { return makeV3d(a.x*r, a.y*r, a.z*r); }
|
2016-02-15 10:48:27 +01:00
|
|
|
inline float32 length(const V3d &v) { return sqrt(v.x*v.x + v.y*v.y + v.z*v.z); }
|
|
|
|
inline V3d normalize(const V3d &v) { return scale(v, 1.0f/length(v)); }
|
|
|
|
inline V3d setlength(const V3d &v, float32 l) { return scale(v, l/length(v)); }
|
|
|
|
V3d cross(const V3d &a, const V3d &b);
|
2016-02-16 08:40:19 +01:00
|
|
|
inline float32 dot(const V3d &a, const V3d &b) { return a.x*b.x + a.y*b.y + a.z*b.z; }
|
2016-07-11 20:27:21 +02:00
|
|
|
inline V3d lerp(const V3d &a, const V3d &b, float32 r){
|
2017-08-04 21:47:15 +02:00
|
|
|
return makeV3d(a.x + r*(b.x - a.x),
|
|
|
|
a.y + r*(b.y - a.y),
|
|
|
|
a.z + r*(b.z - a.z));
|
2016-07-11 20:27:21 +02:00
|
|
|
};
|
2016-02-15 10:48:27 +01:00
|
|
|
|
2017-08-05 01:44:37 +02:00
|
|
|
struct V4d
|
|
|
|
{
|
|
|
|
float32 x, y, z, w;
|
|
|
|
};
|
|
|
|
inline bool32 equal(const V4d &v1, const V4d &v2) { return v1.x == v2.x && v1.y == v2.y && v1.z == v2.z && v1.w == v2.w; }
|
|
|
|
|
2017-08-04 21:47:15 +02:00
|
|
|
Quat makeQuat(float32 w, float32 x, float32 y, float32 z);
|
|
|
|
Quat makeQuat(float32 w, const V3d &vec);
|
|
|
|
|
2016-02-14 20:56:05 +01:00
|
|
|
struct Quat
|
|
|
|
{
|
2016-07-11 20:27:21 +02:00
|
|
|
// order is important for streaming
|
|
|
|
float32 x, y, z, w;
|
2017-08-04 21:47:15 +02:00
|
|
|
|
2016-02-15 10:48:27 +01:00
|
|
|
static Quat rotation(float32 angle, const V3d &axis){
|
2017-08-04 21:47:15 +02:00
|
|
|
return makeQuat(cos(angle/2.0f), scale(axis, sin(angle/2.0f))); }
|
2016-02-14 20:56:05 +01:00
|
|
|
void set(float32 w, float32 x, float32 y, float32 z){
|
|
|
|
this->w = w; this->x = x; this->y = y; this->z = z; }
|
2017-08-04 21:47:15 +02:00
|
|
|
V3d vec(void){ return makeV3d(x, y, z); }
|
2016-02-14 20:56:05 +01:00
|
|
|
};
|
|
|
|
|
2017-08-04 21:47:15 +02:00
|
|
|
inline Quat makeQuat(float32 w, float32 x, float32 y, float32 z) { Quat q = { x, y, z, w }; return q; }
|
|
|
|
inline Quat makeQuat(float32 w, const V3d &vec) { Quat q = { vec.x, vec.y, vec.z, w }; return q; }
|
|
|
|
inline Quat add(const Quat &q, const Quat &p) { return makeQuat(q.w+p.w, q.x+p.x, q.y+p.y, q.z+p.z); }
|
|
|
|
inline Quat sub(const Quat &q, const Quat &p) { return makeQuat(q.w-p.w, q.x-p.x, q.y-p.y, q.z-p.z); }
|
|
|
|
inline Quat negate(const Quat &q) { return makeQuat(-q.w, -q.x, -q.y, -q.z); }
|
2016-07-11 20:27:21 +02:00
|
|
|
inline float32 dot(const Quat &q, const Quat &p) { return q.w*p.w + q.x*p.x + q.y*p.y + q.z*p.z; }
|
2017-08-04 21:47:15 +02:00
|
|
|
inline Quat scale(const Quat &q, float32 r) { return makeQuat(q.w*r, q.x*r, q.y*r, q.z*r); }
|
2016-02-15 10:48:27 +01:00
|
|
|
inline float32 length(const Quat &q) { return sqrt(q.w*q.w + q.x*q.x + q.y*q.y + q.z*q.z); }
|
|
|
|
inline Quat normalize(const Quat &q) { return scale(q, 1.0f/length(q)); }
|
2017-08-04 21:47:15 +02:00
|
|
|
inline Quat conj(const Quat &q) { return makeQuat(q.w, -q.x, -q.y, -q.z); }
|
2016-02-15 10:48:27 +01:00
|
|
|
Quat mult(const Quat &q, const Quat &p);
|
2017-08-04 21:47:15 +02:00
|
|
|
inline V3d rotate(const V3d &v, const Quat &q) { return mult(mult(q, makeQuat(0.0f, v)), conj(q)).vec(); }
|
2016-07-11 20:27:21 +02:00
|
|
|
Quat lerp(const Quat &q, const Quat &p, float32 r);
|
|
|
|
Quat slerp(const Quat &q, const Quat &p, float32 a);
|
|
|
|
|
2017-03-16 01:10:01 +01:00
|
|
|
enum CombineOp
|
|
|
|
{
|
|
|
|
COMBINEREPLACE,
|
|
|
|
COMBINEPRECONCAT,
|
2018-07-13 01:09:45 +02:00
|
|
|
COMBINEPOSTCONCAT
|
2017-03-16 01:10:01 +01:00
|
|
|
};
|
2016-02-15 10:48:27 +01:00
|
|
|
|
2017-08-04 19:54:03 +02:00
|
|
|
struct RawMatrix
|
2016-02-14 20:56:05 +01:00
|
|
|
{
|
|
|
|
V3d right;
|
|
|
|
float32 rightw;
|
|
|
|
V3d up;
|
|
|
|
float32 upw;
|
|
|
|
V3d at;
|
|
|
|
float32 atw;
|
|
|
|
V3d pos;
|
2017-08-04 19:54:03 +02:00
|
|
|
float32 posw;;
|
2016-02-14 20:56:05 +01:00
|
|
|
|
2018-01-03 18:02:02 +01:00
|
|
|
static void mult(RawMatrix *dst, RawMatrix *src1, RawMatrix *src2);
|
|
|
|
static void transpose(RawMatrix *dst, RawMatrix *src);
|
|
|
|
static void setIdentity(RawMatrix *dst);
|
2016-02-14 20:56:05 +01:00
|
|
|
};
|
|
|
|
|
2017-08-04 19:54:03 +02:00
|
|
|
struct Matrix
|
2016-02-17 14:26:49 +01:00
|
|
|
{
|
2017-08-04 19:54:03 +02:00
|
|
|
enum Type {
|
|
|
|
TYPENORMAL = 1,
|
|
|
|
TYPEORTHOGONAL = 2,
|
|
|
|
TYPEORTHONORMAL = 3,
|
|
|
|
TYPEMASK = 3
|
|
|
|
};
|
|
|
|
enum Flags {
|
|
|
|
IDENTITY = 0x20000
|
|
|
|
};
|
|
|
|
struct Tolerance {
|
|
|
|
float32 normal;
|
|
|
|
float32 orthogonal;
|
|
|
|
float32 identity;
|
|
|
|
};
|
2016-02-17 14:26:49 +01:00
|
|
|
|
2017-08-04 19:54:03 +02:00
|
|
|
V3d right;
|
|
|
|
uint32 flags;
|
|
|
|
V3d up;
|
|
|
|
uint32 pad1;
|
|
|
|
V3d at;
|
|
|
|
uint32 pad2;
|
|
|
|
V3d pos;
|
|
|
|
uint32 pad3;
|
|
|
|
|
|
|
|
static Matrix *create(void);
|
|
|
|
void destroy(void);
|
2016-02-17 14:26:49 +01:00
|
|
|
void setIdentity(void);
|
2017-08-04 19:54:03 +02:00
|
|
|
void optimize(Tolerance *tolerance = nil);
|
|
|
|
void update(void) { flags &= ~(IDENTITY|TYPEMASK); }
|
2018-05-24 00:53:50 +02:00
|
|
|
static Matrix *mult(Matrix *dst, const Matrix *src1, const Matrix *src2);
|
|
|
|
static Matrix *invert(Matrix *dst, const Matrix *src);
|
|
|
|
static Matrix *transpose(Matrix *dst, const Matrix *src);
|
2017-08-04 19:54:03 +02:00
|
|
|
Matrix *rotate(V3d *axis, float32 angle, CombineOp op);
|
|
|
|
Matrix *rotate(const Quat &q, CombineOp op);
|
|
|
|
Matrix *translate(V3d *translation, CombineOp op);
|
|
|
|
Matrix *scale(V3d *scl, CombineOp op);
|
2017-08-10 00:42:33 +02:00
|
|
|
Matrix *transform(Matrix *mat, CombineOp op);
|
2017-10-22 12:19:00 +02:00
|
|
|
Quat getRotation(void);
|
2017-08-04 19:54:03 +02:00
|
|
|
void lookAt(const V3d &dir, const V3d &up);
|
|
|
|
|
|
|
|
// helper functions. consider private
|
2018-05-24 00:53:50 +02:00
|
|
|
static void mult_(Matrix *dst, const Matrix *src1, const Matrix *src2);
|
|
|
|
static void invertOrthonormal(Matrix *dst, const Matrix *src);
|
|
|
|
static Matrix *invertGeneral(Matrix *dst, const Matrix *src);
|
2017-08-04 19:54:03 +02:00
|
|
|
static void makeRotation(Matrix *dst, V3d *axis, float32 angle);
|
|
|
|
static void makeRotation(Matrix *dst, const Quat &q);
|
|
|
|
private:
|
|
|
|
float32 normalError(void);
|
|
|
|
float32 orthogonalError(void);
|
|
|
|
float32 identityError(void);
|
2016-02-17 14:26:49 +01:00
|
|
|
};
|
|
|
|
|
2017-08-04 19:54:03 +02:00
|
|
|
inline void convMatrix(Matrix *dst, RawMatrix *src){
|
|
|
|
*dst = *(Matrix*)src;
|
|
|
|
dst->optimize();
|
|
|
|
}
|
|
|
|
|
|
|
|
inline void convMatrix(RawMatrix *dst, Matrix *src){
|
|
|
|
*dst = *(RawMatrix*)src;
|
|
|
|
dst->rightw = 0.0;
|
|
|
|
dst->upw = 0.0;
|
|
|
|
dst->atw = 0.0;
|
|
|
|
dst->posw = 1.0;
|
|
|
|
}
|
2016-02-14 20:56:05 +01:00
|
|
|
|
2017-08-21 14:40:19 +02:00
|
|
|
struct Line
|
|
|
|
{
|
|
|
|
V3d start;
|
|
|
|
V3d end;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct Rect
|
|
|
|
{
|
|
|
|
int32 h, w;
|
|
|
|
int32 x, y;
|
|
|
|
};
|
|
|
|
|
2016-02-18 14:29:04 +01:00
|
|
|
struct Sphere
|
|
|
|
{
|
|
|
|
V3d center;
|
|
|
|
float32 radius;
|
|
|
|
};
|
|
|
|
|
2017-03-16 01:10:01 +01:00
|
|
|
struct Plane
|
|
|
|
{
|
|
|
|
V3d normal;
|
|
|
|
float32 distance;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct BBox
|
|
|
|
{
|
|
|
|
V3d sup;
|
|
|
|
V3d inf;
|
|
|
|
|
2018-07-02 07:01:34 +02:00
|
|
|
void initialize(V3d *point);
|
|
|
|
void addPoint(V3d *point);
|
2017-03-16 01:10:01 +01:00
|
|
|
void calculate(V3d *points, int32 n);
|
2018-07-02 07:01:34 +02:00
|
|
|
bool containsPoint(V3d *point);
|
2017-03-16 01:10:01 +01:00
|
|
|
};
|
|
|
|
|
2016-08-21 18:20:27 +02:00
|
|
|
enum PrimitiveType
|
|
|
|
{
|
|
|
|
PRIMTYPENONE = 0,
|
|
|
|
PRIMTYPELINELIST,
|
|
|
|
PRIMTYPEPOLYLINE,
|
|
|
|
PRIMTYPETRILIST,
|
|
|
|
PRIMTYPETRISTRIP,
|
|
|
|
PRIMTYPETRIFAN,
|
2018-07-13 01:09:45 +02:00
|
|
|
PRIMTYPEPOINTLIST
|
2016-08-21 18:20:27 +02:00
|
|
|
};
|
|
|
|
|
2016-06-16 14:08:09 +02:00
|
|
|
/*
|
|
|
|
* Streams
|
|
|
|
*/
|
|
|
|
|
2016-07-19 18:40:10 +02:00
|
|
|
void makePath(char *filename);
|
|
|
|
|
2014-12-27 23:18:10 +01:00
|
|
|
class Stream
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
virtual void close(void) = 0;
|
|
|
|
virtual uint32 write(const void *data, uint32 length) = 0;
|
|
|
|
virtual uint32 read(void *data, uint32 length) = 0;
|
|
|
|
virtual void seek(int32 offset, int32 whence = 1) = 0;
|
|
|
|
virtual uint32 tell(void) = 0;
|
|
|
|
virtual bool eof(void) = 0;
|
|
|
|
int32 writeI8(int8 val);
|
|
|
|
int32 writeU8(uint8 val);
|
|
|
|
int32 writeI16(int16 val);
|
|
|
|
int32 writeU16(uint16 val);
|
|
|
|
int32 writeI32(int32 val);
|
|
|
|
int32 writeU32(uint32 val);
|
|
|
|
int32 writeF32(float32 val);
|
|
|
|
int8 readI8(void);
|
|
|
|
uint8 readU8(void);
|
|
|
|
int16 readI16(void);
|
|
|
|
uint16 readU16(void);
|
|
|
|
int32 readI32(void);
|
|
|
|
uint32 readU32(void);
|
|
|
|
float32 readF32(void);
|
|
|
|
};
|
|
|
|
|
2014-12-30 17:39:39 +01:00
|
|
|
class StreamMemory : public Stream
|
|
|
|
{
|
|
|
|
uint8 *data;
|
|
|
|
uint32 length;
|
|
|
|
uint32 capacity;
|
|
|
|
uint32 position;
|
|
|
|
public:
|
|
|
|
void close(void);
|
|
|
|
uint32 write(const void *data, uint32 length);
|
|
|
|
uint32 read(void *data, uint32 length);
|
2015-01-26 10:15:26 +01:00
|
|
|
void seek(int32 offset, int32 whence = 1);
|
2014-12-30 17:39:39 +01:00
|
|
|
uint32 tell(void);
|
|
|
|
bool eof(void);
|
|
|
|
StreamMemory *open(uint8 *data, uint32 length, uint32 capacity = 0);
|
|
|
|
uint32 getLength(void);
|
|
|
|
|
|
|
|
enum {
|
|
|
|
S_EOF = 0xFFFFFFFF
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2014-12-27 23:18:10 +01:00
|
|
|
class StreamFile : public Stream
|
|
|
|
{
|
|
|
|
FILE *file;
|
|
|
|
public:
|
2017-07-29 16:09:11 +02:00
|
|
|
StreamFile(void) { file = nil; }
|
2014-12-27 23:18:10 +01:00
|
|
|
void close(void);
|
|
|
|
uint32 write(const void *data, uint32 length);
|
|
|
|
uint32 read(void *data, uint32 length);
|
2015-01-26 10:15:26 +01:00
|
|
|
void seek(int32 offset, int32 whence = 1);
|
2014-12-27 23:18:10 +01:00
|
|
|
uint32 tell(void);
|
|
|
|
bool eof(void);
|
|
|
|
StreamFile *open(const char *path, const char *mode);
|
|
|
|
};
|
2014-12-18 17:26:57 +01:00
|
|
|
|
2014-12-20 15:05:34 +01:00
|
|
|
enum Platform
|
|
|
|
{
|
2016-06-25 23:14:18 +02:00
|
|
|
PLATFORM_NULL = 0,
|
2015-07-11 23:48:11 +02:00
|
|
|
// D3D7
|
2016-06-16 15:35:45 +02:00
|
|
|
PLATFORM_GL = 2,
|
2015-07-11 23:48:11 +02:00
|
|
|
// MAC
|
2014-12-20 15:05:34 +01:00
|
|
|
PLATFORM_PS2 = 4,
|
|
|
|
PLATFORM_XBOX = 5,
|
2015-07-11 23:48:11 +02:00
|
|
|
// GAMECUBE
|
|
|
|
// SOFTRAS
|
2014-12-20 15:05:34 +01:00
|
|
|
PLATFORM_D3D8 = 8,
|
2015-07-11 23:48:11 +02:00
|
|
|
PLATFORM_D3D9 = 9,
|
2017-08-24 15:10:34 +02:00
|
|
|
// PSP
|
2016-06-16 14:08:09 +02:00
|
|
|
|
2016-06-16 15:35:45 +02:00
|
|
|
// non-stock-RW platforms
|
|
|
|
|
2017-08-24 15:10:34 +02:00
|
|
|
PLATFORM_WDGL = 11, // WarDrum OpenGL
|
|
|
|
PLATFORM_GL3 = 12, // my GL3 implementation
|
2016-06-16 14:08:09 +02:00
|
|
|
|
2016-01-03 19:45:51 +01:00
|
|
|
NUM_PLATFORMS,
|
|
|
|
|
|
|
|
FOURCC_PS2 = 0x00325350 // 'PS2\0'
|
2014-12-20 15:05:34 +01:00
|
|
|
};
|
|
|
|
|
2016-06-25 23:14:18 +02:00
|
|
|
#define MAKEPLUGINID(v, id) (((v & 0xFFFFFF) << 8) | (id & 0xFF))
|
2018-01-03 18:02:02 +01:00
|
|
|
#define MAKEPIPEID(v, id) (((v & 0xFFFF) << 16) | (id & 0xFFFF))
|
2016-06-25 23:14:18 +02:00
|
|
|
|
|
|
|
enum VendorID
|
|
|
|
{
|
|
|
|
VEND_CORE = 0,
|
|
|
|
VEND_CRITERIONTK = 1,
|
|
|
|
VEND_CRITERIONINT = 4,
|
|
|
|
VEND_CRITERIONWORLD = 5,
|
2017-08-25 14:06:53 +02:00
|
|
|
// Used for rasters (platform-specific)
|
|
|
|
VEND_RASTER = 10,
|
|
|
|
// Used for driver/device allocation tags
|
2018-07-13 01:09:45 +02:00
|
|
|
VEND_DRIVER = 11
|
2016-06-25 23:14:18 +02:00
|
|
|
};
|
|
|
|
|
2017-08-24 15:10:34 +02:00
|
|
|
// TODO: modules (VEND_CRITERIONINT)
|
|
|
|
|
2014-12-18 17:26:57 +01:00
|
|
|
enum PluginID
|
|
|
|
{
|
|
|
|
// Core
|
2016-06-25 23:14:18 +02:00
|
|
|
ID_NAOBJECT = MAKEPLUGINID(VEND_CORE, 0x00),
|
|
|
|
ID_STRUCT = MAKEPLUGINID(VEND_CORE, 0x01),
|
|
|
|
ID_STRING = MAKEPLUGINID(VEND_CORE, 0x02),
|
|
|
|
ID_EXTENSION = MAKEPLUGINID(VEND_CORE, 0x03),
|
|
|
|
ID_CAMERA = MAKEPLUGINID(VEND_CORE, 0x05),
|
|
|
|
ID_TEXTURE = MAKEPLUGINID(VEND_CORE, 0x06),
|
|
|
|
ID_MATERIAL = MAKEPLUGINID(VEND_CORE, 0x07),
|
|
|
|
ID_MATLIST = MAKEPLUGINID(VEND_CORE, 0x08),
|
2017-08-24 15:10:34 +02:00
|
|
|
ID_WORLD = MAKEPLUGINID(VEND_CORE, 0x0B),
|
|
|
|
ID_MATRIX = MAKEPLUGINID(VEND_CORE, 0x0D),
|
2016-06-25 23:14:18 +02:00
|
|
|
ID_FRAMELIST = MAKEPLUGINID(VEND_CORE, 0x0E),
|
|
|
|
ID_GEOMETRY = MAKEPLUGINID(VEND_CORE, 0x0F),
|
|
|
|
ID_CLUMP = MAKEPLUGINID(VEND_CORE, 0x10),
|
|
|
|
ID_LIGHT = MAKEPLUGINID(VEND_CORE, 0x12),
|
|
|
|
ID_ATOMIC = MAKEPLUGINID(VEND_CORE, 0x14),
|
|
|
|
ID_TEXTURENATIVE = MAKEPLUGINID(VEND_CORE, 0x15),
|
|
|
|
ID_TEXDICTIONARY = MAKEPLUGINID(VEND_CORE, 0x16),
|
2017-08-24 15:10:34 +02:00
|
|
|
ID_IMAGE = MAKEPLUGINID(VEND_CORE, 0x18),
|
2016-06-25 23:14:18 +02:00
|
|
|
ID_GEOMETRYLIST = MAKEPLUGINID(VEND_CORE, 0x1A),
|
|
|
|
ID_ANIMANIMATION = MAKEPLUGINID(VEND_CORE, 0x1B),
|
|
|
|
ID_RIGHTTORENDER = MAKEPLUGINID(VEND_CORE, 0x1F),
|
|
|
|
ID_UVANIMDICT = MAKEPLUGINID(VEND_CORE, 0x2B),
|
2014-12-24 23:52:03 +01:00
|
|
|
|
2015-09-09 23:26:16 +02:00
|
|
|
// Toolkit
|
2016-06-25 23:14:18 +02:00
|
|
|
ID_SKYMIPMAP = MAKEPLUGINID(VEND_CRITERIONTK, 0x10),
|
|
|
|
ID_SKIN = MAKEPLUGINID(VEND_CRITERIONTK, 0x16),
|
2017-08-24 15:10:34 +02:00
|
|
|
ID_HANIM = MAKEPLUGINID(VEND_CRITERIONTK, 0x1E),
|
2017-08-23 12:21:23 +02:00
|
|
|
ID_USERDATA = MAKEPLUGINID(VEND_CRITERIONTK, 0x1F),
|
2016-06-25 23:14:18 +02:00
|
|
|
ID_MATFX = MAKEPLUGINID(VEND_CRITERIONTK, 0x20),
|
|
|
|
ID_PDS = MAKEPLUGINID(VEND_CRITERIONTK, 0x31),
|
|
|
|
ID_ADC = MAKEPLUGINID(VEND_CRITERIONTK, 0x34),
|
|
|
|
ID_UVANIMATION = MAKEPLUGINID(VEND_CRITERIONTK, 0x35),
|
2015-09-09 23:26:16 +02:00
|
|
|
|
|
|
|
// World
|
2016-06-25 23:14:18 +02:00
|
|
|
ID_MESH = MAKEPLUGINID(VEND_CRITERIONWORLD, 0x0E),
|
|
|
|
ID_NATIVEDATA = MAKEPLUGINID(VEND_CRITERIONWORLD, 0x10),
|
|
|
|
ID_VERTEXFMT = MAKEPLUGINID(VEND_CRITERIONWORLD, 0x11),
|
|
|
|
|
|
|
|
// custom native raster
|
2017-08-25 14:06:53 +02:00
|
|
|
ID_RASTERGL = MAKEPLUGINID(VEND_RASTER, PLATFORM_GL),
|
|
|
|
ID_RASTERPS2 = MAKEPLUGINID(VEND_RASTER, PLATFORM_PS2),
|
|
|
|
ID_RASTERXBOX = MAKEPLUGINID(VEND_RASTER, PLATFORM_XBOX),
|
|
|
|
ID_RASTERD3D8 = MAKEPLUGINID(VEND_RASTER, PLATFORM_D3D8),
|
|
|
|
ID_RASTERD3D9 = MAKEPLUGINID(VEND_RASTER, PLATFORM_D3D9),
|
|
|
|
ID_RASTERWDGL = MAKEPLUGINID(VEND_RASTER, PLATFORM_WDGL),
|
|
|
|
ID_RASTERGL3 = MAKEPLUGINID(VEND_RASTER, PLATFORM_GL3),
|
|
|
|
|
|
|
|
// anything driver/device related (only as allocation tag)
|
2018-07-13 01:09:45 +02:00
|
|
|
ID_DRIVER = MAKEPLUGINID(VEND_DRIVER, 0)
|
2014-12-18 17:26:57 +01:00
|
|
|
};
|
|
|
|
|
2017-08-26 20:08:23 +02:00
|
|
|
enum CoreModuleID
|
|
|
|
{
|
|
|
|
ID_NAMODULE = MAKEPLUGINID(VEND_CRITERIONINT, 0x00),
|
|
|
|
ID_FRAMEMODULE = MAKEPLUGINID(VEND_CRITERIONINT, 0x03),
|
2018-07-13 01:09:45 +02:00
|
|
|
ID_TEXTUREMODULE = MAKEPLUGINID(VEND_CRITERIONINT, 0x08)
|
2017-08-26 20:08:23 +02:00
|
|
|
};
|
|
|
|
|
2018-07-13 01:09:45 +02:00
|
|
|
#define ECODE(c, s) c
|
2016-06-17 00:06:37 +02:00
|
|
|
|
|
|
|
enum Errors
|
|
|
|
{
|
|
|
|
ERR_NONE = 0x80000000,
|
|
|
|
#include "base.err"
|
|
|
|
};
|
|
|
|
|
|
|
|
#undef ECODE
|
|
|
|
|
2016-07-19 18:40:10 +02:00
|
|
|
extern int32 version;
|
|
|
|
extern int32 build;
|
|
|
|
extern int32 platform;
|
|
|
|
extern bool32 streamAppendFrames;
|
2015-01-25 22:27:03 +01:00
|
|
|
extern char *debugFile;
|
2014-12-18 17:26:57 +01:00
|
|
|
|
2018-01-07 02:12:20 +01:00
|
|
|
int strcmp_ci(const char *s1, const char *s2);
|
2016-02-25 00:30:26 +01:00
|
|
|
int strncmp_ci(const char *s1, const char *s2, int n);
|
|
|
|
|
2015-09-09 23:26:16 +02:00
|
|
|
// 0x04000000 3.1
|
|
|
|
// 0x08000000 3.2
|
|
|
|
// 0x0C000000 3.3
|
|
|
|
// 0x10000000 3.4
|
|
|
|
// 0x14000000 3.5
|
|
|
|
// 0x18000000 3.6
|
|
|
|
// 0x1C000000 3.7
|
|
|
|
|
2014-12-18 17:26:57 +01:00
|
|
|
inline uint32
|
2015-01-25 22:27:03 +01:00
|
|
|
libraryIDPack(int version, int build)
|
2014-12-18 17:26:57 +01:00
|
|
|
{
|
2015-08-17 10:24:24 +02:00
|
|
|
if(version <= 0x31000)
|
2015-08-11 23:40:57 +02:00
|
|
|
return version>>8;
|
|
|
|
return (version-0x30000 & 0x3FF00) << 14 | (version&0x3F) << 16 |
|
|
|
|
(build & 0xFFFF);
|
2014-12-18 17:26:57 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
2015-01-25 22:27:03 +01:00
|
|
|
libraryIDUnpackVersion(uint32 libid)
|
2014-12-18 17:26:57 +01:00
|
|
|
{
|
|
|
|
if(libid & 0xFFFF0000)
|
2015-08-11 23:40:57 +02:00
|
|
|
return (libid>>14 & 0x3FF00) + 0x30000 |
|
|
|
|
(libid>>16 & 0x3F);
|
2014-12-18 17:26:57 +01:00
|
|
|
else
|
|
|
|
return libid<<8;
|
|
|
|
}
|
|
|
|
|
|
|
|
inline int
|
2015-01-25 22:27:03 +01:00
|
|
|
libraryIDUnpackBuild(uint32 libid)
|
2014-12-18 17:26:57 +01:00
|
|
|
{
|
|
|
|
if(libid & 0xFFFF0000)
|
|
|
|
return libid & 0xFFFF;
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
struct ChunkHeaderInfo
|
|
|
|
{
|
|
|
|
uint32 type;
|
|
|
|
uint32 length;
|
|
|
|
uint32 version, build;
|
|
|
|
};
|
|
|
|
|
|
|
|
// TODO?: make these methods of ChunkHeaderInfo?
|
2015-01-25 22:27:03 +01:00
|
|
|
bool writeChunkHeader(Stream *s, int32 type, int32 size);
|
|
|
|
bool readChunkHeaderInfo(Stream *s, ChunkHeaderInfo *header);
|
|
|
|
bool findChunk(Stream *s, uint32 type, uint32 *length, uint32 *version);
|
2014-12-18 17:26:57 +01:00
|
|
|
|
2014-12-19 16:24:29 +01:00
|
|
|
int32 findPointer(void *p, void **list, int32 num);
|
2015-06-18 23:05:37 +02:00
|
|
|
uint8 *getFileContents(char *name, uint32 *len);
|
2014-12-18 17:26:57 +01:00
|
|
|
}
|