| 
									
										
										
										
											2011-02-23 10:52:22 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							| 
									
										
										
										
											2010-02-12 13:34:04 +00:00
										 |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Blender Foundation | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-27 20:29:51 +00:00
										 |  |  | /** \file blender/editors/object/object_lattice.c
 | 
					
						
							|  |  |  |  *  \ingroup edobj | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  | #include <string.h>
 | 
					
						
							|  |  |  | #include <math.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_listbase.h"
 | 
					
						
							| 
									
										
										
										
											2011-11-07 01:38:32 +00:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2011-01-07 18:36:47 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | #include "DNA_curve_types.h"
 | 
					
						
							|  |  |  | #include "DNA_key_types.h"
 | 
					
						
							|  |  |  | #include "DNA_lattice_types.h"
 | 
					
						
							|  |  |  | #include "DNA_meshdata_types.h"
 | 
					
						
							|  |  |  | #include "DNA_object_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | #include "RNA_access.h"
 | 
					
						
							| 
									
										
										
										
											2012-10-13 10:42:38 +00:00
										 |  |  | #include "RNA_define.h"
 | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | #include "BKE_context.h"
 | 
					
						
							|  |  |  | #include "BKE_depsgraph.h"
 | 
					
						
							|  |  |  | #include "BKE_key.h"
 | 
					
						
							|  |  |  | #include "BKE_lattice.h"
 | 
					
						
							| 
									
										
										
										
											2012-12-28 09:06:48 +00:00
										 |  |  | #include "BKE_deform.h"
 | 
					
						
							| 
									
										
										
										
											2013-03-16 16:11:50 +00:00
										 |  |  | #include "BKE_report.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | #include "ED_lattice.h"
 | 
					
						
							|  |  |  | #include "ED_object.h"
 | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | #include "ED_screen.h"
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | #include "ED_view3d.h"
 | 
					
						
							|  |  |  | #include "ED_util.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "WM_api.h"
 | 
					
						
							|  |  |  | #include "WM_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "object_intern.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | /********************** Load/Make/Free ********************/ | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void free_editLatt(Object *ob) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	Lattice *lt = ob->data; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (lt->editlatt) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		Lattice *editlt = lt->editlatt->latt; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (editlt->def) | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 			MEM_freeN(editlt->def); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (editlt->dvert) | 
					
						
							| 
									
										
										
										
											2012-12-28 09:06:48 +00:00
										 |  |  | 			BKE_defvert_array_free(editlt->dvert, editlt->pntsu * editlt->pntsv * editlt->pntsw); | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		MEM_freeN(editlt); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		MEM_freeN(lt->editlatt); | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt->editlatt = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void make_editLatt(Object *obedit) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	Lattice *lt = obedit->data; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	KeyBlock *actkey; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	free_editLatt(obedit); | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-09-19 10:12:07 +00:00
										 |  |  | 	actkey = BKE_keyblock_from_object(obedit); | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (actkey) | 
					
						
							| 
									
										
										
										
											2012-09-19 10:12:07 +00:00
										 |  |  | 		BKE_key_convert_to_lattice(actkey, lt); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	lt->editlatt = MEM_callocN(sizeof(EditLatt), "editlatt"); | 
					
						
							|  |  |  | 	lt->editlatt->latt = MEM_dupallocN(lt); | 
					
						
							|  |  |  | 	lt->editlatt->latt->def = MEM_dupallocN(lt->def); | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (lt->dvert) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		int tot = lt->pntsu * lt->pntsv * lt->pntsw; | 
					
						
							| 
									
										
										
										
											2012-06-17 09:58:26 +00:00
										 |  |  | 		lt->editlatt->latt->dvert = MEM_mallocN(sizeof(MDeformVert) * tot, "Lattice MDeformVert"); | 
					
						
							| 
									
										
										
										
											2012-12-28 09:06:48 +00:00
										 |  |  | 		BKE_defvert_array_copy(lt->editlatt->latt->dvert, lt->dvert, tot); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	if (lt->key) lt->editlatt->shapenr = obedit->shapenr; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void load_editLatt(Object *obedit) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 	Lattice *lt, *editlt; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	KeyBlock *actkey; | 
					
						
							|  |  |  | 	BPoint *bp; | 
					
						
							|  |  |  | 	float *fp; | 
					
						
							|  |  |  | 	int tot; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	lt = obedit->data; | 
					
						
							|  |  |  | 	editlt = lt->editlatt->latt; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (lt->editlatt->shapenr) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		actkey = BLI_findlink(<->key->block, lt->editlatt->shapenr - 1); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		/* active key: vertices */ | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		tot = editlt->pntsu * editlt->pntsv * editlt->pntsw; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		if (actkey->data) MEM_freeN(actkey->data); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		fp = actkey->data = MEM_callocN(lt->key->elemsize * tot, "actkey->data"); | 
					
						
							|  |  |  | 		actkey->totelem = tot; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		bp = editlt->def; | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		while (tot--) { | 
					
						
							| 
									
										
										
										
											2011-11-07 01:38:32 +00:00
										 |  |  | 			copy_v3_v3(fp, bp->vec); | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 			fp += 3; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 			bp++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		MEM_freeN(lt->def); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt->def = MEM_dupallocN(editlt->def); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt->flag = editlt->flag; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt->pntsu = editlt->pntsu; | 
					
						
							|  |  |  | 		lt->pntsv = editlt->pntsv; | 
					
						
							|  |  |  | 		lt->pntsw = editlt->pntsw; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt->typeu = editlt->typeu; | 
					
						
							|  |  |  | 		lt->typev = editlt->typev; | 
					
						
							|  |  |  | 		lt->typew = editlt->typew; | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 		lt->actbp = editlt->actbp; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (lt->dvert) { | 
					
						
							| 
									
										
										
										
											2012-12-28 09:06:48 +00:00
										 |  |  | 		BKE_defvert_array_free(lt->dvert, lt->pntsu * lt->pntsv * lt->pntsw); | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt->dvert = NULL; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (editlt->dvert) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		tot = lt->pntsu * lt->pntsv * lt->pntsw; | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-17 09:58:26 +00:00
										 |  |  | 		lt->dvert = MEM_mallocN(sizeof(MDeformVert) * tot, "Lattice MDeformVert"); | 
					
						
							| 
									
										
										
										
											2012-12-28 09:06:48 +00:00
										 |  |  | 		BKE_defvert_array_copy(lt->dvert, editlt->dvert, tot); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-13 10:42:38 +00:00
										 |  |  | /************************** Select All Operator *************************/ | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | void ED_setflagsLatt(Object *obedit, int flag) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	Lattice *lt = obedit->data; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	BPoint *bp; | 
					
						
							|  |  |  | 	int a; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	bp = lt->editlatt->latt->def; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	a = lt->editlatt->latt->pntsu * lt->editlatt->latt->pntsv * lt->editlatt->latt->pntsw; | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 	lt->editlatt->latt->actbp = LT_ACTBP_NONE; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	while (a--) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		if (bp->hide == 0) { | 
					
						
							|  |  |  | 			bp->f1 = flag; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		bp++; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-10-28 03:02:09 +00:00
										 |  |  | static int lattice_select_all_exec(bContext *C, wmOperator *op) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	Object *obedit = CTX_data_edit_object(C); | 
					
						
							|  |  |  | 	Lattice *lt = obedit->data; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	BPoint *bp; | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 	int a; | 
					
						
							|  |  |  | 	int action = RNA_enum_get(op->ptr, "action"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (action == SEL_TOGGLE) { | 
					
						
							|  |  |  | 		action = SEL_SELECT; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		bp = lt->editlatt->latt->def; | 
					
						
							|  |  |  | 		a = lt->editlatt->latt->pntsu * lt->editlatt->latt->pntsv * lt->editlatt->latt->pntsw; | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 		while (a--) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 			if (bp->hide == 0) { | 
					
						
							| 
									
										
										
										
											2012-07-19 11:40:25 +00:00
										 |  |  | 				if (bp->f1 & SELECT) { | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 					action = SEL_DESELECT; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 			bp++; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 	switch (action) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		case SEL_SELECT: | 
					
						
							|  |  |  | 			ED_setflagsLatt(obedit, 1); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case SEL_DESELECT: | 
					
						
							|  |  |  | 			ED_setflagsLatt(obedit, 0); | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case SEL_INVERT: | 
					
						
							|  |  |  | 			bp = lt->editlatt->latt->def; | 
					
						
							|  |  |  | 			a = lt->editlatt->latt->pntsu * lt->editlatt->latt->pntsv * lt->editlatt->latt->pntsw; | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 			lt->editlatt->latt->actbp = LT_ACTBP_NONE; | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			while (a--) { | 
					
						
							|  |  |  | 				if (bp->hide == 0) { | 
					
						
							| 
									
										
										
										
											2012-07-19 11:40:25 +00:00
										 |  |  | 					bp->f1 ^= SELECT; | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 				bp++; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 			break; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_GEOM | ND_SELECT, obedit->data); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | void LATTICE_OT_select_all(wmOperatorType *ot) | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							| 
									
										
										
										
											2012-03-22 07:26:09 +00:00
										 |  |  | 	ot->name = "(De)select All"; | 
					
						
							|  |  |  | 	ot->description = "Change selection of all UVW control points"; | 
					
						
							|  |  |  | 	ot->idname = "LATTICE_OT_select_all"; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							| 
									
										
										
										
											2012-03-22 07:26:09 +00:00
										 |  |  | 	ot->exec = lattice_select_all_exec; | 
					
						
							|  |  |  | 	ot->poll = ED_operator_editlattice; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO; | 
					
						
							| 
									
										
										
										
											2009-11-29 22:16:29 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	WM_operator_properties_select_all(ot); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-16 16:11:50 +00:00
										 |  |  | /************************** Select Ungrouped Verts Operator *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int lattice_select_ungrouped_exec(bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Object *obedit = CTX_data_edit_object(C); | 
					
						
							|  |  |  | 	Lattice *lt = ((Lattice *)obedit->data)->editlatt->latt; | 
					
						
							|  |  |  | 	MDeformVert *dv; | 
					
						
							|  |  |  | 	BPoint *bp; | 
					
						
							|  |  |  | 	int a, tot; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (obedit->defbase.first == NULL || lt->dvert == NULL) { | 
					
						
							|  |  |  | 		BKE_report(op->reports, RPT_ERROR, "No weights/vertex groups on object"); | 
					
						
							|  |  |  | 		return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!RNA_boolean_get(op->ptr, "extend")) { | 
					
						
							|  |  |  | 		ED_setflagsLatt(obedit, 0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	dv = lt->dvert; | 
					
						
							|  |  |  | 	tot = lt->pntsu * lt->pntsv * lt->pntsw; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (a = 0, bp = lt->def; a < tot; a++, bp++, dv++) { | 
					
						
							|  |  |  | 		if (bp->hide == 0) { | 
					
						
							|  |  |  | 			if (dv->dw == NULL) { | 
					
						
							|  |  |  | 				bp->f1 |= SELECT; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	WM_event_add_notifier(C, NC_GEOM | ND_SELECT, obedit->data); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LATTICE_OT_select_ungrouped(wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name = "Select Ungrouped"; | 
					
						
							|  |  |  | 	ot->idname = "LATTICE_OT_select_ungrouped"; | 
					
						
							|  |  |  | 	ot->description = "Select vertices without a group"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->exec = lattice_select_ungrouped_exec; | 
					
						
							|  |  |  | 	ot->poll = ED_operator_editlattice; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	RNA_def_boolean(ot->srna, "extend", false, "Extend", "Extend the selection"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-13 10:42:38 +00:00
										 |  |  | /************************** Make Regular Operator *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | static int make_regular_poll(bContext *C) | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Object *ob; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ED_operator_editlattice(C)) return 1; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	ob = CTX_data_active_object(C); | 
					
						
							|  |  |  | 	return (ob && ob->type == OB_LATTICE); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-02-14 17:55:27 +00:00
										 |  |  | static int make_regular_exec(bContext *C, wmOperator *UNUSED(op)) | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	Object *ob = CTX_data_edit_object(C); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	Lattice *lt; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ob) { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		lt = ob->data; | 
					
						
							| 
									
										
										
										
											2012-05-05 16:03:57 +00:00
										 |  |  | 		BKE_lattice_resize(lt->editlatt->latt, lt->pntsu, lt->pntsv, lt->pntsw, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		ob = CTX_data_active_object(C); | 
					
						
							|  |  |  | 		lt = ob->data; | 
					
						
							| 
									
										
										
										
											2012-05-05 16:03:57 +00:00
										 |  |  | 		BKE_lattice_resize(lt, lt->pntsu, lt->pntsv, lt->pntsw, NULL); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2010-12-05 18:59:23 +00:00
										 |  |  | 	DAG_id_tag_update(&ob->id, OB_RECALC_DATA); | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	WM_event_add_notifier(C, NC_GEOM | ND_DATA, ob->data); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LATTICE_OT_make_regular(wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							| 
									
										
										
										
											2012-03-22 07:26:09 +00:00
										 |  |  | 	ot->name = "Make Regular"; | 
					
						
							|  |  |  | 	ot->description = "Set UVW control points a uniform distance apart"; | 
					
						
							|  |  |  | 	ot->idname = "LATTICE_OT_make_regular"; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							| 
									
										
										
										
											2012-03-22 07:26:09 +00:00
										 |  |  | 	ot->exec = make_regular_exec; | 
					
						
							|  |  |  | 	ot->poll = make_regular_poll; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-13 10:42:38 +00:00
										 |  |  | /************************** Flip Verts Operator *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* flipping options */ | 
					
						
							|  |  |  | typedef enum eLattice_FlipAxes { | 
					
						
							|  |  |  | 	LATTICE_FLIP_U = 0, | 
					
						
							|  |  |  | 	LATTICE_FLIP_V = 1, | 
					
						
							|  |  |  | 	LATTICE_FLIP_W = 2 | 
					
						
							|  |  |  | } eLattice_FlipAxes; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Helper macro for accessing item at index (u, v, w) 
 | 
					
						
							|  |  |  |  * < lt: (Lattice) | 
					
						
							|  |  |  |  * < U: (int) u-axis coordinate of point | 
					
						
							|  |  |  |  * < V: (int) v-axis coordinate of point | 
					
						
							|  |  |  |  * < W: (int) w-axis coordinate of point | 
					
						
							|  |  |  |  * < dimU: (int) number of points per row or number of columns (U-Axis) | 
					
						
							|  |  |  |  * < dimV: (int) number of rows (V-Axis) | 
					
						
							|  |  |  |  * > returns: (BPoint *) pointer to BPoint at this index | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define LATTICE_PT(lt, U, V, W, dimU, dimV)       \
 | 
					
						
							|  |  |  | 	( (lt)->def               +                   \ | 
					
						
							|  |  |  | 	  ((dimU) * (dimV)) * (W) +                   \ | 
					
						
							|  |  |  | 	  (dimU) * (V)            +                   \ | 
					
						
							|  |  |  | 	  (U)                                         \ | 
					
						
							|  |  |  | 	) | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | /* Flip midpoint value so that relative distances between midpoint and neighbour-pair is maintained
 | 
					
						
							|  |  |  |  * ! Assumes that uvw <=> xyz (i.e. axis-aligned index-axes with coordinate-axes) | 
					
						
							|  |  |  |  * - Helper for lattice_flip_exec() | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void lattice_flip_point_value(Lattice *lt, int u, int v, int w, float mid, eLattice_FlipAxes axis) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BPoint *bp; | 
					
						
							|  |  |  | 	float diff; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* just the point in the middle (unpaired) */ | 
					
						
							|  |  |  | 	bp = LATTICE_PT(lt, u, v, w, lt->pntsu, lt->pntsv); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flip over axis */ | 
					
						
							|  |  |  | 	diff = mid - bp->vec[axis]; | 
					
						
							|  |  |  | 	bp->vec[axis] = mid + diff; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Swap pairs of lattice points along a specified axis
 | 
					
						
							|  |  |  |  * - Helper for lattice_flip_exec() | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static void lattice_swap_point_pairs(Lattice *lt, int u, int v, int w, float mid, eLattice_FlipAxes axis) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	BPoint *bpA, *bpB; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	int numU = lt->pntsu; | 
					
						
							|  |  |  | 	int numV = lt->pntsv; | 
					
						
							|  |  |  | 	int numW = lt->pntsw; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	int u0 = u, u1 = u; | 
					
						
							|  |  |  | 	int v0 = v, v1 = v; | 
					
						
							|  |  |  | 	int w0 = w, w1 = w; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get pair index by just overriding the relevant pair-value
 | 
					
						
							|  |  |  | 	 * - "-1" else buffer overflow | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	switch (axis) { | 
					
						
							|  |  |  | 		case LATTICE_FLIP_U: | 
					
						
							|  |  |  | 			u1 = numU - u - 1; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case LATTICE_FLIP_V: | 
					
						
							|  |  |  | 			v1 = numV - v - 1; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case LATTICE_FLIP_W: | 
					
						
							|  |  |  | 			w1 = numW - w - 1; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get points to operate on */ | 
					
						
							|  |  |  | 	bpA = LATTICE_PT(lt, u0, v0, w0, numU, numV); | 
					
						
							|  |  |  | 	bpB = LATTICE_PT(lt, u1, v1, w1, numU, numV); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Swap all coordinates, so that flipped coordinates belong to
 | 
					
						
							|  |  |  | 	 * the indices on the correct side of the lattice. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 *   Coords:  (-2 4) |0| (3 4)   --> (3 4) |0| (-2 4)  | 
					
						
							|  |  |  | 	 *   Indices:  (0,L)     (1,R)   --> (0,L)     (1,R) | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	swap_v3_v3(bpA->vec, bpB->vec); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* However, we need to mirror the coordinate values on the axis we're dealing with,
 | 
					
						
							|  |  |  | 	 * otherwise we'd have effectively only rotated the points around. If we don't do this, | 
					
						
							|  |  |  | 	 * we'd just be reimplementing the naive mirroring algorithm, which causes unwanted deforms | 
					
						
							|  |  |  | 	 * such as flipped normals, etc. | 
					
						
							|  |  |  | 	 * | 
					
						
							|  |  |  | 	 *   Coords:  (3 4) |0| (-2 4)  --\    | 
					
						
							|  |  |  | 	 *                                 \-> (-3 4) |0| (2 4) | 
					
						
							|  |  |  | 	 *   Indices: (0,L)     (1,R)   -->     (0,L)     (1,R) | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	lattice_flip_point_value(lt, u0, v0, w0, mid, axis); | 
					
						
							|  |  |  | 	lattice_flip_point_value(lt, u1, v1, w1, mid, axis); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | static int lattice_flip_exec(bContext *C, wmOperator *op) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Object *obedit = CTX_data_edit_object(C); | 
					
						
							|  |  |  | 	Lattice *lt; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	eLattice_FlipAxes axis = RNA_enum_get(op->ptr, "axis"); | 
					
						
							|  |  |  | 	int numU, numV, numW; | 
					
						
							|  |  |  | 	int totP; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	float mid = 0.0f; | 
					
						
							|  |  |  | 	short isOdd = 0; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* get lattice - we need the "edit lattice" from the lattice... confusing... */ | 
					
						
							|  |  |  | 	lt = (Lattice *)obedit->data; | 
					
						
							|  |  |  | 	lt = lt->editlatt->latt; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	numU = lt->pntsu; | 
					
						
							|  |  |  | 	numV = lt->pntsv; | 
					
						
							|  |  |  | 	numW = lt->pntsw; | 
					
						
							|  |  |  | 	totP = numU * numV * numW; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* First Pass: determine midpoint - used for flipping center verts if there are odd number of points on axis */ | 
					
						
							|  |  |  | 	switch (axis) { | 
					
						
							|  |  |  | 		case LATTICE_FLIP_U: | 
					
						
							|  |  |  | 			isOdd = numU & 1; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case LATTICE_FLIP_V: | 
					
						
							|  |  |  | 			isOdd = numV & 1; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		case LATTICE_FLIP_W: | 
					
						
							|  |  |  | 			isOdd = numW & 1; | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 		default: | 
					
						
							|  |  |  | 			printf("lattice_flip(): Unknown flipping axis (%d)\n", axis); | 
					
						
							|  |  |  | 			return OPERATOR_CANCELLED; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (isOdd) { | 
					
						
							|  |  |  | 		BPoint *bp; | 
					
						
							|  |  |  | 		float avgInv = 1.0f / (float)totP; | 
					
						
							|  |  |  | 		int i; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* midpoint calculation - assuming that u/v/w are axis-aligned */ | 
					
						
							|  |  |  | 		for (i = 0, bp = lt->def; i < totP; i++, bp++) { | 
					
						
							|  |  |  | 			mid += bp->vec[axis] * avgInv; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Second Pass: swap pairs of vertices per axis, assuming they are all sorted */ | 
					
						
							|  |  |  | 	switch (axis) { | 
					
						
							|  |  |  | 		case LATTICE_FLIP_U: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			int u, v, w; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* v/w strips - front to back, top to bottom */ | 
					
						
							|  |  |  | 			for (w = 0; w < numW; w++) { | 
					
						
							|  |  |  | 				for (v = 0; v < numV; v++) { | 
					
						
							|  |  |  | 					/* swap coordinates of pairs of vertices on u */ | 
					
						
							|  |  |  | 					for (u = 0; u < (numU / 2); u++) { | 
					
						
							|  |  |  | 						lattice_swap_point_pairs(lt, u, v, w, mid, axis); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					/* flip u-coordinate of midpoint (i.e. unpaired point on u) */ | 
					
						
							|  |  |  | 					if (isOdd) { | 
					
						
							|  |  |  | 						u = (numU / 2); | 
					
						
							|  |  |  | 						lattice_flip_point_value(lt, u, v, w, mid, axis); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 		case LATTICE_FLIP_V: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			int u, v, w; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* u/w strips - front to back, left to right */ | 
					
						
							|  |  |  | 			for (w = 0; w < numW; w++) { | 
					
						
							|  |  |  | 				for (u = 0; u < numU; u++) { | 
					
						
							|  |  |  | 					/* swap coordinates of pairs of vertices on v */ | 
					
						
							|  |  |  | 					for (v = 0; v < (numV / 2); v++) { | 
					
						
							|  |  |  | 						lattice_swap_point_pairs(lt, u, v, w, mid, axis); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					/* flip v-coordinate of midpoint (i.e. unpaired point on v) */ | 
					
						
							|  |  |  | 					if (isOdd) { | 
					
						
							|  |  |  | 						v = (numV / 2); | 
					
						
							|  |  |  | 						lattice_flip_point_value(lt, u, v, w, mid, axis); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 		case LATTICE_FLIP_W: | 
					
						
							|  |  |  | 		{ | 
					
						
							|  |  |  | 			int u, v, w; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			for (v = 0; v < numV; v++) { | 
					
						
							|  |  |  | 				for (u = 0; u < numU; u++) { | 
					
						
							|  |  |  | 					/* swap coordinates of pairs of vertices on w */ | 
					
						
							|  |  |  | 					for (w = 0; w < (numW / 2); w++) { | 
					
						
							|  |  |  | 						lattice_swap_point_pairs(lt, u, v, w, mid, axis); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					 | 
					
						
							|  |  |  | 					/* flip w-coordinate of midpoint (i.e. unpaired point on w) */ | 
					
						
							|  |  |  | 					if (isOdd) { | 
					
						
							|  |  |  | 						w = (numW / 2); | 
					
						
							|  |  |  | 						lattice_flip_point_value(lt, u, v, w, mid, axis); | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		default: /* shouldn't happen, but just in case */ | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* updates */ | 
					
						
							|  |  |  | 	DAG_id_tag_update(&obedit->id, OB_RECALC_DATA); | 
					
						
							|  |  |  | 	WM_event_add_notifier(C, NC_GEOM | ND_DATA, obedit->data); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	return OPERATOR_FINISHED; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void LATTICE_OT_flip(wmOperatorType *ot) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	static EnumPropertyItem flip_items[] = { | 
					
						
							|  |  |  | 		{LATTICE_FLIP_U, "U", 0, "U (X) Axis", ""}, | 
					
						
							|  |  |  | 		{LATTICE_FLIP_V, "V", 0, "V (Y) Axis", ""}, | 
					
						
							|  |  |  | 		{LATTICE_FLIP_W, "W", 0, "W (Z) Axis", ""}, | 
					
						
							|  |  |  | 		{0, NULL, 0, NULL, NULL}}; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* identifiers */ | 
					
						
							|  |  |  | 	ot->name = "Flip (Distortion Free)"; | 
					
						
							|  |  |  | 	ot->description = "Mirror all control points without inverting the lattice deform"; | 
					
						
							|  |  |  | 	ot->idname = "LATTICE_OT_flip"; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* api callbacks */ | 
					
						
							|  |  |  | 	ot->poll = ED_operator_editlattice; | 
					
						
							|  |  |  | 	ot->invoke = WM_menu_invoke; | 
					
						
							|  |  |  | 	ot->exec = lattice_flip_exec; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* flags */ | 
					
						
							|  |  |  | 	ot->flag = OPTYPE_REGISTER | OPTYPE_UNDO; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* properties */ | 
					
						
							|  |  |  | 	ot->prop = RNA_def_enum(ot->srna, "axis", flip_items, LATTICE_FLIP_U, "Flip Axis", "Coordinates along this axis get flipped"); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | /****************************** Mouse Selection *************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | static void findnearestLattvert__doClosest(void *userData, BPoint *bp, const float screen_co[2]) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | 	struct { BPoint *bp; float dist; int select; float mval_fl[2]; } *data = userData; | 
					
						
							|  |  |  | 	float dist_test = len_manhattan_v2v2(data->mval_fl, screen_co); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | 	if ((bp->f1 & SELECT) && data->select) | 
					
						
							|  |  |  | 		dist_test += 5.0f; | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | 	if (dist_test < data->dist) { | 
					
						
							|  |  |  | 		data->dist = dist_test; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		data->bp = bp; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-12 16:47:36 +00:00
										 |  |  | static BPoint *findnearestLattvert(ViewContext *vc, const int mval[2], int sel) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-10-23 03:38:26 +00:00
										 |  |  | 	/* (sel == 1): selected gets a disadvantage */ | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	/* in nurb and bezt or bp the nearest is written */ | 
					
						
							|  |  |  | 	/* return 0 1 2: handlepunt */ | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | 	struct { BPoint *bp; float dist; int select; float mval_fl[2]; } data = {NULL}; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	data.dist = 100; | 
					
						
							|  |  |  | 	data.select = sel; | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | 	data.mval_fl[0] = mval[0]; | 
					
						
							|  |  |  | 	data.mval_fl[1] = mval[1]; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-22 23:22:05 +00:00
										 |  |  | 	ED_view3d_init_mats_rv3d(vc->obedit, vc->rv3d); | 
					
						
							| 
									
										
										
										
											2012-10-10 04:03:22 +00:00
										 |  |  | 	lattice_foreachScreenVert(vc, findnearestLattvert__doClosest, &data, V3D_PROJ_TEST_CLIP_DEFAULT); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return data.bp; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-19 23:17:44 +00:00
										 |  |  | bool mouse_lattice(bContext *C, const int mval[2], bool extend, bool deselect, bool toggle) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	ViewContext vc; | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	BPoint *bp = NULL; | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 	Lattice *lt; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	view3d_set_viewcontext(C, &vc); | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 	lt = ((Lattice *)vc.obedit->data)->editlatt->latt; | 
					
						
							| 
									
										
										
										
											2012-10-10 01:22:19 +00:00
										 |  |  | 	bp = findnearestLattvert(&vc, mval, TRUE); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (bp) { | 
					
						
							| 
									
										
										
										
											2012-06-05 21:54:21 +00:00
										 |  |  | 		if (extend) { | 
					
						
							|  |  |  | 			bp->f1 |= SELECT; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else if (deselect) { | 
					
						
							|  |  |  | 			bp->f1 &= ~SELECT; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-05-24 21:05:27 +00:00
										 |  |  | 		else if (toggle) { | 
					
						
							|  |  |  | 			bp->f1 ^= SELECT;  /* swap */ | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-06-05 21:54:21 +00:00
										 |  |  | 		else { | 
					
						
							|  |  |  | 			ED_setflagsLatt(vc.obedit, 0); | 
					
						
							| 
									
										
										
										
											2012-05-24 21:05:27 +00:00
										 |  |  | 			bp->f1 |= SELECT; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 		if (bp->f1 & SELECT) { | 
					
						
							|  |  |  | 			lt->actbp = bp - lt->def; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			lt->actbp = LT_ACTBP_NONE; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 		WM_event_add_notifier(C, NC_GEOM | ND_SELECT, vc.obedit->data); | 
					
						
							| 
									
										
										
										
											2009-11-24 04:59:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-19 23:17:44 +00:00
										 |  |  | 		return true; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-11-24 04:59:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-03-19 23:17:44 +00:00
										 |  |  | 	return false; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | /******************************** Undo *************************/ | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | typedef struct UndoLattice { | 
					
						
							|  |  |  | 	BPoint *def; | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 	int pntsu, pntsv, pntsw, actbp; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } UndoLattice; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 14:32:55 +00:00
										 |  |  | static void undoLatt_to_editLatt(void *data, void *edata, void *UNUSED(obdata)) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	UndoLattice *ult = (UndoLattice *)data; | 
					
						
							|  |  |  | 	EditLatt *editlatt = (EditLatt *)edata; | 
					
						
							|  |  |  | 	int a = editlatt->latt->pntsu * editlatt->latt->pntsv * editlatt->latt->pntsw; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	memcpy(editlatt->latt->def, ult->def, a * sizeof(BPoint)); | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 	editlatt->latt->actbp = ult->actbp; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-05-09 14:32:55 +00:00
										 |  |  | static void *editLatt_to_undoLatt(void *edata, void *UNUSED(obdata)) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	UndoLattice *ult = MEM_callocN(sizeof(UndoLattice), "UndoLattice"); | 
					
						
							|  |  |  | 	EditLatt *editlatt = (EditLatt *)edata; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	ult->def = MEM_dupallocN(editlatt->latt->def); | 
					
						
							|  |  |  | 	ult->pntsu = editlatt->latt->pntsu; | 
					
						
							|  |  |  | 	ult->pntsv = editlatt->latt->pntsv; | 
					
						
							|  |  |  | 	ult->pntsw = editlatt->latt->pntsw; | 
					
						
							| 
									
										
										
										
											2013-06-09 20:28:08 +00:00
										 |  |  | 	ult->actbp = editlatt->latt->actbp; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	return ult; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void free_undoLatt(void *data) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	UndoLattice *ult = (UndoLattice *)data; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 06:38:07 +00:00
										 |  |  | 	if (ult->def) MEM_freeN(ult->def); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	MEM_freeN(ult); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int validate_undoLatt(void *data, void *edata) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	UndoLattice *ult = (UndoLattice *)data; | 
					
						
							|  |  |  | 	EditLatt *editlatt = (EditLatt *)edata; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-10 06:36:42 +00:00
										 |  |  | 	return (ult->pntsu == editlatt->latt->pntsu && | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	        ult->pntsv == editlatt->latt->pntsv && | 
					
						
							|  |  |  | 	        ult->pntsw == editlatt->latt->pntsw); | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void *get_editlatt(bContext *C) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	Object *obedit = CTX_data_edit_object(C); | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-04-28 15:42:27 +00:00
										 |  |  | 	if (obedit && obedit->type == OB_LATTICE) { | 
					
						
							|  |  |  | 		Lattice *lt = obedit->data; | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 		return lt->editlatt; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2009-07-03 15:23:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | 	return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* and this is all the undo system needs to know */ | 
					
						
							| 
									
										
										
										
											2010-11-17 09:45:45 +00:00
										 |  |  | void undo_push_lattice(bContext *C, const char *name) | 
					
						
							| 
									
										
										
										
											2009-01-13 15:18:41 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	undo_editmode_push(C, name, get_editlatt, free_undoLatt, undoLatt_to_editLatt, editLatt_to_undoLatt, validate_undoLatt); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 |