| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  | /* 
 | 
					
						
							|  |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Joseph Gilbert | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-11-05 01:48:10 +00:00
										 |  |  | /** \file blender/python/mathutils/mathutils_Matrix.h
 | 
					
						
							|  |  |  |  *  \ingroup pymathutils | 
					
						
							| 
									
										
										
										
											2011-02-27 20:10:08 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #ifndef __MATHUTILS_MATRIX_H__
 | 
					
						
							|  |  |  | #define __MATHUTILS_MATRIX_H__
 | 
					
						
							| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | extern PyTypeObject matrix_Type; | 
					
						
							| 
									
										
										
										
											2011-12-24 07:03:19 +00:00
										 |  |  | extern PyTypeObject matrix_access_Type; | 
					
						
							| 
									
										
										
										
											2009-06-30 00:42:17 +00:00
										 |  |  | #define MatrixObject_Check(_v) PyObject_TypeCheck((_v), &matrix_Type)
 | 
					
						
							| 
									
										
										
										
											2010-04-16 08:17:13 +00:00
										 |  |  | #define MATRIX_MAX_DIM 4
 | 
					
						
							| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-19 05:23:52 +00:00
										 |  |  | /* matrix[row][col] == MATRIX_ITEM_INDEX(matrix, row, col) */ | 
					
						
							| 
									
										
										
										
											2011-12-19 03:12:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef DEBUG
 | 
					
						
							| 
									
										
										
										
											2011-12-20 05:48:35 +00:00
										 |  |  | #  define MATRIX_ITEM_ASSERT(_mat, _row, _col) (BLI_assert(_row < (_mat)->num_row && _col < (_mat)->num_col))
 | 
					
						
							| 
									
										
										
										
											2011-12-19 03:12:10 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2011-12-19 05:23:52 +00:00
										 |  |  | #  define MATRIX_ITEM_ASSERT(_mat, _row, _col) (void)0
 | 
					
						
							| 
									
										
										
										
											2011-12-19 03:12:10 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-01 00:19:01 +10:00
										 |  |  | #define MATRIX_ITEM_INDEX_NUMROW(_totrow, _row, _col) (((_totrow) * (_col)) + (_row))
 | 
					
						
							| 
									
										
										
										
											2011-12-20 05:48:35 +00:00
										 |  |  | #define MATRIX_ITEM_INDEX(_mat, _row, _col) (MATRIX_ITEM_ASSERT(_mat, _row, _col),(((_mat)->num_row * (_col)) + (_row)))
 | 
					
						
							| 
									
										
										
										
											2011-12-20 04:11:23 +00:00
										 |  |  | #define MATRIX_ITEM_PTR(  _mat, _row, _col) ((_mat)->matrix + MATRIX_ITEM_INDEX(_mat, _row, _col))
 | 
					
						
							|  |  |  | #define MATRIX_ITEM(      _mat, _row, _col) ((_mat)->matrix  [MATRIX_ITEM_INDEX(_mat, _row, _col)])
 | 
					
						
							| 
									
										
										
										
											2011-12-19 03:12:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-20 05:48:35 +00:00
										 |  |  | #define MATRIX_COL_INDEX(_mat, _col) (MATRIX_ITEM_INDEX(_mat, 0, _col))
 | 
					
						
							|  |  |  | #define MATRIX_COL_PTR(  _mat, _col) ((_mat)->matrix + MATRIX_COL_INDEX(_mat, _col))
 | 
					
						
							| 
									
										
										
										
											2011-12-19 03:12:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-04-16 08:17:13 +00:00
										 |  |  | typedef struct { | 
					
						
							| 
									
										
										
										
											2011-12-20 04:11:23 +00:00
										 |  |  | 	BASE_MATH_MEMBERS(matrix); | 
					
						
							|  |  |  | 	unsigned short num_col; | 
					
						
							|  |  |  | 	unsigned short num_row; | 
					
						
							| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  | } MatrixObject; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-19 05:23:52 +00:00
										 |  |  | /* struct data contains a pointer to the actual data that the
 | 
					
						
							|  |  |  |  * object uses. It can use either PyMem allocated data (which will | 
					
						
							|  |  |  |  * be stored in py_data) or be a wrapper for data allocated through | 
					
						
							|  |  |  |  * blender (stored in blend_data). This is an either/or struct not both */ | 
					
						
							| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-19 05:23:52 +00:00
										 |  |  | /* prototypes */ | 
					
						
							| 
									
										
										
										
											2015-01-04 17:03:54 +11:00
										 |  |  | PyObject *Matrix_CreatePyObject( | 
					
						
							|  |  |  |         const float *mat, | 
					
						
							|  |  |  |         const unsigned short num_col, const unsigned short num_row, | 
					
						
							|  |  |  |         PyTypeObject *base_type | 
					
						
							|  |  |  |         ) ATTR_WARN_UNUSED_RESULT; | 
					
						
							|  |  |  | PyObject *Matrix_CreatePyObject_wrap( | 
					
						
							|  |  |  |         float *mat, | 
					
						
							|  |  |  |         const unsigned short num_col, const unsigned short num_row, | 
					
						
							|  |  |  |         PyTypeObject *base_type | 
					
						
							|  |  |  |         ) ATTR_WARN_UNUSED_RESULT ATTR_NONNULL(1); | 
					
						
							|  |  |  | PyObject *Matrix_CreatePyObject_cb( | 
					
						
							|  |  |  |         PyObject *user, | 
					
						
							|  |  |  |         const unsigned short num_col, const unsigned short num_row, | 
					
						
							|  |  |  |         unsigned char cb_type, unsigned char cb_subtype | 
					
						
							|  |  |  |         ) ATTR_WARN_UNUSED_RESULT; | 
					
						
							| 
									
										
										
										
											2009-06-23 13:34:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-08-19 21:36:50 +10:00
										 |  |  | /* PyArg_ParseTuple's "O&" formatting helpers. */ | 
					
						
							|  |  |  | int Matrix_ParseAny(PyObject *o, void *p); | 
					
						
							|  |  |  | int Matrix_Parse3x3(PyObject *o, void *p); | 
					
						
							|  |  |  | int Matrix_Parse4x4(PyObject *o, void *p); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-17 10:46:02 +00:00
										 |  |  | extern unsigned char mathutils_matrix_row_cb_index; /* default */ | 
					
						
							|  |  |  | extern unsigned char mathutils_matrix_col_cb_index; | 
					
						
							|  |  |  | extern unsigned char mathutils_matrix_translation_cb_index; | 
					
						
							| 
									
										
										
										
											2011-12-26 00:05:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-24 06:13:58 +00:00
										 |  |  | extern struct Mathutils_Callback mathutils_matrix_row_cb; /* default */ | 
					
						
							|  |  |  | extern struct Mathutils_Callback mathutils_matrix_col_cb; | 
					
						
							| 
									
										
										
										
											2011-12-26 00:05:41 +00:00
										 |  |  | extern struct Mathutils_Callback mathutils_matrix_translation_cb; | 
					
						
							| 
									
										
										
										
											2009-06-17 20:33:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-05 09:57:02 +00:00
										 |  |  | void matrix_as_3x3(float mat[3][3], MatrixObject *self); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-17 18:59:41 +00:00
										 |  |  | #endif /* __MATHUTILS_MATRIX_H__ */
 |