Add vec_math module
This commit is contained in:
parent
17a52c4b89
commit
9e7ff8dc4f
@ -15,8 +15,8 @@ CFLAGS += -O0 -g3
|
|||||||
endif
|
endif
|
||||||
|
|
||||||
TARGET = drow-engine
|
TARGET = drow-engine
|
||||||
HEADERS = err.h parser.h types.h print.h filereader.h gl_draw.h
|
HEADERS = err.h parser.h types.h print.h filereader.h gl_draw.h vec_math.h
|
||||||
OBJECTS = main.o parser.o print.o filereader.o gl_draw.o
|
OBJECTS = main.o parser.o print.o filereader.o gl_draw.o vec_math.c
|
||||||
INCS = -I.
|
INCS = -I.
|
||||||
|
|
||||||
CFLAGS += $(shell $(PKG_CONFIG) --cflags gl glu glib-2.0)
|
CFLAGS += $(shell $(PKG_CONFIG) --cflags gl glu glib-2.0)
|
||||||
|
16
src/print.c
16
src/print.c
@ -92,3 +92,19 @@ void print_plain_faces(FACE face, uint32_t fc)
|
|||||||
}
|
}
|
||||||
printf("\n");
|
printf("\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Print all coordinates of a vector.
|
||||||
|
*
|
||||||
|
* @param the vector we want to print
|
||||||
|
*/
|
||||||
|
void print_vector(vector *vec)
|
||||||
|
{
|
||||||
|
printf("vector:\n"
|
||||||
|
"x %f\n"
|
||||||
|
"y %f\n"
|
||||||
|
"z %f\n\n",
|
||||||
|
vec->x,
|
||||||
|
vec->y,
|
||||||
|
vec->z);
|
||||||
|
}
|
||||||
|
@ -27,6 +27,7 @@ void print_edges(HE_obj *obj);
|
|||||||
void print_vertices(HE_obj *obj);
|
void print_vertices(HE_obj *obj);
|
||||||
void print_faces(HE_obj *obj);
|
void print_faces(HE_obj *obj);
|
||||||
void print_plain_faces(FACE face, uint32_t fc);
|
void print_plain_faces(FACE face, uint32_t fc);
|
||||||
|
void print_vector(vector *vec);
|
||||||
|
|
||||||
|
|
||||||
#endif /* _DROW_ENGINE_PRINT_H */
|
#endif /* _DROW_ENGINE_PRINT_H */
|
||||||
|
10
src/types.h
10
src/types.h
@ -30,11 +30,21 @@
|
|||||||
|
|
||||||
typedef uint32_t** FACE;
|
typedef uint32_t** FACE;
|
||||||
|
|
||||||
|
typedef struct vector vector;
|
||||||
typedef struct HE_edge HE_edge;
|
typedef struct HE_edge HE_edge;
|
||||||
typedef struct HE_vert HE_vert;
|
typedef struct HE_vert HE_vert;
|
||||||
typedef struct HE_face HE_face;
|
typedef struct HE_face HE_face;
|
||||||
typedef struct HE_obj HE_obj;
|
typedef struct HE_obj HE_obj;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Represents a vector with x, y, z coordinates.
|
||||||
|
*/
|
||||||
|
struct vector {
|
||||||
|
float x;
|
||||||
|
float y;
|
||||||
|
float z;
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Represents a half-edge.
|
* Represents a half-edge.
|
||||||
*/
|
*/
|
||||||
|
45
src/vec_math.c
Normal file
45
src/vec_math.c
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2011-2014 hasufell
|
||||||
|
*
|
||||||
|
* This file is part of a hasufell project.
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation version 2 of the License only.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "err.h"
|
||||||
|
#include "types.h"
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calculate the vector product of a and b
|
||||||
|
* and store it in c.
|
||||||
|
*
|
||||||
|
* @param a vector
|
||||||
|
* @param b vector
|
||||||
|
* @param c vector [out]
|
||||||
|
* @return true/false for success/failure
|
||||||
|
*/
|
||||||
|
bool vector_product(vector *a, vector *b, vector *c)
|
||||||
|
{
|
||||||
|
if (!a || !b)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
c->x = a->y * b->z - a->z * b->y;
|
||||||
|
c->y = a->z * b->x - a->x * b->z;
|
||||||
|
c->z = a->x * b->y - a->y * b->x;
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
31
src/vec_math.h
Normal file
31
src/vec_math.h
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2011-2014 hasufell
|
||||||
|
*
|
||||||
|
* This file is part of a hasufell project.
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation version 2 of the License only.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _DROW_ENGINE_VEC_MATH_H
|
||||||
|
#define _DROW_ENGINE_VEC_MATH_H
|
||||||
|
|
||||||
|
|
||||||
|
#include "types.h"
|
||||||
|
|
||||||
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
|
||||||
|
bool vector_product(vector *a, vector *b, vector *c);
|
||||||
|
|
||||||
|
|
||||||
|
#endif /* _DROW_ENGINE_VEC_MATH_H */
|
Loading…
Reference in New Issue
Block a user