| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * 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. | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup edtransform | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include <math.h>
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | #include <stdio.h>
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include <stdlib.h>
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | #include <string.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_object_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							|  |  |  | #include "DNA_screen_types.h"
 | 
					
						
							|  |  |  | #include "DNA_space_types.h"
 | 
					
						
							|  |  |  | #include "DNA_view3d_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-26 12:39:36 -02:00
										 |  |  | #include "GPU_immediate.h"
 | 
					
						
							| 
									
										
										
										
											2017-03-21 16:08:14 -04:00
										 |  |  | #include "GPU_matrix.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-27 19:07:23 -06:00
										 |  |  | #include "GPU_state.h"
 | 
					
						
							| 
									
										
										
										
											2017-01-26 12:39:36 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-10 20:43:45 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2015-03-27 15:23:39 +01:00
										 |  |  | #include "BLI_rect.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "BLI_string.h"
 | 
					
						
							|  |  |  | #include "BLI_utildefines.h"
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-05 17:56:54 +00:00
										 |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-04 07:15:09 +00:00
										 |  |  | #include "ED_view3d.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-16 17:32:01 +10:00
										 |  |  | #include "BLT_translation.h"
 | 
					
						
							| 
									
										
										
										
											2013-02-19 15:45:56 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-10 18:33:16 +00:00
										 |  |  | #include "UI_resources.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | #include "transform.h"
 | 
					
						
							| 
									
										
										
										
											2019-10-29 00:45:05 +11:00
										 |  |  | #include "transform_snap.h"
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-28 21:25:47 -03:00
										 |  |  | /* Own include. */ | 
					
						
							|  |  |  | #include "transform_constraints.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | static void drawObjectConstraint(TransInfo *t); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  | static void projection_matrix_calc(const TransInfo *t, float r_pmtx[3][3]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   unit_m3(r_pmtx); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!(t->con.mode & CON_AXIS0)) { | 
					
						
							|  |  |  |     zero_v3(r_pmtx[0]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!(t->con.mode & CON_AXIS1)) { | 
					
						
							|  |  |  |     zero_v3(r_pmtx[1]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!(t->con.mode & CON_AXIS2)) { | 
					
						
							|  |  |  |     zero_v3(r_pmtx[2]); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   float mat[3][3]; | 
					
						
							|  |  |  |   mul_m3_m3m3(mat, r_pmtx, t->spacemtx_inv); | 
					
						
							|  |  |  |   mul_m3_m3m3(r_pmtx, t->spacemtx, mat); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | /* ************************** CONSTRAINTS ************************* */ | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | #define CONSTRAIN_EPSILON 0.0001f
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void constraint_plane_calc(TransInfo *t, float r_plane[4]) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   const float *constraint_vector[2]; | 
					
						
							|  |  |  |   int n = 0; | 
					
						
							|  |  |  |   for (int i = 0; i < 3; i++) { | 
					
						
							|  |  |  |     if (t->con.mode & (CON_AXIS0 << i)) { | 
					
						
							|  |  |  |       constraint_vector[n++] = t->spacemtx[i]; | 
					
						
							|  |  |  |       if (n == 2) { | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   BLI_assert(n == 2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   cross_v3_v3v3(r_plane, constraint_vector[0], constraint_vector[1]); | 
					
						
							|  |  |  |   normalize_v3(r_plane); | 
					
						
							|  |  |  |   r_plane[3] = -dot_v3v3(r_plane, t->center_global); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | void constraintNumInput(TransInfo *t, float vec[3]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int mode = t->con.mode; | 
					
						
							|  |  |  |   if (mode & CON_APPLY) { | 
					
						
							|  |  |  |     float nval = (t->flag & T_NULL_ONE) ? 1.0f : 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     const int dims = getConstraintSpaceDimension(t); | 
					
						
							|  |  |  |     if (dims == 2) { | 
					
						
							|  |  |  |       int axis = mode & (CON_AXIS0 | CON_AXIS1 | CON_AXIS2); | 
					
						
							|  |  |  |       if (axis == (CON_AXIS0 | CON_AXIS1)) { | 
					
						
							|  |  |  |         /* vec[0] = vec[0]; */ /* same */ | 
					
						
							|  |  |  |         /* vec[1] = vec[1]; */ /* same */ | 
					
						
							|  |  |  |         vec[2] = nval; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (axis == (CON_AXIS1 | CON_AXIS2)) { | 
					
						
							|  |  |  |         vec[2] = vec[1]; | 
					
						
							|  |  |  |         vec[1] = vec[0]; | 
					
						
							|  |  |  |         vec[0] = nval; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (axis == (CON_AXIS0 | CON_AXIS2)) { | 
					
						
							|  |  |  |         /* vec[0] = vec[0]; */ /* same */ | 
					
						
							|  |  |  |         vec[2] = vec[1]; | 
					
						
							|  |  |  |         vec[1] = nval; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (dims == 1) { | 
					
						
							|  |  |  |       if (mode & CON_AXIS0) { | 
					
						
							|  |  |  |         /* vec[0] = vec[0]; */ /* same */ | 
					
						
							|  |  |  |         vec[1] = nval; | 
					
						
							|  |  |  |         vec[2] = nval; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (mode & CON_AXIS1) { | 
					
						
							|  |  |  |         vec[1] = vec[0]; | 
					
						
							|  |  |  |         vec[0] = nval; | 
					
						
							|  |  |  |         vec[2] = nval; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (mode & CON_AXIS2) { | 
					
						
							|  |  |  |         vec[2] = vec[0]; | 
					
						
							|  |  |  |         vec[0] = nval; | 
					
						
							|  |  |  |         vec[1] = nval; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-21 17:24:14 +02:00
										 |  |  | static void viewAxisCorrectCenter(const TransInfo *t, float t_con_center[3]) | 
					
						
							| 
									
										
										
										
											2011-04-29 05:01:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (t->spacetype == SPACE_VIEW3D) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |     // View3D *v3d = t->area->spacedata.first;
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     const float min_dist = 1.0f; /* v3d->clip_start; */ | 
					
						
							|  |  |  |     float dir[3]; | 
					
						
							|  |  |  |     float l; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     sub_v3_v3v3(dir, t_con_center, t->viewinv[3]); | 
					
						
							|  |  |  |     if (dot_v3v3(dir, t->viewinv[2]) < 0.0f) { | 
					
						
							|  |  |  |       negate_v3(dir); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     project_v3_v3v3(dir, dir, t->viewinv[2]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     l = len_v3(dir); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (l < min_dist) { | 
					
						
							|  |  |  |       float diff[3]; | 
					
						
							|  |  |  |       normalize_v3_v3_length(diff, t->viewinv[2], min_dist - l); | 
					
						
							|  |  |  |       sub_v3_v3(t_con_center, diff); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2011-04-29 05:01:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-21 17:24:14 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Axis calculation taking the view into account, correcting view-aligned axis. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static void axisProjection(const TransInfo *t, | 
					
						
							|  |  |  |                            const float axis[3], | 
					
						
							|  |  |  |                            const float in[3], | 
					
						
							|  |  |  |                            float out[3]) | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   float norm[3], vec[3], factor, angle; | 
					
						
							|  |  |  |   float t_con_center[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (is_zero_v3(in)) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   copy_v3_v3(t_con_center, t->center_global); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* checks for center being too close to the view center */ | 
					
						
							|  |  |  |   viewAxisCorrectCenter(t, t_con_center); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   angle = fabsf(angle_v3v3(axis, t->viewinv[2])); | 
					
						
							|  |  |  |   if (angle > (float)M_PI_2) { | 
					
						
							|  |  |  |     angle = (float)M_PI - angle; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* For when view is parallel to constraint... will cause NaNs otherwise
 | 
					
						
							|  |  |  |    * So we take vertical motion in 3D space and apply it to the | 
					
						
							|  |  |  |    * constraint axis. Nice for camera grab + MMB */ | 
					
						
							|  |  |  |   if (angle < DEG2RADF(5.0f)) { | 
					
						
							|  |  |  |     project_v3_v3v3(vec, in, t->viewinv[1]); | 
					
						
							|  |  |  |     factor = dot_v3v3(t->viewinv[1], vec) * 2.0f; | 
					
						
							| 
									
										
										
										
											2019-04-17 08:44:58 +02:00
										 |  |  |     /* Since camera distance is quite relative, use quadratic relationship.
 | 
					
						
							|  |  |  |      * holding shift can compensate. */ | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (factor < 0.0f) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       factor *= -factor; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       factor *= factor; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* -factor makes move down going backwards */ | 
					
						
							|  |  |  |     normalize_v3_v3_length(out, axis, -factor); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							| 
									
										
										
										
											2019-07-23 14:50:59 +10:00
										 |  |  |     float v[3]; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     float norm_center[3]; | 
					
						
							|  |  |  |     float plane[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     getViewVector(t, t_con_center, norm_center); | 
					
						
							|  |  |  |     cross_v3_v3v3(plane, norm_center, axis); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     project_v3_v3v3(vec, in, plane); | 
					
						
							|  |  |  |     sub_v3_v3v3(vec, in, vec); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     add_v3_v3v3(v, vec, t_con_center); | 
					
						
							|  |  |  |     getViewVector(t, v, norm); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* give arbitrary large value if projection is impossible */ | 
					
						
							|  |  |  |     factor = dot_v3v3(axis, norm); | 
					
						
							|  |  |  |     if (1.0f - fabsf(factor) < 0.0002f) { | 
					
						
							|  |  |  |       copy_v3_v3(out, axis); | 
					
						
							|  |  |  |       if (factor > 0) { | 
					
						
							|  |  |  |         mul_v3_fl(out, 1000000000.0f); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         mul_v3_fl(out, -1000000000.0f); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							| 
									
										
										
										
											2019-07-23 14:50:59 +10:00
										 |  |  |       /* Use ray-ray intersection instead of line-line because this gave
 | 
					
						
							|  |  |  |        * precision issues adding small values to large numbers. */ | 
					
						
							|  |  |  |       float mul; | 
					
						
							| 
									
										
										
										
											2019-07-23 08:11:46 -03:00
										 |  |  |       if (isect_ray_ray_v3(t_con_center, axis, v, norm, &mul, NULL)) { | 
					
						
							|  |  |  |         mul_v3_v3fl(out, axis, mul); | 
					
						
							| 
									
										
										
										
											2019-07-23 14:50:59 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         /* In practice this should never fail. */ | 
					
						
							|  |  |  |         BLI_assert(0); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       /* possible some values become nan when
 | 
					
						
							|  |  |  |        * viewpoint and object are both zero */ | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       if (!isfinite(out[0])) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         out[0] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (!isfinite(out[1])) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         out[1] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							|  |  |  |       if (!isfinite(out[2])) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         out[2] = 0.0f; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-01 21:42:39 +11:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |  * Snap to the intersection between the edge direction and the constraint plane. | 
					
						
							| 
									
										
										
										
											2016-02-01 21:42:39 +11:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  | static void constraint_snap_plane_to_edge(const TransInfo *t, const float plane[4], float r_out[3]) | 
					
						
							| 
									
										
										
										
											2016-02-01 21:42:39 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |   float lambda; | 
					
						
							|  |  |  |   const float *edge_snap_point = t->tsnap.snapPoint; | 
					
						
							|  |  |  |   const float *edge_dir = t->tsnap.snapNormal; | 
					
						
							|  |  |  |   bool is_aligned = fabsf(dot_v3v3(edge_dir, plane)) < CONSTRAIN_EPSILON; | 
					
						
							|  |  |  |   if (!is_aligned && isect_ray_plane_v3(edge_snap_point, edge_dir, plane, &lambda, false)) { | 
					
						
							|  |  |  |     madd_v3_v3v3fl(r_out, edge_snap_point, edge_dir, lambda); | 
					
						
							|  |  |  |     sub_v3_v3(r_out, t->tsnap.snapTarget); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Snap to the nearest point between the snap point and the line that | 
					
						
							|  |  |  |  * intersects the face plane with the constraint plane. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  | static void constraint_snap_plane_to_face(const TransInfo *t, const float plane[4], float r_out[3]) | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | { | 
					
						
							|  |  |  |   float face_plane[4], isect_orig[3], isect_dir[3]; | 
					
						
							|  |  |  |   const float *face_snap_point = t->tsnap.snapPoint; | 
					
						
							|  |  |  |   const float *face_normal = t->tsnap.snapNormal; | 
					
						
							|  |  |  |   plane_from_point_normal_v3(face_plane, face_snap_point, face_normal); | 
					
						
							|  |  |  |   bool is_aligned = fabsf(dot_v3v3(plane, face_plane)) > (1.0f - CONSTRAIN_EPSILON); | 
					
						
							|  |  |  |   if (!is_aligned && isect_plane_plane_v3(plane, face_plane, isect_orig, isect_dir)) { | 
					
						
							|  |  |  |     closest_to_ray_v3(r_out, face_snap_point, isect_orig, isect_dir); | 
					
						
							|  |  |  |     sub_v3_v3(r_out, t->tsnap.snapTarget); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Snap to the nearest point on the axis to the edge/line element. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  | void transform_constraint_snap_axis_to_edge(const TransInfo *t, | 
					
						
							|  |  |  |                                             const float axis[3], | 
					
						
							|  |  |  |                                             float r_out[3]) | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | { | 
					
						
							|  |  |  |   float lambda; | 
					
						
							|  |  |  |   const float *edge_snap_point = t->tsnap.snapPoint; | 
					
						
							|  |  |  |   const float *edge_dir = t->tsnap.snapNormal; | 
					
						
							| 
									
										
										
										
											2020-07-01 17:13:13 -03:00
										 |  |  |   bool is_aligned = fabsf(dot_v3v3(axis, edge_dir)) > (1.0f - CONSTRAIN_EPSILON); | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |   if (!is_aligned && | 
					
						
							|  |  |  |       isect_ray_ray_v3(t->tsnap.snapTarget, axis, edge_snap_point, edge_dir, &lambda, NULL)) { | 
					
						
							|  |  |  |     mul_v3_v3fl(r_out, axis, lambda); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Snap to the intersection of the axis and the plane defined by the face. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  | void transform_constraint_snap_axis_to_face(const TransInfo *t, | 
					
						
							|  |  |  |                                             const float axis[3], | 
					
						
							|  |  |  |                                             float r_out[3]) | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | { | 
					
						
							|  |  |  |   float lambda; | 
					
						
							|  |  |  |   float face_plane[4]; | 
					
						
							|  |  |  |   const float *face_snap_point = t->tsnap.snapPoint; | 
					
						
							|  |  |  |   const float *face_normal = t->tsnap.snapNormal; | 
					
						
							|  |  |  |   plane_from_point_normal_v3(face_plane, face_snap_point, face_normal); | 
					
						
							| 
									
										
										
										
											2020-06-22 09:53:33 -03:00
										 |  |  |   bool is_aligned = fabsf(dot_v3v3(axis, face_plane)) < CONSTRAIN_EPSILON; | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |   if (!is_aligned && isect_ray_plane_v3(t->tsnap.snapTarget, axis, face_plane, &lambda, false)) { | 
					
						
							|  |  |  |     mul_v3_v3fl(r_out, axis, lambda); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Return true if the 2x axis are both aligned when projected into the view. | 
					
						
							|  |  |  |  * In this case, we can't usefully project the cursor onto the plane. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-08-07 22:56:13 +10:00
										 |  |  | static bool isPlaneProjectionViewAligned(const TransInfo *t, const float plane[4]) | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | { | 
					
						
							|  |  |  |   const float eps = 0.001f; | 
					
						
							|  |  |  |   float view_to_plane[3]; | 
					
						
							|  |  |  |   getViewVector(t, t->center_global, view_to_plane); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |   float factor = dot_v3v3(plane, view_to_plane); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return fabsf(factor) < eps; | 
					
						
							| 
									
										
										
										
											2016-02-01 21:42:39 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-21 17:24:14 +02:00
										 |  |  | static void planeProjection(const TransInfo *t, const float in[3], float out[3]) | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   float vec[3], factor, norm[3]; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   add_v3_v3v3(vec, in, t->center_global); | 
					
						
							|  |  |  |   getViewVector(t, vec, norm); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   sub_v3_v3v3(vec, out, in); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   factor = dot_v3v3(vec, norm); | 
					
						
							| 
									
										
										
										
											2019-08-12 17:13:23 -03:00
										 |  |  |   if (factor == 0.0f) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return; /* prevent divide by zero */ | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   factor = dot_v3v3(vec, vec) / factor; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   copy_v3_v3(vec, norm); | 
					
						
							|  |  |  |   mul_v3_fl(vec, factor); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   add_v3_v3v3(out, in, vec); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-06-27 05:59:41 +00:00
										 |  |  |  * Generic callback for constant spatial constraints applied to linear motion | 
					
						
							| 
									
										
										
										
											2009-07-12 02:01:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * The IN vector in projected into the constrained space and then further | 
					
						
							|  |  |  |  * projected along the view vector. | 
					
						
							|  |  |  |  * (in perspective mode, the view vector is relative to the position on screen) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-19 18:54:46 -03:00
										 |  |  | static void applyAxisConstraintVec( | 
					
						
							|  |  |  |     TransInfo *t, TransDataContainer *UNUSED(tc), TransData *td, const float in[3], float out[3]) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   copy_v3_v3(out, in); | 
					
						
							|  |  |  |   if (!td && t->con.mode & CON_APPLY) { | 
					
						
							| 
									
										
										
										
											2020-09-11 22:59:21 -03:00
										 |  |  |     bool is_snap_to_point = false, is_snap_to_edge = false, is_snap_to_face = false; | 
					
						
							| 
									
										
										
										
											2020-05-22 14:43:38 -03:00
										 |  |  |     mul_m3_v3(t->con.pmtx, out); | 
					
						
							| 
									
										
										
										
											2020-09-11 22:59:21 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |     if (activeSnap(t)) { | 
					
						
							| 
									
										
										
										
											2020-09-11 22:59:21 -03:00
										 |  |  |       if (validSnap(t)) { | 
					
						
							|  |  |  |         is_snap_to_point = (t->tsnap.snapElem & SCE_SNAP_MODE_VERTEX) != 0; | 
					
						
							|  |  |  |         is_snap_to_edge = (t->tsnap.snapElem & SCE_SNAP_MODE_EDGE) != 0; | 
					
						
							|  |  |  |         is_snap_to_face = (t->tsnap.snapElem & SCE_SNAP_MODE_FACE) != 0; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (t->tsnap.snapElem & SCE_SNAP_MODE_GRID) { | 
					
						
							|  |  |  |         is_snap_to_point = true; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-05-22 14:43:38 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |     /* With snap points, a projection is alright, no adjustments needed. */ | 
					
						
							| 
									
										
										
										
											2020-09-11 22:59:21 -03:00
										 |  |  |     if (!is_snap_to_point || is_snap_to_edge || is_snap_to_face) { | 
					
						
							| 
									
										
										
										
											2020-05-22 14:43:38 -03:00
										 |  |  |       const int dims = getConstraintSpaceDimension(t); | 
					
						
							|  |  |  |       if (dims == 2) { | 
					
						
							|  |  |  |         if (!is_zero_v3(out)) { | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |           float plane[4]; | 
					
						
							|  |  |  |           constraint_plane_calc(t, plane); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (is_snap_to_edge) { | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  |             constraint_snap_plane_to_edge(t, plane, out); | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |           } | 
					
						
							|  |  |  |           else if (is_snap_to_face) { | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  |             constraint_snap_plane_to_face(t, plane, out); | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |           } | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |             /* View alignment correction. */ | 
					
						
							|  |  |  |             if (!isPlaneProjectionViewAligned(t, plane)) { | 
					
						
							|  |  |  |               planeProjection(t, in, out); | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-05-22 14:43:38 -03:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (dims == 1) { | 
					
						
							|  |  |  |         float c[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (t->con.mode & CON_AXIS0) { | 
					
						
							|  |  |  |           copy_v3_v3(c, t->spacemtx[0]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else if (t->con.mode & CON_AXIS1) { | 
					
						
							|  |  |  |           copy_v3_v3(c, t->spacemtx[1]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else if (t->con.mode & CON_AXIS2) { | 
					
						
							|  |  |  |           copy_v3_v3(c, t->spacemtx[2]); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (is_snap_to_edge) { | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  |           transform_constraint_snap_axis_to_edge(t, c, out); | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |         } | 
					
						
							|  |  |  |         else if (is_snap_to_face) { | 
					
						
							| 
									
										
										
										
											2020-06-22 09:07:51 -03:00
										 |  |  |           transform_constraint_snap_axis_to_face(t, c, out); | 
					
						
							| 
									
										
										
										
											2020-06-18 00:00:43 -03:00
										 |  |  |         } | 
					
						
							|  |  |  |         else { | 
					
						
							|  |  |  |           /* View alignment correction. */ | 
					
						
							|  |  |  |           axisProjection(t, c, in, out); | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-05-22 14:43:38 -03:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-11-26 19:47:55 +00:00
										 |  |  |  * Generic callback for object based spatial constraints applied to linear motion | 
					
						
							| 
									
										
										
										
											2009-07-12 02:01:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |  * At first, the following is applied without orientation | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * The IN vector in projected into the constrained space and then further | 
					
						
							|  |  |  |  * projected along the view vector. | 
					
						
							|  |  |  |  * (in perspective mode, the view vector is relative to the position on screen) | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Further down, that vector is mapped to each data's space. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-19 18:54:46 -03:00
										 |  |  | static void applyObjectConstraintVec( | 
					
						
							|  |  |  |     TransInfo *t, TransDataContainer *tc, TransData *td, const float in[3], float out[3]) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-05-22 14:43:38 -03:00
										 |  |  |   if (!td) { | 
					
						
							|  |  |  |     applyAxisConstraintVec(t, tc, td, in, out); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     /* Specific TransData's space. */ | 
					
						
							|  |  |  |     copy_v3_v3(out, in); | 
					
						
							| 
									
										
										
										
											2020-07-29 09:09:34 -03:00
										 |  |  |     if (t->con.mode & CON_APPLY) { | 
					
						
							|  |  |  |       mul_m3_v3(t->spacemtx_inv, out); | 
					
						
							|  |  |  |       mul_m3_v3(td->axismtx, out); | 
					
						
							|  |  |  |       if (t->flag & T_EDIT) { | 
					
						
							|  |  |  |         mul_m3_v3(tc->mat3_unit, out); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-06-27 05:59:41 +00:00
										 |  |  |  * Generic callback for constant spatial constraints applied to resize motion | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static void applyAxisConstraintSize(TransInfo *t, | 
					
						
							|  |  |  |                                     TransDataContainer *UNUSED(tc), | 
					
						
							|  |  |  |                                     TransData *td, | 
					
						
							|  |  |  |                                     float smat[3][3]) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (!td && t->con.mode & CON_APPLY) { | 
					
						
							|  |  |  |     float tmat[3][3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!(t->con.mode & CON_AXIS0)) { | 
					
						
							|  |  |  |       smat[0][0] = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!(t->con.mode & CON_AXIS1)) { | 
					
						
							|  |  |  |       smat[1][1] = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!(t->con.mode & CON_AXIS2)) { | 
					
						
							|  |  |  |       smat[2][2] = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |     mul_m3_m3m3(tmat, smat, t->spacemtx_inv); | 
					
						
							|  |  |  |     mul_m3_m3m3(smat, t->spacemtx, tmat); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-06-27 05:59:41 +00:00
										 |  |  |  * Callback for object based spatial constraints applied to resize motion | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static void applyObjectConstraintSize(TransInfo *t, | 
					
						
							|  |  |  |                                       TransDataContainer *tc, | 
					
						
							|  |  |  |                                       TransData *td, | 
					
						
							|  |  |  |                                       float smat[3][3]) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (td && t->con.mode & CON_APPLY) { | 
					
						
							|  |  |  |     float tmat[3][3]; | 
					
						
							|  |  |  |     float imat[3][3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     invert_m3_m3(imat, td->axismtx); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!(t->con.mode & CON_AXIS0)) { | 
					
						
							|  |  |  |       smat[0][0] = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!(t->con.mode & CON_AXIS1)) { | 
					
						
							|  |  |  |       smat[1][1] = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!(t->con.mode & CON_AXIS2)) { | 
					
						
							|  |  |  |       smat[2][2] = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     mul_m3_m3m3(tmat, smat, imat); | 
					
						
							|  |  |  |     if (t->flag & T_EDIT) { | 
					
						
							|  |  |  |       mul_m3_m3m3(smat, tc->mat3_unit, smat); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     mul_m3_m3m3(smat, td->axismtx, tmat); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-06-27 05:59:41 +00:00
										 |  |  |  * Generic callback for constant spatial constraints applied to rotations | 
					
						
							| 
									
										
										
										
											2009-07-12 02:01:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * The rotation axis is copied into VEC. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * In the case of single axis constraints, the rotation axis is directly the one constrained to. | 
					
						
							|  |  |  |  * For planar constraints (2 axis), the rotation axis is the normal of the plane. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The following only applies when CON_NOFLIP is not set. | 
					
						
							|  |  |  |  * The vector is then modified to always point away from the screen (in global space) | 
					
						
							|  |  |  |  * This insures that the rotation is always logically following the mouse. | 
					
						
							|  |  |  |  * (ie: not doing counterclockwise rotations when the mouse moves clockwise). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static void applyAxisConstraintRot( | 
					
						
							|  |  |  |     TransInfo *t, TransDataContainer *UNUSED(tc), TransData *td, float vec[3], float *angle) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (!td && t->con.mode & CON_APPLY) { | 
					
						
							|  |  |  |     int mode = t->con.mode & (CON_AXIS0 | CON_AXIS1 | CON_AXIS2); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (mode) { | 
					
						
							|  |  |  |       case CON_AXIS0: | 
					
						
							|  |  |  |       case (CON_AXIS1 | CON_AXIS2): | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |         copy_v3_v3(vec, t->spacemtx[0]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         break; | 
					
						
							|  |  |  |       case CON_AXIS1: | 
					
						
							|  |  |  |       case (CON_AXIS0 | CON_AXIS2): | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |         copy_v3_v3(vec, t->spacemtx[1]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         break; | 
					
						
							|  |  |  |       case CON_AXIS2: | 
					
						
							|  |  |  |       case (CON_AXIS0 | CON_AXIS1): | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |         copy_v3_v3(vec, t->spacemtx[2]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* don't flip axis if asked to or if num input */ | 
					
						
							|  |  |  |     if (angle && (mode & CON_NOFLIP) == 0 && hasNumInput(&t->num) == 0) { | 
					
						
							|  |  |  |       if (dot_v3v3(vec, t->viewinv[2]) > 0.0f) { | 
					
						
							|  |  |  |         *angle = -(*angle); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-06-27 05:59:41 +00:00
										 |  |  |  * Callback for object based spatial constraints applied to rotations | 
					
						
							| 
									
										
										
										
											2009-07-12 02:01:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * The rotation axis is copied into VEC. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * In the case of single axis constraints, the rotation axis is directly the one constrained to. | 
					
						
							|  |  |  |  * For planar constraints (2 axis), the rotation axis is the normal of the plane. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The following only applies when CON_NOFLIP is not set. | 
					
						
							|  |  |  |  * The vector is then modified to always point away from the screen (in global space) | 
					
						
							|  |  |  |  * This insures that the rotation is always logically following the mouse. | 
					
						
							|  |  |  |  * (ie: not doing counterclockwise rotations when the mouse moves clockwise). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-16 16:27:55 +02:00
										 |  |  | static void applyObjectConstraintRot( | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     TransInfo *t, TransDataContainer *tc, TransData *td, float vec[3], float *angle) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (t->con.mode & CON_APPLY) { | 
					
						
							|  |  |  |     int mode = t->con.mode & (CON_AXIS0 | CON_AXIS1 | CON_AXIS2); | 
					
						
							|  |  |  |     float tmp_axismtx[3][3]; | 
					
						
							|  |  |  |     float(*axismtx)[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* on setup call, use first object */ | 
					
						
							|  |  |  |     if (td == NULL) { | 
					
						
							|  |  |  |       BLI_assert(tc == NULL); | 
					
						
							|  |  |  |       tc = TRANS_DATA_CONTAINER_FIRST_OK(t); | 
					
						
							|  |  |  |       td = tc->data; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (t->flag & T_EDIT) { | 
					
						
							|  |  |  |       mul_m3_m3m3(tmp_axismtx, tc->mat3_unit, td->axismtx); | 
					
						
							|  |  |  |       axismtx = tmp_axismtx; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       axismtx = td->axismtx; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     switch (mode) { | 
					
						
							|  |  |  |       case CON_AXIS0: | 
					
						
							|  |  |  |       case (CON_AXIS1 | CON_AXIS2): | 
					
						
							|  |  |  |         copy_v3_v3(vec, axismtx[0]); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case CON_AXIS1: | 
					
						
							|  |  |  |       case (CON_AXIS0 | CON_AXIS2): | 
					
						
							|  |  |  |         copy_v3_v3(vec, axismtx[1]); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case CON_AXIS2: | 
					
						
							|  |  |  |       case (CON_AXIS0 | CON_AXIS1): | 
					
						
							|  |  |  |         copy_v3_v3(vec, axismtx[2]); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (angle && (mode & CON_NOFLIP) == 0 && hasNumInput(&t->num) == 0) { | 
					
						
							|  |  |  |       if (dot_v3v3(vec, t->viewinv[2]) > 0.0f) { | 
					
						
							|  |  |  |         *angle = -(*angle); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*--------------------- INTERNAL SETUP CALLS ------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  | void setConstraint(TransInfo *t, int mode, const char text[]) | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_strncpy(t->con.text + 1, text, sizeof(t->con.text) - 1); | 
					
						
							|  |  |  |   t->con.mode = mode; | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |   projection_matrix_calc(t, t->con.pmtx); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   startConstraint(t); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   t->con.drawExtra = NULL; | 
					
						
							|  |  |  |   t->con.applyVec = applyAxisConstraintVec; | 
					
						
							|  |  |  |   t->con.applySize = applyAxisConstraintSize; | 
					
						
							|  |  |  |   t->con.applyRot = applyAxisConstraintRot; | 
					
						
							|  |  |  |   t->redraw = TREDRAW_HARD; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-05-01 05:26:10 +00:00
										 |  |  | /* applies individual td->axismtx constraints */ | 
					
						
							|  |  |  | void setAxisMatrixConstraint(TransInfo *t, int mode, const char text[]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |   BLI_strncpy(t->con.text + 1, text, sizeof(t->con.text) - 1); | 
					
						
							|  |  |  |   t->con.mode = mode; | 
					
						
							|  |  |  |   projection_matrix_calc(t, t->con.pmtx); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |   startConstraint(t); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |   t->con.drawExtra = drawObjectConstraint; | 
					
						
							|  |  |  |   t->con.applyVec = applyObjectConstraintVec; | 
					
						
							|  |  |  |   t->con.applySize = applyObjectConstraintSize; | 
					
						
							|  |  |  |   t->con.applyRot = applyObjectConstraintRot; | 
					
						
							|  |  |  |   t->redraw = TREDRAW_HARD; | 
					
						
							| 
									
										
										
										
											2013-05-01 05:26:10 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | void setLocalConstraint(TransInfo *t, int mode, const char text[]) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (t->flag & T_EDIT) { | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |     /* Although in edit-mode each object has its local space, use the
 | 
					
						
							|  |  |  |      * orientation of the active object. */ | 
					
						
							|  |  |  |     setConstraint(t, mode, text); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     setAxisMatrixConstraint(t, mode, text); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-03-03 16:31:46 +00:00
										 |  |  |  * Set the constraint according to the user defined orientation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ftext is a format string passed to BLI_snprintf. It will add the name of | 
					
						
							|  |  |  |  * the orientation where %s is (logically). | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2020-09-24 19:16:41 -03:00
										 |  |  | void setUserConstraint(TransInfo *t, int mode, const char ftext[]) | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-05-22 14:05:51 -03:00
										 |  |  |   char text[256]; | 
					
						
							| 
									
										
										
										
											2020-09-24 19:16:41 -03:00
										 |  |  |   short orientation = t->orient[t->orient_curr].type; | 
					
						
							|  |  |  |   if (orientation == V3D_ORIENT_CUSTOM_MATRIX) { | 
					
						
							|  |  |  |     /* Use the real value of the "orient_type". */ | 
					
						
							|  |  |  |     orientation = t->orient[0].type; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |   const char *spacename = transform_orientations_spacename_get(t, orientation); | 
					
						
							| 
									
										
										
										
											2020-05-22 14:05:51 -03:00
										 |  |  |   BLI_snprintf(text, sizeof(text), ftext, spacename); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-05 10:04:02 -03:00
										 |  |  |   if (t->modifiers & (MOD_CONSTRAINT_SELECT | MOD_CONSTRAINT_PLANE)) { | 
					
						
							|  |  |  |     /* Force the orientation of the active object.
 | 
					
						
							|  |  |  |      * Although possible, it is not convenient to use the local or axis constraint | 
					
						
							|  |  |  |      * with the modifier to select constraint. | 
					
						
							|  |  |  |      * This also follows the convention of older versions. */ | 
					
						
							|  |  |  |     setConstraint(t, mode, text); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     switch (orientation) { | 
					
						
							|  |  |  |       case V3D_ORIENT_LOCAL: | 
					
						
							|  |  |  |         setLocalConstraint(t, mode, text); | 
					
						
							|  |  |  |         break; | 
					
						
							|  |  |  |       case V3D_ORIENT_NORMAL: | 
					
						
							|  |  |  |         if (checkUseAxisMatrix(t)) { | 
					
						
							|  |  |  |           setAxisMatrixConstraint(t, mode, text); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         ATTR_FALLTHROUGH; | 
					
						
							|  |  |  |       case V3D_ORIENT_GLOBAL: | 
					
						
							|  |  |  |       case V3D_ORIENT_VIEW: | 
					
						
							|  |  |  |       case V3D_ORIENT_CURSOR: | 
					
						
							|  |  |  |       case V3D_ORIENT_GIMBAL: | 
					
						
							|  |  |  |       case V3D_ORIENT_CUSTOM_MATRIX: | 
					
						
							|  |  |  |       case V3D_ORIENT_CUSTOM: | 
					
						
							|  |  |  |       default: { | 
					
						
							|  |  |  |         setConstraint(t, mode, text); | 
					
						
							| 
									
										
										
										
											2020-05-22 14:58:56 -03:00
										 |  |  |         break; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   t->con.mode |= CON_USER; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*----------------- DRAWING CONSTRAINTS -------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-10-16 14:32:17 +00:00
										 |  |  | void drawConstraint(TransInfo *t) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   TransCon *tc = &(t->con); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (!ELEM(t->spacetype, SPACE_VIEW3D, SPACE_IMAGE, SPACE_NODE)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (!(tc->mode & CON_APPLY)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							|  |  |  |   if (t->flag & T_NO_CONSTRAINT) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (tc->drawExtra) { | 
					
						
							|  |  |  |     tc->drawExtra(t); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     if (tc->mode & CON_SELECT) { | 
					
						
							|  |  |  |       float vec[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       convertViewVec(t, vec, (t->mval[0] - t->con.imval[0]), (t->mval[1] - t->con.imval[1])); | 
					
						
							|  |  |  |       add_v3_v3(vec, t->center_global); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |       drawLine(t, t->center_global, t->spacemtx[0], 'X', 0); | 
					
						
							|  |  |  |       drawLine(t, t->center_global, t->spacemtx[1], 'Y', 0); | 
					
						
							|  |  |  |       drawLine(t, t->center_global, t->spacemtx[2], 'Z', 0); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-20 16:38:34 +02:00
										 |  |  |       eGPUDepthTest depth_test_enabled = GPU_depth_test_get(); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       if (depth_test_enabled) { | 
					
						
							| 
									
										
										
										
											2020-08-20 16:38:34 +02:00
										 |  |  |         GPU_depth_test(GPU_DEPTH_NONE); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       const uint shdr_pos = GPU_vertformat_attr_add( | 
					
						
							|  |  |  |           immVertexFormat(), "pos", GPU_COMP_F32, 3, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       immBindBuiltinProgram(GPU_SHADER_3D_LINE_DASHED_UNIFORM_COLOR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       float viewport_size[4]; | 
					
						
							|  |  |  |       GPU_viewport_size_get_f(viewport_size); | 
					
						
							|  |  |  |       immUniform2f("viewport_size", viewport_size[2], viewport_size[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       immUniform1i("colors_len", 0); /* "simple" mode */ | 
					
						
							|  |  |  |       immUniformColor4f(1.0f, 1.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |       immUniform1f("dash_width", 2.0f); | 
					
						
							|  |  |  |       immUniform1f("dash_factor", 0.5f); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       immBegin(GPU_PRIM_LINES, 2); | 
					
						
							|  |  |  |       immVertex3fv(shdr_pos, t->center_global); | 
					
						
							|  |  |  |       immVertex3fv(shdr_pos, vec); | 
					
						
							|  |  |  |       immEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       if (depth_test_enabled) { | 
					
						
							| 
									
										
										
										
											2020-08-20 16:38:34 +02:00
										 |  |  |         GPU_depth_test(GPU_DEPTH_LESS_EQUAL); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (tc->mode & CON_AXIS0) { | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |       drawLine(t, t->center_global, t->spacemtx[0], 'X', DRAWLIGHT); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (tc->mode & CON_AXIS1) { | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |       drawLine(t, t->center_global, t->spacemtx[1], 'Y', DRAWLIGHT); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |     if (tc->mode & CON_AXIS2) { | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |       drawLine(t, t->center_global, t->spacemtx[2], 'Z', DRAWLIGHT); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* called from drawview.c, as an extra per-window draw option */ | 
					
						
							| 
									
										
										
										
											2009-03-28 20:46:38 +00:00
										 |  |  | void drawPropCircle(const struct bContext *C, TransInfo *t) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (t->flag & T_PROP_EDIT) { | 
					
						
							|  |  |  |     RegionView3D *rv3d = CTX_wm_region_view3d(C); | 
					
						
							|  |  |  |     float tmat[4][4], imat[4][4]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (t->spacetype == SPACE_VIEW3D && rv3d != NULL) { | 
					
						
							|  |  |  |       copy_m4_m4(tmat, rv3d->viewmat); | 
					
						
							|  |  |  |       invert_m4_m4(imat, tmat); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       unit_m4(tmat); | 
					
						
							|  |  |  |       unit_m4(imat); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     GPU_matrix_push(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (t->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |       /* pass */ | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (t->spacetype == SPACE_IMAGE) { | 
					
						
							|  |  |  |       GPU_matrix_scale_2f(1.0f / t->aspect[0], 1.0f / t->aspect[1]); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (ELEM(t->spacetype, SPACE_GRAPH, SPACE_ACTION)) { | 
					
						
							|  |  |  |       /* only scale y */ | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |       rcti *mask = &t->region->v2d.mask; | 
					
						
							|  |  |  |       rctf *datamask = &t->region->v2d.cur; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       float xsize = BLI_rctf_size_x(datamask); | 
					
						
							|  |  |  |       float ysize = BLI_rctf_size_y(datamask); | 
					
						
							|  |  |  |       float xmask = BLI_rcti_size_x(mask); | 
					
						
							|  |  |  |       float ymask = BLI_rcti_size_y(mask); | 
					
						
							|  |  |  |       GPU_matrix_scale_2f(1.0f, (ysize / xsize) * (xmask / ymask)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-20 16:38:34 +02:00
										 |  |  |     eGPUDepthTest depth_test_enabled = GPU_depth_test_get(); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (depth_test_enabled) { | 
					
						
							| 
									
										
										
										
											2020-08-20 16:38:34 +02:00
										 |  |  |       GPU_depth_test(GPU_DEPTH_NONE); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     uint pos = GPU_vertformat_attr_add(immVertexFormat(), "pos", GPU_COMP_F32, 3, GPU_FETCH_FLOAT); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-30 18:21:35 +02:00
										 |  |  |     immBindBuiltinProgram(GPU_SHADER_3D_POLYLINE_UNIFORM_COLOR); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-30 18:21:35 +02:00
										 |  |  |     float viewport[4]; | 
					
						
							|  |  |  |     GPU_viewport_size_get_f(viewport); | 
					
						
							| 
									
										
										
										
											2020-08-16 15:38:34 +02:00
										 |  |  |     GPU_blend(GPU_BLEND_ALPHA); | 
					
						
							| 
									
										
										
										
											2020-06-30 18:21:35 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     immUniform2fv("viewportSize", &viewport[2]); | 
					
						
							|  |  |  |     immUniform1f("lineWidth", 3.0f * U.pixelsize); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     immUniformThemeColorShadeAlpha(TH_GRID, -20, 255); | 
					
						
							|  |  |  |     imm_drawcircball(t->center_global, t->prop_size, imat, pos); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     immUniform1f("lineWidth", 1.0f * U.pixelsize); | 
					
						
							|  |  |  |     immUniformThemeColorShadeAlpha(TH_GRID, 20, 255); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     imm_drawcircball(t->center_global, t->prop_size, imat, pos); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     immUnbindProgram(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     if (depth_test_enabled) { | 
					
						
							| 
									
										
										
										
											2020-08-20 16:38:34 +02:00
										 |  |  |       GPU_depth_test(GPU_DEPTH_LESS_EQUAL); | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     GPU_matrix_pop(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2009-01-10 18:33:16 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | static void drawObjectConstraint(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Draw the first one lighter because that's the one who controls the others.
 | 
					
						
							|  |  |  |    * Meaning the transformation is projected on that one and just copied on the others | 
					
						
							|  |  |  |    * constraint space. | 
					
						
							|  |  |  |    * In a nutshell, the object with light axis is controlled by the user and the others follow. | 
					
						
							|  |  |  |    * Without drawing the first light, users have little clue what they are doing. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   short options = DRAWLIGHT; | 
					
						
							|  |  |  |   float tmp_axismtx[3][3]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-21 04:40:16 +10:00
										 |  |  |   FOREACH_TRANS_DATA_CONTAINER (t, tc) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     TransData *td = tc->data; | 
					
						
							| 
									
										
										
										
											2020-09-09 18:41:07 +02:00
										 |  |  |     for (int i = 0; i < tc->data_len; i++, td++) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       float co[3]; | 
					
						
							|  |  |  |       float(*axismtx)[3]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (t->flag & T_PROP_EDIT) { | 
					
						
							|  |  |  |         /* we're sorted, so skip the rest */ | 
					
						
							|  |  |  |         if (td->factor == 0.0f) { | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (t->options & CTX_GPENCIL_STROKES) { | 
					
						
							|  |  |  |         /* only draw a constraint line for one point, otherwise we can't see anything */ | 
					
						
							|  |  |  |         if ((options & DRAWLIGHT) == 0) { | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-30 11:10:07 -03:00
										 |  |  |       if (t->flag & T_EDIT) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         mul_v3_m4v3(co, tc->mat, td->center); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         mul_m3_m3m3(tmp_axismtx, tc->mat3_unit, td->axismtx); | 
					
						
							|  |  |  |         axismtx = tmp_axismtx; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (t->flag & T_POSE) { | 
					
						
							|  |  |  |         mul_v3_m4v3(co, tc->mat, td->center); | 
					
						
							|  |  |  |         axismtx = td->axismtx; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         copy_v3_v3(co, td->center); | 
					
						
							|  |  |  |         axismtx = td->axismtx; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (t->con.mode & CON_AXIS0) { | 
					
						
							|  |  |  |         drawLine(t, co, axismtx[0], 'X', options); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (t->con.mode & CON_AXIS1) { | 
					
						
							|  |  |  |         drawLine(t, co, axismtx[1], 'Y', options); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (t->con.mode & CON_AXIS2) { | 
					
						
							|  |  |  |         drawLine(t, co, axismtx[2], 'Z', options); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       options &= ~DRAWLIGHT; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*--------------------- START / STOP CONSTRAINTS ---------------------- */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | void startConstraint(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   t->con.mode |= CON_APPLY; | 
					
						
							|  |  |  |   *t->con.text = ' '; | 
					
						
							|  |  |  |   t->num.idx_max = min_ii(getConstraintSpaceDimension(t) - 1, t->idx_max); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | void stopConstraint(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-09-03 17:57:58 -03:00
										 |  |  |   if (t->orient_curr != 0) { | 
					
						
							|  |  |  |     t->orient_curr = 0; | 
					
						
							|  |  |  |     transform_orientations_current_set(t, t->orient_curr); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   t->con.mode &= ~(CON_APPLY | CON_SELECT); | 
					
						
							|  |  |  |   *t->con.text = '\0'; | 
					
						
							|  |  |  |   t->num.idx_max = t->idx_max; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*------------------------- MMB Select -------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-31 15:19:29 -03:00
										 |  |  | void initSelectConstraint(TransInfo *t) | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-05-31 15:19:29 -03:00
										 |  |  |   if (t->orient_curr == 0) { | 
					
						
							| 
									
										
										
										
											2020-09-24 19:16:41 -03:00
										 |  |  |     transform_orientations_current_set(t, 1); | 
					
						
							| 
									
										
										
										
											2020-04-29 08:07:25 -03:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-24 19:16:41 -03:00
										 |  |  |   setUserConstraint(t, CON_APPLY | CON_SELECT, "%s"); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   setNearestAxis(t); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | void selectConstraint(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (t->con.mode & CON_SELECT) { | 
					
						
							|  |  |  |     setNearestAxis(t); | 
					
						
							|  |  |  |     startConstraint(t); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void postSelectConstraint(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (!(t->con.mode & CON_SELECT)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   t->con.mode &= ~CON_AXIS0; | 
					
						
							|  |  |  |   t->con.mode &= ~CON_AXIS1; | 
					
						
							|  |  |  |   t->con.mode &= ~CON_AXIS2; | 
					
						
							|  |  |  |   t->con.mode &= ~CON_SELECT; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   setNearestAxis(t); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   startConstraint(t); | 
					
						
							|  |  |  |   t->redraw = TREDRAW_HARD; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void setNearestAxis2d(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* no correction needed... just use whichever one is lower */ | 
					
						
							|  |  |  |   if (abs(t->mval[0] - t->con.imval[0]) < abs(t->mval[1] - t->con.imval[1])) { | 
					
						
							|  |  |  |     t->con.mode |= CON_AXIS1; | 
					
						
							| 
									
										
										
										
											2019-06-11 22:25:01 +02:00
										 |  |  |     BLI_strncpy(t->con.text, TIP_(" along Y axis"), sizeof(t->con.text)); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     t->con.mode |= CON_AXIS0; | 
					
						
							| 
									
										
										
										
											2019-06-11 22:25:01 +02:00
										 |  |  |     BLI_strncpy(t->con.text, TIP_(" along X axis"), sizeof(t->con.text)); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void setNearestAxis3d(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   float zfac; | 
					
						
							|  |  |  |   float mvec[3], proj[3]; | 
					
						
							|  |  |  |   float len[3]; | 
					
						
							|  |  |  |   int i; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* calculate mouse movement */ | 
					
						
							|  |  |  |   mvec[0] = (float)(t->mval[0] - t->con.imval[0]); | 
					
						
							|  |  |  |   mvec[1] = (float)(t->mval[1] - t->con.imval[1]); | 
					
						
							|  |  |  |   mvec[2] = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* We need to correct axis length for the current zoom-level of view,
 | 
					
						
							|  |  |  |    * this to prevent projected values to be clipped behind the camera | 
					
						
							|  |  |  |    * and to overflow the short integers. | 
					
						
							|  |  |  |    * The formula used is a bit stupid, just a simplification of the subtraction | 
					
						
							|  |  |  |    * of two 2D points 30 pixels apart (that's the last factor in the formula) after | 
					
						
							|  |  |  |    * projecting them with ED_view3d_win_to_delta and then get the length of that vector. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   zfac = mul_project_m4_v3_zfac(t->persmat, t->center_global); | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |   zfac = len_v3(t->persinv[0]) * 2.0f / t->region->winx * zfac * 30.0f; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   for (i = 0; i < 3; i++) { | 
					
						
							|  |  |  |     float axis[3], axis_2d[2]; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |     copy_v3_v3(axis, t->spacemtx[i]); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     mul_v3_fl(axis, zfac); | 
					
						
							|  |  |  |     /* now we can project to get window coordinate */ | 
					
						
							|  |  |  |     add_v3_v3(axis, t->center_global); | 
					
						
							|  |  |  |     projectFloatView(t, axis, axis_2d); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     sub_v2_v2v2(axis, axis_2d, t->center2d); | 
					
						
							|  |  |  |     axis[2] = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (normalize_v3(axis) > 1e-3f) { | 
					
						
							|  |  |  |       project_v3_v3v3(proj, mvec, axis); | 
					
						
							|  |  |  |       sub_v3_v3v3(axis, mvec, proj); | 
					
						
							|  |  |  |       len[i] = normalize_v3(axis); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       len[i] = 1e10f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (len[0] <= len[1] && len[0] <= len[2]) { | 
					
						
							| 
									
										
										
										
											2020-09-23 10:45:47 -03:00
										 |  |  |     if (t->modifiers & MOD_CONSTRAINT_PLANE) { | 
					
						
							|  |  |  |       t->con.mode |= (CON_AXIS1 | CON_AXIS2); | 
					
						
							|  |  |  |       BLI_snprintf(t->con.text, sizeof(t->con.text), TIP_(" locking %s X axis"), t->spacename); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       t->con.mode |= CON_AXIS0; | 
					
						
							|  |  |  |       BLI_snprintf(t->con.text, sizeof(t->con.text), TIP_(" along %s X axis"), t->spacename); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |   else if (len[1] <= len[0] && len[1] <= len[2]) { | 
					
						
							| 
									
										
										
										
											2020-09-23 10:45:47 -03:00
										 |  |  |     if (t->modifiers & MOD_CONSTRAINT_PLANE) { | 
					
						
							|  |  |  |       t->con.mode |= (CON_AXIS0 | CON_AXIS2); | 
					
						
							|  |  |  |       BLI_snprintf(t->con.text, sizeof(t->con.text), TIP_(" locking %s Y axis"), t->spacename); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       t->con.mode |= CON_AXIS1; | 
					
						
							|  |  |  |       BLI_snprintf(t->con.text, sizeof(t->con.text), TIP_(" along %s Y axis"), t->spacename); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  |   else if (len[2] <= len[1] && len[2] <= len[0]) { | 
					
						
							| 
									
										
										
										
											2020-09-23 10:45:47 -03:00
										 |  |  |     if (t->modifiers & MOD_CONSTRAINT_PLANE) { | 
					
						
							|  |  |  |       t->con.mode |= (CON_AXIS0 | CON_AXIS1); | 
					
						
							|  |  |  |       BLI_snprintf(t->con.text, sizeof(t->con.text), TIP_(" locking %s Z axis"), t->spacename); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       t->con.mode |= CON_AXIS2; | 
					
						
							|  |  |  |       BLI_snprintf(t->con.text, sizeof(t->con.text), TIP_(" along %s Z axis"), t->spacename); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void setNearestAxis(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* clear any prior constraint flags */ | 
					
						
							|  |  |  |   t->con.mode &= ~CON_AXIS0; | 
					
						
							|  |  |  |   t->con.mode &= ~CON_AXIS1; | 
					
						
							|  |  |  |   t->con.mode &= ~CON_AXIS2; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* constraint setting - depends on spacetype */ | 
					
						
							|  |  |  |   if (t->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |     /* 3d-view */ | 
					
						
							|  |  |  |     setNearestAxis3d(t); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   else { | 
					
						
							|  |  |  |     /* assume that this means a 2D-Editor */ | 
					
						
							|  |  |  |     setNearestAxis2d(t); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-05-22 12:34:29 -03:00
										 |  |  |   projection_matrix_calc(t, t->con.pmtx); | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*-------------- HELPER FUNCTIONS ----------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-26 20:17:40 +11:00
										 |  |  | int constraintModeToIndex(const TransInfo *t) | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if ((t->con.mode & CON_APPLY) == 0) { | 
					
						
							|  |  |  |     return -1; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   switch (t->con.mode & (CON_AXIS0 | CON_AXIS1 | CON_AXIS2)) { | 
					
						
							|  |  |  |     case (CON_AXIS0): | 
					
						
							|  |  |  |     case (CON_AXIS1 | CON_AXIS2): | 
					
						
							|  |  |  |       return 0; | 
					
						
							|  |  |  |     case (CON_AXIS1): | 
					
						
							|  |  |  |     case (CON_AXIS0 | CON_AXIS2): | 
					
						
							|  |  |  |       return 1; | 
					
						
							|  |  |  |     case (CON_AXIS2): | 
					
						
							|  |  |  |     case (CON_AXIS0 | CON_AXIS1): | 
					
						
							|  |  |  |       return 2; | 
					
						
							|  |  |  |     default: | 
					
						
							|  |  |  |       return -1; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-26 20:17:40 +11:00
										 |  |  | char constraintModeToChar(const TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int index = constraintModeToIndex(t); | 
					
						
							|  |  |  |   if (index == -1) { | 
					
						
							|  |  |  |     return '\0'; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   BLI_assert((uint)index < 3); | 
					
						
							|  |  |  |   return 'X' + index; | 
					
						
							| 
									
										
										
										
											2019-02-26 20:17:40 +11:00
										 |  |  | } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-04 09:20:46 +00:00
										 |  |  | bool isLockConstraint(TransInfo *t) | 
					
						
							| 
									
										
										
										
											2011-12-17 00:52:36 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int mode = t->con.mode; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if ((mode & (CON_AXIS0 | CON_AXIS1)) == (CON_AXIS0 | CON_AXIS1)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if ((mode & (CON_AXIS1 | CON_AXIS2)) == (CON_AXIS1 | CON_AXIS2)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if ((mode & (CON_AXIS0 | CON_AXIS2)) == (CON_AXIS0 | CON_AXIS2)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     return true; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return false; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * Returns the dimension of the constraint space. | 
					
						
							| 
									
										
										
										
											2009-07-12 02:01:13 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  |  * For that reason, the flags always needs to be set to properly evaluate here, | 
					
						
							|  |  |  |  * even if they aren't actually used in the callback function. (Which could happen | 
					
						
							|  |  |  |  * for weird constraints not yet designed. Along a path for example.) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int getConstraintSpaceDimension(TransInfo *t) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   int n = 0; | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (t->con.mode & CON_AXIS0) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     n++; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (t->con.mode & CON_AXIS1) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     n++; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   if (t->con.mode & CON_AXIS2) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     n++; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:19:45 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   return n; | 
					
						
							|  |  |  |   /*
 | 
					
						
							| 
									
										
										
										
											2019-04-18 07:21:26 +02:00
										 |  |  |    * Someone willing to do it cryptically could do the following instead: | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * return t->con & (CON_AXIS0|CON_AXIS1|CON_AXIS2); | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * Based on the assumptions that the axis flags are one after the other and start at 1 | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
											
												2.5
Transform:
First working port of the transform code:
- Object mode only (other conversions need to be ported)
- Contraints (global and local only) working
- Snap (no edit mode, obviously) working
- Numinput working
- Gears (Ctrl and Shift) working
- Only grap, rotate, scale, shear, warp and to sphere have been added as hotkey, but the rest should work too once accessible
- No manipulator
- No drawn feedback other than moving stuff and header print (no constraint line, snap circle, ...)
- No NDOF support
I've only tested Scons support, though Makefil *should* work, I *think*.
Misc:
-QuatIsNull function in arith
-Exporting project_* and view[line|ray] functions from view3d
											
										 
											2008-12-29 01:41:28 +00:00
										 |  |  | } |