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/include/transform.h')
-rw-r--r--source/blender/include/transform.h549
1 files changed, 0 insertions, 549 deletions
diff --git a/source/blender/include/transform.h b/source/blender/include/transform.h
deleted file mode 100644
index 374094273ac..00000000000
--- a/source/blender/include/transform.h
+++ /dev/null
@@ -1,549 +0,0 @@
-/**
- * $Id$
- *
- * ***** 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,
- * 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 LICENSE BLOCK *****
- */
-
-#ifndef TRANSFORM_H
-#define TRANSFORM_H
-
-#include "BIF_transform.h"
-
-/* ************************** Types ***************************** */
-
-struct TransInfo;
-struct TransData;
-struct TransSnap;
-struct NumInput;
-struct Object;
-struct View3D;
-struct ScrArea;
-struct bPose;
-struct bConstraint;
-struct BezTriple;
-
-typedef struct NDofInput {
- int flag;
- int axis;
- float fval[7];
- float factor[3];
-} NDofInput;
-
-typedef struct NumInput {
- short idx;
- short idx_max;
- short flag; /* Different flags to indicate different behaviors */
- float val[3]; /* Direct value of the input */
- int ctrl[3]; /* Control to indicate what to do with the numbers that are typed */
-} NumInput ;
-
-/*
- The ctrl value has different meaning:
- 0 : No value has been typed
-
- otherwise, |value| - 1 is where the cursor is located after the period
- Positive : number is positive
- Negative : number is negative
-*/
-
-typedef struct TransSnap {
- short modePoint;
- short modeTarget;
- int status;
- float snapPoint[3]; /* snapping from this point */
- float snapTarget[3];/* to this point */
- float snapNormal[3];
- float snapTangent[3];
- float dist; // Distance from snapPoint to snapTarget
- double last;
- void (*applySnap)(struct TransInfo *, float *);
- void (*calcSnap)(struct TransInfo *, float *);
- void (*targetSnap)(struct TransInfo *);
- float (*distance)(struct TransInfo *, float p1[3], float p2[3]); // Get the transform distance between two points (used by Closest snap)
-} TransSnap;
-
-typedef struct TransCon {
- char text[50]; /* Description of the Constraint for header_print */
- float mtx[3][3]; /* Matrix of the Constraint space */
- float imtx[3][3]; /* Inverse Matrix of the Constraint space */
- float pmtx[3][3]; /* Projection Constraint Matrix (same as imtx with some axis == 0) */
- float center[3]; /* transformation center to define where to draw the view widget
- ALWAYS in global space. Unlike the transformation center */
- short imval[2]; /* initial mouse value for visual calculation */
- /* the one in TransInfo is not garanty to stay the same (Rotates change it) */
- int mode; /* Mode flags of the Constraint */
- void (*drawExtra)(struct TransInfo *);
- /* For constraints that needs to draw differently from the other
- uses this instead of the generic draw function */
- void (*applyVec)(struct TransInfo *, struct TransData *, float *, float *, float *);
- /* Apply function pointer for linear vectorial transformation */
- /* The last three parameters are pointers to the in/out/printable vectors */
- void (*applySize)(struct TransInfo *, struct TransData *, float [3][3]);
- /* Apply function pointer for size transformation */
- void (*applyRot)(struct TransInfo *, struct TransData *, float [3], float *);
- /* Apply function pointer for rotation transformation */
-} TransCon;
-
-typedef struct TransDataIpokey {
- int flag; /* which keys */
- float *locx, *locy, *locz; /* channel pointers */
- float *rotx, *roty, *rotz;
- float *quatx, *quaty, *quatz, *quatw;
- float *sizex, *sizey, *sizez;
- float oldloc[9]; /* storage old values */
- float oldrot[9];
- float oldsize[9];
- float oldquat[12];
-} TransDataIpokey;
-
-typedef struct TransDataExtension {
- float drot[3]; /* Initial object drot */
- float dsize[3]; /* Initial object dsize */
- float *rot; /* Rotation of the data to transform (Faculative) */
- float irot[3]; /* Initial rotation */
- float *quat; /* Rotation quaternion of the data to transform (Faculative) */
- float iquat[4]; /* Initial rotation quaternion */
- float *size; /* Size of the data to transform (Faculative) */
- float isize[3]; /* Initial size */
- float obmat[4][4]; /* Object matrix */
-} TransDataExtension;
-
-typedef struct TransData2D {
- float loc[3]; /* Location of data used to transform (x,y,0) */
- float *loc2d; /* Pointer to real 2d location of data */
-} TransData2D;
-
-/* we need to store 2 handles for each transdata incase the other handle wasnt selected */
-typedef struct TransDataCurveHandleFlags {
- short ih1, ih2;
- short *h1, *h2;
-} TransDataCurveHandleFlags;
-
-
-typedef struct TransData {
- float dist; /* Distance needed to affect element (for Proportionnal Editing) */
- float rdist; /* Distance to the nearest element (for Proportionnal Editing) */
- float factor; /* Factor of the transformation (for Proportionnal Editing) */
- float *loc; /* Location of the data to transform */
- float iloc[3]; /* Initial location */
- float *val; /* Value pointer for special transforms */
- float ival; /* Old value*/
- float center[3]; /* Individual data center */
- float mtx[3][3]; /* Transformation matrix from data space to global space */
- float smtx[3][3]; /* Transformation matrix from global space to data space */
- float axismtx[3][3];/* Axis orientation matrix of the data */
- struct Object *ob;
- struct bConstraint *con; /* for objects/bones, the first constraint in its constraint stack */
- TransDataExtension *ext; /* for objects, poses. 1 single malloc per TransInfo! */
- TransDataIpokey *tdi; /* for objects, ipo keys. per transdata a malloc */
- TransDataCurveHandleFlags *hdata; /* for curves, stores handle flags for modification/cancel */
- void *extra; /* extra data (mirrored element pointer, in editmode mesh to EditVert) (editbone for roll fixing) (...) */
- short flag; /* Various flags */
- short protectflag; /* If set, copy of Object or PoseChannel protection */
-/*#ifdef WITH_VERSE*/
- void *verse; /* pointer at verse data struct (VerseVert, etc.) */
-/*#endif*/
-} TransData;
-
-typedef struct TransInfo {
- int mode; /* current mode */
- int flag; /* generic flags for special behaviors */
- short state; /* current state (running, canceled,...)*/
- int context; /* current context */
- float val; /* init value for some transformations (and rotation angle) */
- float fac; /* factor for distance based transform */
- int (*transform)(struct TransInfo *, short *);
- /* transform function pointer */
- int (*handleEvent)(struct TransInfo *, unsigned short event, short val);
- /* event handler function pointer RETURN 1 if redraw is needed */
- int total; /* total number of transformed data */
- TransData *data; /* transformed data (array) */
- TransDataExtension *ext; /* transformed data extension (array) */
- TransData2D *data2d; /* transformed data for 2d (array) */
- TransCon con; /* transformed constraint */
- TransSnap tsnap;
- NumInput num; /* numerical input */
- NDofInput ndof; /* ndof input */
- char redraw; /* redraw flag */
- float propsize; /* proportional circle radius */
- char proptext[20]; /* proportional falloff text */
- float center[3]; /* center of transformation */
- int center2d[2]; /* center in screen coordinates */
- short imval[2]; /* initial mouse position */
- short shiftmval[2]; /* mouse position when shift was pressed */
- short idx_max; /* maximum index on the input vector */
- float snap[3]; /* Snapping Gears */
-
- float viewmat[4][4]; /* copy from G.vd, prevents feedback, */
- float viewinv[4][4]; /* and to make sure we don't have to */
- float persmat[4][4]; /* access G.vd from other space types */
- float persinv[4][4];
- short persp;
- short around;
- char spacetype; /* spacetype where transforming is */
-
- float vec[3]; /* translation, to show for widget */
- float mat[3][3]; /* rot/rescale, to show for widget */
-
- char *undostr; /* if set, uses this string for undo */
- float spacemtx[3][3]; /* orientation matrix of the current space */
- char spacename[32]; /* name of the current space */
-
- struct Object *poseobj; /* if t->flag & T_POSE, this denotes pose object */
-
- void *customData; /* Per Transform custom data */
-} TransInfo;
-
-
-/* ******************** Macros & Prototypes *********************** */
-
-/* NUMINPUT FLAGS */
-#define NUM_NULL_ONE 2
-#define NUM_NO_NEGATIVE 4
-#define NUM_NO_ZERO 8
-#define NUM_NO_FRACTION 16
-#define NUM_AFFECT_ALL 32
-
-/* NDOFINPUT FLAGS */
-#define NDOF_INIT 1
-
-/* transinfo->state */
-#define TRANS_RUNNING 0
-#define TRANS_CONFIRM 1
-#define TRANS_CANCEL 2
-
-/* transinfo->flag */
-#define T_OBJECT (1 << 0)
-#define T_EDIT (1 << 1)
-#define T_POSE (1 << 2)
-#define T_TEXTURE (1 << 3)
-#define T_CAMERA (1 << 4)
- // when shift pressed, higher resolution transform. cannot rely on G.qual, need event!
-#define T_SHIFT_MOD (1 << 5)
- // trans on points, having no rotation/scale
-#define T_POINTS (1 << 6)
- // for manipulator exceptions, like scaling using center point, drawing help lines
-#define T_USES_MANIPULATOR (1 << 7)
-
- /* restrictions flags */
-#define T_ALL_RESTRICTIONS ((1 << 8)|(1 << 9)|(1 << 10))
-#define T_NO_CONSTRAINT (1 << 8)
-#define T_NULL_ONE (1 << 9)
-#define T_NO_ZERO (1 << 10)
-
-#define T_PROP_EDIT (1 << 11)
-#define T_PROP_CONNECTED (1 << 12)
-
- /* if MMB is pressed or not */
-#define T_MMB_PRESSED (1 << 13)
-
-#define T_V3D_ALIGN (1 << 14)
- /* for 2d views like uv or ipo */
-#define T_2D_EDIT (1 << 15)
-#define T_CLIP_UV (1 << 16)
-
-#define T_FREE_CUSTOMDATA (1 << 17)
- /* auto-ik is on */
-#define T_AUTOIK (1 << 18)
-
-/* ******************************************************************************** */
-
-/* transinfo->con->mode */
-#define CON_APPLY 1
-#define CON_AXIS0 2
-#define CON_AXIS1 4
-#define CON_AXIS2 8
-#define CON_SELECT 16
-#define CON_NOFLIP 32 /* does not reorient vector to face viewport when on */
-#define CON_LOCAL 64
-#define CON_USER 128
-
-/* transdata->flag */
-#define TD_SELECTED 1
-#define TD_ACTIVE (1 << 1)
-#define TD_NOACTION (1 << 2)
-#define TD_USEQUAT (1 << 3)
-#define TD_NOTCONNECTED (1 << 4)
-#define TD_SINGLESIZE (1 << 5) /* used for scaling of MetaElem->rad */
-#ifdef WITH_VERSE
- #define TD_VERSE_OBJECT (1 << 6)
- #define TD_VERSE_VERT (1 << 7)
-#endif
-#define TD_TIMEONLY (1 << 8)
-#define TD_NOCENTER (1 << 9)
-#define TD_NO_EXT (1 << 10) /* ext abused for particle key timing */
-#define TD_SKIP (1 << 11) /* don't transform this data */
-#define TD_BEZTRIPLE (1 << 12) /* if this is a bez triple, we need to restore the handles, if this is set transdata->misc.hdata needs freeing */
-#define TD_NO_LOC (1 << 13) /* when this is set, don't apply translation changes to this element */
-
-/* transsnap->status */
-#define SNAP_ON 1
-#define TARGET_INIT 2
-#define POINT_INIT 4
-
-/* transsnap->modePoint */
-#define SNAP_GRID 0
-#define SNAP_GEO 1
-
-/* transsnap->modeTarget */
-#define SNAP_CLOSEST 0
-#define SNAP_CENTER 1
-#define SNAP_MEDIAN 2
-#define SNAP_ACTIVE 3
-
-void checkFirstTime(void);
-
-void setTransformViewMatrices(TransInfo *t);
-void convertViewVec(TransInfo *t, float *vec, short dx, short dy);
-void projectIntView(TransInfo *t, float *vec, int *adr);
-void projectFloatView(TransInfo *t, float *vec, float *adr);
-
-void convertVecToDisplayNum(float *vec, float *num);
-void convertDisplayNumToVec(float *num, float *vec);
-
-void initWarp(TransInfo *t);
-int handleEventWarp(TransInfo *t, unsigned short event, short val);
-int Warp(TransInfo *t, short mval[2]);
-
-void initShear(TransInfo *t);
-int handleEventShear(TransInfo *t, unsigned short evenl, short val);
-int Shear(TransInfo *t, short mval[2]);
-
-void initResize(TransInfo *t);
-int Resize(TransInfo *t, short mval[2]);
-
-void initTranslation(TransInfo *t);
-int Translation(TransInfo *t, short mval[2]);
-
-void initToSphere(TransInfo *t);
-int ToSphere(TransInfo *t, short mval[2]);
-
-void initRotation(TransInfo *t);
-int Rotation(TransInfo *t, short mval[2]);
-
-void initShrinkFatten(TransInfo *t);
-int ShrinkFatten(TransInfo *t, short mval[2]);
-
-void initTilt(TransInfo *t);
-int Tilt(TransInfo *t, short mval[2]);
-
-void initCurveShrinkFatten(TransInfo *t);
-int CurveShrinkFatten(TransInfo *t, short mval[2]);
-
-void initTrackball(TransInfo *t);
-int Trackball(TransInfo *t, short mval[2]);
-
-void initPushPull(TransInfo *t);
-int PushPull(TransInfo *t, short mval[2]);
-
-void initBevel(TransInfo *t);
-int handleEventBevel(TransInfo *t, unsigned short evenl, short val);
-int Bevel(TransInfo *t, short mval[2]);
-
-void initBevelWeight(TransInfo *t);
-int BevelWeight(TransInfo *t, short mval[2]);
-
-void initCrease(TransInfo *t);
-int Crease(TransInfo *t, short mval[2]);
-
-void initBoneSize(TransInfo *t);
-int BoneSize(TransInfo *t, short mval[2]);
-
-void initBoneEnvelope(TransInfo *t);
-int BoneEnvelope(TransInfo *t, short mval[2]);
-
-void initBoneRoll(TransInfo *t);
-int BoneRoll(TransInfo *t, short mval[2]);
-
-void initTimeTranslate(TransInfo *t);
-int TimeTranslate(TransInfo *t, short mval[2]);
-
-void initTimeSlide(TransInfo *t);
-int TimeSlide(TransInfo *t, short mval[2]);
-
-void initTimeScale(TransInfo *t);
-int TimeScale(TransInfo *t, short mval[2]);
-
-void initBakeTime(TransInfo *t);
-int BakeTime(TransInfo *t, short mval[2]);
-
-void initMirror(TransInfo *t);
-int Mirror(TransInfo *t, short mval[2]);
-
-void initAlign(TransInfo *t);
-int Align(TransInfo *t, short mval[2]);
-
-/*********************** transform_conversions.c ********** */
-struct ListBase;
-void flushTransGPactionData(TransInfo *t);
-void flushTransIpoData(TransInfo *t);
-void flushTransUVs(TransInfo *t);
-void flushTransParticles(TransInfo *t);
-int clipUVTransform(TransInfo *t, float *vec, int resize);
-
-/*********************** exported from transform_manipulator.c ********** */
-void draw_manipulator_ext(struct ScrArea *sa, int type, char axis, int col, float vec[3], float mat[][3]);
-int calc_manipulator_stats(struct ScrArea *sa);
-float get_drawsize(struct View3D *v3d, float *co);
-
-/*********************** TransData Creation and General Handling *********** */
-void createTransData(TransInfo *t);
-void sort_trans_data_dist(TransInfo *t);
-void add_tdi_poin(float *poin, float *old, float delta);
-void special_aftertrans_update(TransInfo *t);
-
-void transform_autoik_update(TransInfo *t, short mode);
-
-/* auto-keying stuff used by special_aftertrans_update */
-short autokeyframe_cfra_can_key(struct Object *ob);
-void autokeyframe_ob_cb_func(struct Object *ob, int tmode);
-void autokeyframe_pose_cb_func(struct Object *ob, int tmode, short targetless_ik);
-
-/*********************** Constraints *****************************/
-
-void getConstraintMatrix(TransInfo *t);
-void setConstraint(TransInfo *t, float space[3][3], int mode, const char text[]);
-void setLocalConstraint(TransInfo *t, int mode, const char text[]);
-void setUserConstraint(TransInfo *t, int mode, const char text[]);
-
-void constraintNumInput(TransInfo *t, float vec[3]);
-
-void getConstraintMatrix(TransInfo *t);
-int isLockConstraint(TransInfo *t);
-int getConstraintSpaceDimension(TransInfo *t);
-char constraintModeToChar(TransInfo *t);
-
-void startConstraint(TransInfo *t);
-void stopConstraint(TransInfo *t);
-
-void initSelectConstraint(TransInfo *t, float mtx[3][3]);
-void selectConstraint(TransInfo *t);
-void postSelectConstraint(TransInfo *t);
-
-void setNearestAxis(TransInfo *t);
-
-/*********************** Snapping ********************************/
-
-typedef enum {
- NO_GEARS = 0,
- BIG_GEARS = 1,
- SMALL_GEARS = 2
-} GearsType;
-
-void snapGrid(TransInfo *t, float *val);
-void snapGridAction(TransInfo *t, float *val, GearsType action);
-
-void initSnapping(struct TransInfo *t);
-void applySnapping(TransInfo *t, float *vec);
-void resetSnapping(TransInfo *t);
-int handleSnapping(TransInfo *t, int event);
-void drawSnapping(TransInfo *t);
-int usingSnappingNormal(TransInfo *t);
-int validSnappingNormal(TransInfo *t);
-
-/*********************** Generics ********************************/
-
-void initTrans(TransInfo *t);
-void postTrans (TransInfo *t);
-void resetTransRestrictions(TransInfo *t);
-
-void drawLine(float *center, float *dir, char axis, short options);
-
-TransDataCurveHandleFlags *initTransDataCurveHandes(TransData *td, struct BezTriple *bezt);
-
-/* DRAWLINE options flags */
-#define DRAWLIGHT 1
-#define DRAWDASHED 2
-#define DRAWBOLD 4
-
-void applyTransObjects(TransInfo *t);
-void restoreTransObjects(TransInfo *t);
-void recalcData(TransInfo *t);
-
-void calculateCenter(TransInfo *t);
-void calculateCenter2D(TransInfo *t);
-void calculateCenterBound(TransInfo *t);
-void calculateCenterMedian(TransInfo *t);
-void calculateCenterCursor(TransInfo *t);
-
-void calculateCenterCursor2D(TransInfo *t);
-void calculatePropRatio(TransInfo *t);
-
-void getViewVector(float coord[3], float vec[3]);
-void getViewRay(short mval[2], float p[3], float d[3]);
-
-TransInfo * BIF_GetTransInfo(void);
-
-/*********************** NumInput ********************************/
-
-void initNumInput(NumInput *n);
-void outputNumInput(NumInput *n, char *str);
-short hasNumInput(NumInput *n);
-void applyNumInput(NumInput *n, float *vec);
-char handleNumInput(NumInput *n, unsigned short event);
-
-/*********************** NDofInput ********************************/
-
-void initNDofInput(NDofInput *n);
-int hasNDofInput(NDofInput *n);
-void applyNDofInput(NDofInput *n, float *vec);
-int handleNDofInput(NDofInput *n, unsigned short event, short val);
-
-/* handleNDofInput return values */
-#define NDOF_REFRESH 1
-#define NDOF_NOMOVE 2
-#define NDOF_CONFIRM 3
-#define NDOF_CANCEL 4
-
-
-/*********************** TransSpace ******************************/
-
-int manageObjectSpace(int confirm, int set);
-int manageMeshSpace(int confirm, int set);
-int manageBoneSpace(int confirm, int set);
-
-/* Those two fill in mat and return non-zero on success */
-int createSpaceNormal(float mat[3][3], float normal[3]);
-int createSpaceNormalTangent(float mat[3][3], float normal[3], float tangent[3]);
-
-int addMatrixSpace(float mat[3][3], char name[]);
-int addObjectSpace(struct Object *ob);
-void applyTransformOrientation(void);
-
-
-#define ORIENTATION_NONE 0
-#define ORIENTATION_NORMAL 1
-#define ORIENTATION_VERT 2
-#define ORIENTATION_EDGE 3
-#define ORIENTATION_FACE 4
-
-int getTransformOrientation(float normal[3], float plane[3], int activeOnly);
-int createSpaceNormal(float mat[3][3], float normal[3]);
-int createSpaceNormalTangent(float mat[3][3], float normal[3], float tangent[3]);
-
-#endif
-
-