Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/src/editlattice.c')
-rw-r--r--source/blender/src/editlattice.c318
1 files changed, 318 insertions, 0 deletions
diff --git a/source/blender/src/editlattice.c b/source/blender/src/editlattice.c
new file mode 100644
index 00000000000..68c16ea2d44
--- /dev/null
+++ b/source/blender/src/editlattice.c
@@ -0,0 +1,318 @@
+/**
+ * $Id$
+ *
+ * ***** BEGIN GPL/BL DUAL 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. The Blender
+ * Foundation also sells licenses for use in proprietary software under
+ * the Blender License. See http://www.blender.org/BL/ for information
+ * about this.
+ *
+ * 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,
+ * Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ *
+ * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
+ * All rights reserved.
+ *
+ * The Original Code is: all of this file.
+ *
+ * Contributor(s): none yet.
+ *
+ * ***** END GPL/BL DUAL LICENSE BLOCK *****
+ * i.t.t. wat de naam doet vermoeden: ook algemene lattice (calc) functies
+ */
+
+#include <stdlib.h>
+#include <math.h>
+#ifdef WIN32
+#include "BLI_winstuff.h"
+#endif
+#include "MEM_guardedalloc.h"
+
+#include "BLI_blenlib.h"
+#include "BLI_arithb.h"
+#include "BLI_editVert.h"
+
+#include "DNA_object_types.h"
+#include "DNA_scene_types.h"
+#include "DNA_lattice_types.h"
+#include "DNA_curve_types.h"
+#include "DNA_key_types.h"
+#include "DNA_view3d_types.h"
+
+#include "BKE_key.h"
+#include "BKE_displist.h"
+#include "BKE_lattice.h"
+#include "BKE_global.h"
+
+#include "BIF_toolbox.h"
+#include "BIF_space.h"
+#include "BIF_screen.h"
+#include "BIF_editlattice.h"
+#include "BIF_editkey.h"
+
+#include "BSE_edit.h"
+
+#include "BDR_editobject.h"
+#include "BDR_drawobject.h"
+
+#include "blendef.h"
+#include "mydevice.h"
+
+#include "render.h"
+
+#include "BKE_armature.h"
+
+void apply_lattice(void)
+{
+ Base *base;
+ Object *par;
+
+ if(okee("Apply Lattice Deform")==0) return;
+
+ base= FIRSTBASE;
+ while(base) {
+ if TESTBASELIB(base) {
+ if( (par= base->object->parent) ) {
+ if(par->type==OB_LATTICE) {
+
+ lt_applyflag= 1;
+ object_deform(base->object);
+ lt_applyflag= 0;
+
+ base->object->parent= 0;
+ }
+ }
+ }
+ base= base->next;
+ }
+
+ allqueue(REDRAWVIEW3D, 0);
+}
+
+/* ***************************** */
+
+
+
+
+void free_editLatt(void)
+{
+ if(editLatt) {
+ if(editLatt->def) MEM_freeN(editLatt->def);
+ MEM_freeN(editLatt);
+ editLatt= 0;
+ }
+}
+
+
+static void setflagsLatt(int flag)
+{
+ BPoint *bp;
+ int a;
+
+ bp= editLatt->def;
+
+ a= editLatt->pntsu*editLatt->pntsv*editLatt->pntsw;
+
+ while(a--) {
+ if(bp->hide==0) {
+ bp->f1= flag;
+ }
+ bp++;
+ }
+}
+
+
+
+void make_editLatt(void)
+{
+ Lattice *lt;
+ KeyBlock *actkey=0;
+
+ free_editLatt();
+
+ lt= G.obedit->data;
+
+ /* keys? */
+ if(lt->key) {
+ actkey= lt->key->block.first;
+ while(actkey) {
+ if(actkey->flag & SELECT) break;
+ actkey= actkey->next;
+ }
+ }
+
+ if(actkey) {
+ key_to_latt(actkey, lt);
+ }
+
+ editLatt= MEM_dupallocN(lt);
+
+ editLatt->def= MEM_dupallocN(lt->def);
+
+ setflagsLatt(0);
+}
+
+
+void load_editLatt(void)
+{
+ Lattice *lt;
+ KeyBlock *actkey=0;
+ BPoint *bp;
+ float *fp;
+ int tot;
+
+ lt= G.obedit->data;
+
+ /* zijn er keys? */
+ if(lt->key) {
+ actkey= lt->key->block.first;
+ while(actkey) {
+ if(actkey->flag & SELECT) break;
+ actkey= actkey->next;
+ }
+ }
+
+ if(actkey) {
+ /* aktieve key: vertices */
+ tot= editLatt->pntsu*editLatt->pntsv*editLatt->pntsw;
+
+ if(actkey->data) MEM_freeN(actkey->data);
+
+ fp=actkey->data= MEM_callocN(lt->key->elemsize*tot, "actkey->data");
+ actkey->totelem= tot;
+
+ bp= editLatt->def;
+ while(tot--) {
+ VECCOPY(fp, bp->vec);
+ fp+= 3;
+ bp++;
+ }
+
+ if(actkey) do_spec_key(lt->key);
+ }
+ else {
+
+ MEM_freeN(lt->def);
+
+ lt->def= MEM_dupallocN(editLatt->def);
+
+ lt->flag= editLatt->flag;
+
+ lt->pntsu= editLatt->pntsu;
+ lt->pntsv= editLatt->pntsv;
+ lt->pntsw= editLatt->pntsw;
+
+ lt->typeu= editLatt->typeu;
+ lt->typev= editLatt->typev;
+ lt->typew= editLatt->typew;
+ }
+}
+
+void remake_editLatt(void)
+{
+ if(okee("Reload Original data")==0) return;
+
+ make_editLatt();
+ allqueue(REDRAWVIEW3D, 0);
+ allqueue(REDRAWBUTSEDIT, 0);
+}
+
+
+void deselectall_Latt(void)
+{
+ BPoint *bp;
+ int a;
+
+ bp= editLatt->def;
+
+ a= editLatt->pntsu*editLatt->pntsv*editLatt->pntsw;
+
+ allqueue(REDRAWVIEW3D, 0);
+
+ while(a--) {
+ if(bp->hide==0) {
+ if(bp->f1) {
+ setflagsLatt(0);
+ return;
+ }
+ }
+ bp++;
+ }
+ setflagsLatt(1);
+}
+
+
+static BPoint *findnearestLattvert(int sel)
+{
+ /* sel==1: selected krijgen een nadeel */
+ /* in bp wordt nearest weggeschreven */
+ BPoint *bp1, *bp;
+ short dist= 100, temp, mval[2], a;
+
+ bp= 0;
+
+ /* projektie doen */
+ calc_lattverts_ext(); /* drawobject.c */
+
+ getmouseco_areawin(mval);
+
+
+ bp1= editLatt->def;
+
+ a= editLatt->pntsu*editLatt->pntsv*editLatt->pntsw;
+
+ while(a--) {
+ if(bp1->hide==0) {
+ temp= abs(mval[0]- bp1->s[0])+ abs(mval[1]- bp1->s[1]);
+ if( (bp1->f1 & 1)==sel) temp+=5;
+ if(temp<dist) {
+ bp= bp1;
+ dist= temp;
+ }
+ }
+ bp1++;
+ }
+
+ return bp;
+}
+
+
+void mouse_lattice(void)
+{
+ BPoint *bp=0;
+
+ bp= findnearestLattvert(1);
+
+ if(bp) {
+ if((G.qual & LR_SHIFTKEY)==0) {
+
+ setflagsLatt(0);
+ bp->f1 |= 1;
+
+ allqueue(REDRAWVIEW3D, 0);
+ }
+ else {
+
+ if(bp->f1 & 1) bp->f1 &= ~1;
+ else bp->f1 |= 1;
+
+ allqueue(REDRAWVIEW3D, 0);
+
+ }
+
+ countall();
+ }
+
+ rightmouse_transform();
+
+}