BGE Py API
[blender.git] / source / blender / python / api2_2x / Mathutils.h
1 /* 
2  * $Id$
3  *
4  * ***** BEGIN GPL LICENSE BLOCK *****
5  *
6  * This program is free software; you can redistribute it and/or
7  * modify it under the terms of the GNU General Public License
8  * as published by the Free Software Foundation; either version 2
9  * of the License, or (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software Foundation,
18  * Inc., 59 Temple Place - Suite 330, Boston, MA        02111-1307, USA.
19  *
20  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
21  * All rights reserved.
22  *
23  * This is a new part of Blender.
24  *
25  * Contributor(s): Joseph Gilbert
26  *
27  * ***** END GPL LICENSE BLOCK *****
28 */
29 //Include this file for access to vector, quat, matrix, euler, etc...
30
31 #ifndef EXPP_Mathutils_H
32 #define EXPP_Mathutils_H
33
34 #include <Python.h>
35 #include "vector.h"
36 #include "matrix.h"
37 #include "quat.h"
38 #include "euler.h"
39 #include "point.h"
40
41 PyObject *Mathutils_Init( const char * from );
42 PyObject *row_vector_multiplication(VectorObject* vec, MatrixObject * mat);
43 PyObject *column_vector_multiplication(MatrixObject * mat, VectorObject* vec);
44 PyObject *row_point_multiplication(PointObject* pt, MatrixObject * mat);
45 PyObject *column_point_multiplication(MatrixObject * mat, PointObject* pt);
46 PyObject *quat_rotation(PyObject *arg1, PyObject *arg2);
47
48 PyObject *M_Mathutils_Rand(PyObject * self, PyObject * args);
49 PyObject *M_Mathutils_Vector(PyObject * self, PyObject * args);
50 PyObject *M_Mathutils_CrossVecs(PyObject * self, PyObject * args);
51 PyObject *M_Mathutils_DotVecs(PyObject * self, PyObject * args);
52 PyObject *M_Mathutils_AngleBetweenVecs(PyObject * self, PyObject * args);
53 PyObject *M_Mathutils_MidpointVecs(PyObject * self, PyObject * args);
54 PyObject *M_Mathutils_ProjectVecs(PyObject * self, PyObject * args);
55 PyObject *M_Mathutils_Matrix(PyObject * self, PyObject * args);
56 PyObject *M_Mathutils_RotationMatrix(PyObject * self, PyObject * args);
57 PyObject *M_Mathutils_TranslationMatrix(PyObject * self, VectorObject * value);
58 PyObject *M_Mathutils_ScaleMatrix(PyObject * self, PyObject * args);
59 PyObject *M_Mathutils_OrthoProjectionMatrix(PyObject * self, PyObject * args);
60 PyObject *M_Mathutils_ShearMatrix(PyObject * self, PyObject * args);
61 PyObject *M_Mathutils_Quaternion(PyObject * self, PyObject * args);
62 PyObject *M_Mathutils_CrossQuats(PyObject * self, PyObject * args);
63 PyObject *M_Mathutils_DotQuats(PyObject * self, PyObject * args);
64 PyObject *M_Mathutils_DifferenceQuats(PyObject * self, PyObject * args);
65 PyObject *M_Mathutils_Slerp(PyObject * self, PyObject * args);
66 PyObject *M_Mathutils_Euler(PyObject * self, PyObject * args);
67 PyObject *M_Mathutils_Intersect( PyObject * self, PyObject * args );
68 PyObject *M_Mathutils_TriangleArea( PyObject * self, PyObject * args );
69 PyObject *M_Mathutils_TriangleNormal( PyObject * self, PyObject * args );
70 PyObject *M_Mathutils_QuadNormal( PyObject * self, PyObject * args );
71 PyObject *M_Mathutils_LineIntersect( PyObject * self, PyObject * args );
72 PyObject *M_Mathutils_Point(PyObject * self, PyObject * args);
73 //DEPRECATED    
74 PyObject *M_Mathutils_CopyMat(PyObject * self, PyObject * args);
75 PyObject *M_Mathutils_CopyVec(PyObject * self, PyObject * args);
76 PyObject *M_Mathutils_CopyQuat(PyObject * self, PyObject * args);
77 PyObject *M_Mathutils_CopyEuler(PyObject * self, PyObject * args);
78 PyObject *M_Mathutils_RotateEuler(PyObject * self, PyObject * args);
79 PyObject *M_Mathutils_MatMultVec(PyObject * self, PyObject * args);
80 PyObject *M_Mathutils_VecMultMat(PyObject * self, PyObject * args);
81
82 #endif                          /* EXPP_Mathutils_H */