2011-02-23 10:52:22 +00:00
|
|
|
/*
|
2009-02-10 15:38:00 +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
|
2012-03-03 21:42:21 +00:00
|
|
|
* of the License, or (at your option) any later version.
|
2009-02-10 15:38:00 +00:00
|
|
|
*
|
|
|
|
* 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-02-10 15:38:00 +00:00
|
|
|
*
|
|
|
|
* The Original Code is Copyright (C) 2009 Blender Foundation.
|
|
|
|
* All rights reserved.
|
|
|
|
*
|
2012-03-03 21:42:21 +00:00
|
|
|
*
|
2009-02-10 15:38:00 +00:00
|
|
|
* Contributor(s): Blender Foundation
|
|
|
|
*
|
|
|
|
* ***** END GPL LICENSE BLOCK *****
|
|
|
|
*/
|
|
|
|
|
2011-02-27 20:29:51 +00:00
|
|
|
/** \file blender/editors/space_view3d/view3d_buttons.c
|
|
|
|
* \ingroup spview3d
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
#include <string.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <math.h>
|
|
|
|
#include <float.h>
|
|
|
|
|
|
|
|
#include "DNA_armature_types.h"
|
|
|
|
#include "DNA_curve_types.h"
|
|
|
|
#include "DNA_lattice_types.h"
|
|
|
|
#include "DNA_meta_types.h"
|
2012-02-19 22:17:30 +00:00
|
|
|
#include "DNA_mesh_types.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
#include "DNA_meshdata_types.h"
|
|
|
|
#include "DNA_object_types.h"
|
|
|
|
#include "DNA_scene_types.h"
|
|
|
|
|
|
|
|
#include "MEM_guardedalloc.h"
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
#include "BLF_translation.h"
|
|
|
|
|
2009-11-10 20:43:45 +00:00
|
|
|
#include "BLI_math.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
#include "BLI_blenlib.h"
|
|
|
|
#include "BLI_rand.h"
|
2011-01-07 18:36:47 +00:00
|
|
|
#include "BLI_utildefines.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
|
|
|
|
#include "BKE_action.h"
|
|
|
|
#include "BKE_context.h"
|
|
|
|
#include "BKE_curve.h"
|
|
|
|
#include "BKE_customdata.h"
|
|
|
|
#include "BKE_depsgraph.h"
|
2010-08-01 12:47:49 +00:00
|
|
|
#include "BKE_main.h"
|
2009-05-23 03:24:15 +00:00
|
|
|
#include "BKE_mesh.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
#include "BKE_screen.h"
|
2009-07-16 06:27:37 +00:00
|
|
|
#include "BKE_tessmesh.h"
|
2010-01-25 23:12:02 +00:00
|
|
|
#include "BKE_deform.h"
|
2011-12-16 10:39:43 +00:00
|
|
|
#include "BKE_object.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
|
|
|
|
#include "WM_api.h"
|
|
|
|
#include "WM_types.h"
|
|
|
|
|
|
|
|
#include "RNA_access.h"
|
|
|
|
|
|
|
|
#include "ED_armature.h"
|
2009-09-16 17:43:09 +00:00
|
|
|
#include "ED_gpencil.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
#include "ED_mesh.h"
|
|
|
|
#include "ED_screen.h"
|
2009-07-08 16:17:47 +00:00
|
|
|
#include "ED_transform.h"
|
2010-07-25 11:57:36 +00:00
|
|
|
#include "ED_curve.h"
|
2009-02-10 15:38:00 +00:00
|
|
|
|
|
|
|
#include "UI_interface.h"
|
|
|
|
#include "UI_resources.h"
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
#include "view3d_intern.h" /* own include */
|
2009-02-10 15:38:00 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* ******************* view3d space & buttons ************** */
|
2012-05-08 15:55:29 +00:00
|
|
|
#define B_REDR 2
|
2009-02-10 15:38:00 +00:00
|
|
|
#define B_OBJECTPANELMEDIAN 1008
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
#define NBR_TRANSFORM_PROPERTIES 7
|
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
/* temporary struct for storing transform properties */
|
|
|
|
typedef struct {
|
2012-03-03 21:42:21 +00:00
|
|
|
float ob_eul[4]; /* used for quat too... */
|
|
|
|
float ob_scale[3]; /* need temp space due to linked values */
|
2009-02-10 15:38:00 +00:00
|
|
|
float ob_dims[3];
|
|
|
|
short link_scale;
|
2012-10-09 09:14:37 +00:00
|
|
|
float ve_median[NBR_TRANSFORM_PROPERTIES];
|
2009-02-10 15:38:00 +00:00
|
|
|
int curdef;
|
|
|
|
float *defweightp;
|
|
|
|
} TransformProperties;
|
|
|
|
|
2012-03-02 10:30:11 +00:00
|
|
|
/* Helper function to compute a median changed value,
|
|
|
|
* when the value should be clamped in [0.0, 1.0].
|
|
|
|
* Returns either 0.0, 1.0 (both can be applied directly), a positive scale factor
|
|
|
|
* for scale down, or a negative one for scale up.
|
|
|
|
*/
|
|
|
|
static float compute_scale_factor(const float ve_median, const float median)
|
|
|
|
{
|
|
|
|
if (ve_median <= 0.0f)
|
|
|
|
return 0.0f;
|
|
|
|
else if (ve_median >= 1.0f)
|
|
|
|
return 1.0f;
|
|
|
|
else {
|
|
|
|
/* Scale value to target median. */
|
|
|
|
float median_new = ve_median;
|
|
|
|
float median_orig = ve_median - median; /* Previous median value. */
|
|
|
|
|
|
|
|
/* In case of floating point error. */
|
|
|
|
CLAMP(median_orig, 0.0f, 1.0f);
|
|
|
|
CLAMP(median_new, 0.0f, 1.0f);
|
|
|
|
|
|
|
|
if (median_new <= median_orig) {
|
|
|
|
/* Scale down. */
|
|
|
|
return median_new / median_orig;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
/* Scale up, negative to indicate it... */
|
|
|
|
return -(1.0f - median_new) / (1.0f - median_orig);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
|
|
|
|
/* is used for both read and write... */
|
2010-10-15 12:29:02 +00:00
|
|
|
static void v3d_editvertex_buts(uiLayout *layout, View3D *v3d, Object *ob, float lim)
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
2012-10-09 09:14:37 +00:00
|
|
|
/* Get rid of those ugly magic numbers, even in a single func they become confusing! */
|
|
|
|
/* Location, common to all. */
|
|
|
|
/* XXX Those two *must* remain contiguous (used as array)! */
|
|
|
|
#define LOC_X 0
|
|
|
|
#define LOC_Y 1
|
|
|
|
#define LOC_Z 2
|
|
|
|
/* Meshes... */
|
|
|
|
#define M_CREASE 3
|
|
|
|
#define M_WEIGHT 4
|
|
|
|
/* XXX Those two *must* remain contiguous (used as array)! */
|
|
|
|
#define M_SKIN_X 5
|
|
|
|
#define M_SKIN_Y 6
|
|
|
|
/* Curves... */
|
|
|
|
#define C_BWEIGHT 3
|
|
|
|
#define C_WEIGHT 4
|
|
|
|
#define C_RADIUS 5
|
|
|
|
#define C_TILT 6
|
|
|
|
/*Lattice... */
|
|
|
|
#define L_WEIGHT 4
|
|
|
|
|
2012-03-25 23:54:33 +00:00
|
|
|
uiBlock *block = (layout) ? uiLayoutAbsoluteBlock(layout) : NULL;
|
|
|
|
MDeformVert *dvert = NULL;
|
2011-03-28 12:16:20 +00:00
|
|
|
TransformProperties *tfp;
|
2012-10-09 09:14:37 +00:00
|
|
|
float median[NBR_TRANSFORM_PROPERTIES], ve_median[NBR_TRANSFORM_PROPERTIES];
|
|
|
|
int tot, totedgedata, totcurvedata, totlattdata, totskinradius, totcurvebweight;
|
2012-10-12 14:35:10 +00:00
|
|
|
int meshdata = FALSE;
|
2009-02-10 15:38:00 +00:00
|
|
|
char defstr[320];
|
2012-10-09 09:14:37 +00:00
|
|
|
PointerRNA data_ptr;
|
2011-09-30 08:27:38 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
fill_vn_fl(median, NBR_TRANSFORM_PROPERTIES, 0.0f);
|
|
|
|
tot = totedgedata = totcurvedata = totlattdata = totskinradius = totcurvebweight = 0;
|
|
|
|
defstr[0] = '\0';
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2011-03-28 12:16:20 +00:00
|
|
|
/* make sure we got storage */
|
2012-03-03 21:42:21 +00:00
|
|
|
if (v3d->properties_storage == NULL)
|
|
|
|
v3d->properties_storage = MEM_callocN(sizeof(TransformProperties), "TransformProperties");
|
|
|
|
tfp = v3d->properties_storage;
|
|
|
|
|
|
|
|
if (ob->type == OB_MESH) {
|
|
|
|
Mesh *me = ob->data;
|
2009-05-23 03:24:15 +00:00
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
2009-07-16 06:27:37 +00:00
|
|
|
BMesh *bm = em->bm;
|
2012-03-03 21:42:21 +00:00
|
|
|
BMVert *eve, *evedef = NULL;
|
2009-05-23 03:24:15 +00:00
|
|
|
BMEdge *eed;
|
|
|
|
BMIter iter;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2013-01-10 04:43:31 +00:00
|
|
|
const int cd_vert_skin_offset = CustomData_get_offset(&bm->vdata, CD_MVERT_SKIN);
|
|
|
|
const int cd_vert_bweight_offset = CustomData_get_offset(&bm->vdata, CD_BWEIGHT);
|
|
|
|
const int cd_edge_bweight_offset = CustomData_get_offset(&bm->edata, CD_BWEIGHT);
|
|
|
|
const int cd_edge_crease_offset = CustomData_get_offset(&bm->edata, CD_CREASE);
|
|
|
|
|
2013-01-10 14:38:30 +00:00
|
|
|
if (bm->totvertsel) {
|
|
|
|
BM_ITER_MESH (eve, &iter, bm, BM_VERTS_OF_MESH) {
|
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT)) {
|
|
|
|
evedef = eve;
|
|
|
|
tot++;
|
|
|
|
add_v3_v3(&median[LOC_X], eve->co);
|
|
|
|
|
|
|
|
/* TODO cd_vert_bweight_offset */
|
|
|
|
(void)cd_vert_bweight_offset;
|
|
|
|
|
|
|
|
if (cd_vert_skin_offset != -1) {
|
|
|
|
MVertSkin *vs = BM_ELEM_CD_GET_VOID_P(eve, cd_vert_skin_offset);
|
|
|
|
add_v2_v2(&median[M_SKIN_X], vs->radius); /* Third val not used currently. */
|
|
|
|
totskinradius++;
|
|
|
|
}
|
2012-07-18 14:30:31 +00:00
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
2009-05-23 03:24:15 +00:00
|
|
|
|
2013-01-10 04:43:31 +00:00
|
|
|
if ((cd_edge_bweight_offset != -1) ||
|
|
|
|
(cd_edge_crease_offset != -1))
|
|
|
|
{
|
2013-01-10 14:38:30 +00:00
|
|
|
if (bm->totedgesel) {
|
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT)) {
|
|
|
|
if (cd_edge_bweight_offset != -1) {
|
|
|
|
median[M_WEIGHT] += BM_ELEM_CD_GET_FLOAT(eed, cd_edge_bweight_offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cd_edge_crease_offset != -1) {
|
|
|
|
median[M_CREASE] += BM_ELEM_CD_GET_FLOAT(eed, cd_edge_crease_offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
totedgedata++;
|
2013-01-10 04:43:31 +00:00
|
|
|
}
|
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check for defgroups */
|
2012-02-22 16:52:06 +00:00
|
|
|
if (evedef)
|
2012-03-03 21:42:21 +00:00
|
|
|
dvert = CustomData_bmesh_get(&bm->vdata, evedef->head.data, CD_MDEFORMVERT);
|
|
|
|
if (tot == 1 && dvert && dvert->totweight) {
|
2009-02-10 15:38:00 +00:00
|
|
|
bDeformGroup *dg;
|
2012-03-03 21:42:21 +00:00
|
|
|
int i, max = 1, init = 1;
|
2009-02-10 15:38:00 +00:00
|
|
|
char str[320];
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-03-25 23:54:33 +00:00
|
|
|
for (i = 0; i < dvert->totweight; i++) {
|
|
|
|
dg = BLI_findlink(&ob->defbase, dvert->dw[i].def_nr);
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dg) {
|
2012-03-03 21:42:21 +00:00
|
|
|
max += BLI_snprintf(str, sizeof(str), "%s %%x%d|", dg->name, dvert->dw[i].def_nr);
|
2012-01-12 13:16:30 +00:00
|
|
|
if (max < sizeof(str)) strcat(defstr, str);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2010-01-22 06:48:29 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
if (tfp->curdef == dvert->dw[i].def_nr) {
|
|
|
|
init = 0;
|
|
|
|
tfp->defweightp = &dvert->dw[i].weight;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
if (init) { /* needs new initialized */
|
|
|
|
tfp->curdef = dvert->dw[0].def_nr;
|
|
|
|
tfp->defweightp = &dvert->dw[0].weight;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
|
|
|
|
meshdata = totedgedata || totskinradius;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
else if (ob->type == OB_CURVE || ob->type == OB_SURF) {
|
|
|
|
Curve *cu = ob->data;
|
2009-02-10 15:38:00 +00:00
|
|
|
Nurb *nu;
|
|
|
|
BPoint *bp;
|
|
|
|
BezTriple *bezt;
|
|
|
|
int a;
|
2012-04-28 16:49:00 +00:00
|
|
|
ListBase *nurbs = BKE_curve_editNurbs_get(cu);
|
2012-03-03 21:42:21 +00:00
|
|
|
StructRNA *seltype = NULL;
|
|
|
|
void *selp = NULL;
|
2010-07-25 11:57:36 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
nu = nurbs->first;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (nu) {
|
|
|
|
if (nu->type == CU_BEZIER) {
|
2012-03-03 21:42:21 +00:00
|
|
|
bezt = nu->bezt;
|
|
|
|
a = nu->pntsu;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (a--) {
|
|
|
|
if (bezt->f2 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(&median[LOC_X], bezt->vec[1]);
|
2009-02-10 15:38:00 +00:00
|
|
|
tot++;
|
2012-10-09 09:14:37 +00:00
|
|
|
median[C_WEIGHT] += bezt->weight;
|
|
|
|
median[C_RADIUS] += bezt->radius;
|
|
|
|
median[C_TILT] += bezt->alfa;
|
|
|
|
if (!totcurvedata) { /* I.e. first time... */
|
|
|
|
selp = bezt;
|
|
|
|
seltype = &RNA_BezierSplinePoint;
|
|
|
|
}
|
|
|
|
totcurvedata++;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
else {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (bezt->f1 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(&median[LOC_X], bezt->vec[0]);
|
2009-02-10 15:38:00 +00:00
|
|
|
tot++;
|
|
|
|
}
|
2012-02-22 16:52:06 +00:00
|
|
|
if (bezt->f3 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(&median[LOC_X], bezt->vec[2]);
|
2009-02-10 15:38:00 +00:00
|
|
|
tot++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
bezt++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2012-03-03 21:42:21 +00:00
|
|
|
bp = nu->bp;
|
2012-03-25 23:54:33 +00:00
|
|
|
a = nu->pntsu * nu->pntsv;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (a--) {
|
|
|
|
if (bp->f1 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(&median[LOC_X], bp->vec);
|
|
|
|
median[C_BWEIGHT] += bp->vec[3];
|
|
|
|
totcurvebweight++;
|
2009-02-10 15:38:00 +00:00
|
|
|
tot++;
|
2012-10-09 09:14:37 +00:00
|
|
|
median[C_WEIGHT] += bp->weight;
|
|
|
|
median[C_RADIUS] += bp->radius;
|
|
|
|
median[C_TILT] += bp->alfa;
|
|
|
|
if (!totcurvedata) { /* I.e. first time... */
|
|
|
|
selp = bp;
|
|
|
|
seltype = &RNA_SplinePoint;
|
|
|
|
}
|
|
|
|
totcurvedata++;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
bp++;
|
|
|
|
}
|
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
nu = nu->next;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2011-11-03 12:28:32 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (totcurvedata == 1)
|
|
|
|
RNA_pointer_create(&cu->id, seltype, selp, &data_ptr);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
else if (ob->type == OB_LATTICE) {
|
|
|
|
Lattice *lt = ob->data;
|
2009-02-10 15:38:00 +00:00
|
|
|
BPoint *bp;
|
|
|
|
int a;
|
2012-10-09 09:14:37 +00:00
|
|
|
StructRNA *seltype = NULL;
|
|
|
|
void *selp = NULL;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
a = lt->editlatt->latt->pntsu * lt->editlatt->latt->pntsv * lt->editlatt->latt->pntsw;
|
|
|
|
bp = lt->editlatt->latt->def;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (a--) {
|
|
|
|
if (bp->f1 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(&median[LOC_X], bp->vec);
|
2009-02-10 15:38:00 +00:00
|
|
|
tot++;
|
2012-10-09 09:14:37 +00:00
|
|
|
median[L_WEIGHT] += bp->weight;
|
|
|
|
if (!totlattdata) { /* I.e. first time... */
|
|
|
|
selp = bp;
|
|
|
|
seltype = &RNA_LatticePoint;
|
|
|
|
}
|
|
|
|
totlattdata++;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
bp++;
|
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
|
|
|
|
if (totlattdata == 1)
|
|
|
|
RNA_pointer_create(<->id, seltype, selp, &data_ptr);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
if (tot == 0) {
|
|
|
|
uiDefBut(block, LABEL, 0, IFACE_("Nothing selected"), 0, 130, 200, 20, NULL, 0, 0, 0, 0, "");
|
2011-03-28 15:01:19 +00:00
|
|
|
return;
|
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
/* Location, X/Y/Z */
|
|
|
|
mul_v3_fl(&median[LOC_X], 1.0f / (float)tot);
|
2012-02-22 16:52:06 +00:00
|
|
|
if (v3d->flag & V3D_GLOBAL_STATS)
|
2012-10-09 09:14:37 +00:00
|
|
|
mul_m4_v3(ob->obmat, &median[LOC_X]);
|
|
|
|
|
|
|
|
if (meshdata) {
|
|
|
|
if (totedgedata) {
|
|
|
|
median[M_CREASE] /= (float)totedgedata;
|
|
|
|
median[M_WEIGHT] /= (float)totedgedata;
|
|
|
|
}
|
|
|
|
if (totskinradius) {
|
|
|
|
median[M_SKIN_X] /= (float)totskinradius;
|
|
|
|
median[M_SKIN_Y] /= (float)totskinradius;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (totcurvedata) {
|
|
|
|
median[C_WEIGHT] /= (float)totcurvedata;
|
|
|
|
median[C_RADIUS] /= (float)totcurvedata;
|
|
|
|
median[C_TILT] /= (float)totcurvedata;
|
|
|
|
if (totcurvebweight)
|
|
|
|
median[C_BWEIGHT] /= (float)totcurvebweight;
|
|
|
|
}
|
|
|
|
else if (totlattdata)
|
|
|
|
median[L_WEIGHT] /= (float)totlattdata;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
if (block) { /* buttons */
|
2010-12-10 23:31:03 +00:00
|
|
|
uiBut *but;
|
2012-04-20 16:17:52 +00:00
|
|
|
int yi = 200;
|
2012-12-13 01:21:12 +00:00
|
|
|
const int buth = 20 * UI_DPI_FAC;
|
2012-04-20 16:17:52 +00:00
|
|
|
const int but_margin = 2;
|
2012-10-09 09:14:37 +00:00
|
|
|
const char *c;
|
2011-01-09 01:17:56 +00:00
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
memcpy(tfp->ve_median, median, sizeof(tfp->ve_median));
|
2012-03-02 10:30:11 +00:00
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
uiBlockBeginAlign(block);
|
2012-03-03 21:42:21 +00:00
|
|
|
if (tot == 1) {
|
2012-10-09 09:14:37 +00:00
|
|
|
if (totcurvedata) /* Curve */
|
|
|
|
c = IFACE_("Control Point:");
|
|
|
|
else /* Mesh or lattice */
|
|
|
|
c = IFACE_("Vertex:");
|
2012-03-02 10:30:11 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
else
|
|
|
|
c = IFACE_("Median:");
|
|
|
|
uiDefBut(block, LABEL, 0, c, 0, yi -= buth, 200, buth, NULL, 0, 0, 0, 0, "");
|
2012-03-02 10:30:11 +00:00
|
|
|
|
|
|
|
uiBlockBeginAlign(block);
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
/* Should be no need to translate these. */
|
2012-04-20 16:17:52 +00:00
|
|
|
but = uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, "X:", 0, yi -= buth, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[LOC_X]), -lim, lim, 10, RNA_TRANSLATION_PREC_DEFAULT, "");
|
2012-03-02 10:30:11 +00:00
|
|
|
uiButSetUnitType(but, PROP_UNIT_LENGTH);
|
2012-04-20 16:17:52 +00:00
|
|
|
but = uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, "Y:", 0, yi -= buth, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[LOC_Y]), -lim, lim, 10, RNA_TRANSLATION_PREC_DEFAULT, "");
|
2012-03-02 10:30:11 +00:00
|
|
|
uiButSetUnitType(but, PROP_UNIT_LENGTH);
|
2012-04-29 15:47:02 +00:00
|
|
|
but = uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, "Z:", 0, yi -= buth, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[LOC_Z]), -lim, lim, 10, RNA_TRANSLATION_PREC_DEFAULT, "");
|
2012-03-02 10:30:11 +00:00
|
|
|
uiButSetUnitType(but, PROP_UNIT_LENGTH);
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (totcurvebweight == tot) {
|
2012-04-20 16:17:52 +00:00
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, "W:", 0, yi -= buth, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[C_BWEIGHT]), 0.01, 100.0, 1, 3, "");
|
2012-03-02 10:30:11 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
uiBlockBeginAlign(block);
|
2012-04-20 16:17:52 +00:00
|
|
|
uiDefButBitS(block, TOG, V3D_GLOBAL_STATS, B_REDR, IFACE_("Global"),
|
|
|
|
0, yi -= buth + but_margin, 100, buth,
|
2012-03-03 21:42:21 +00:00
|
|
|
&v3d->flag, 0, 0, 0, 0, "Displays global values");
|
2012-04-20 16:17:52 +00:00
|
|
|
uiDefButBitS(block, TOGN, V3D_GLOBAL_STATS, B_REDR, IFACE_("Local"),
|
|
|
|
100, yi, 100, buth,
|
2012-03-03 21:42:21 +00:00
|
|
|
&v3d->flag, 0, 0, 0, 0, "Displays local values");
|
2012-03-02 10:30:11 +00:00
|
|
|
uiBlockEndAlign(block);
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
/* Meshes... */
|
|
|
|
if (meshdata) {
|
|
|
|
if (totedgedata) {
|
2013-01-10 04:43:31 +00:00
|
|
|
Mesh *me = ob->data;
|
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
|
|
|
BMesh *bm = em->bm;
|
|
|
|
|
|
|
|
const int cd_edge_bweight_offset = CustomData_get_offset(&bm->edata, CD_BWEIGHT);
|
|
|
|
const int cd_edge_crease_offset = CustomData_get_offset(&bm->edata, CD_CREASE);
|
|
|
|
|
|
|
|
if (cd_edge_crease_offset != -1) {
|
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN,
|
|
|
|
totedgedata == 1 ? IFACE_("Crease:") : IFACE_("Mean Crease:"),
|
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&(tfp->ve_median[M_CREASE]), 0.0, 1.0, 1, 3, TIP_("Weight used by SubSurf modifier"));
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cd_edge_bweight_offset != -1) {
|
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN,
|
|
|
|
totedgedata == 1 ? IFACE_("Bevel Weight:") : IFACE_("Mean Bevel Weight:"),
|
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&(tfp->ve_median[M_WEIGHT]), 0.0, 1.0, 1, 3, TIP_("Weight used by Bevel modifier"));
|
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
}
|
|
|
|
if (totskinradius) {
|
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN,
|
|
|
|
totskinradius == 1 ? IFACE_("Radius X:") : IFACE_("Mean Radius X:"),
|
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&(tfp->ve_median[M_SKIN_X]), 0.0, 100.0, 1, 3, TIP_("X radius used by Skin modifier"));
|
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN,
|
|
|
|
totskinradius == 1 ? IFACE_("Radius Y:") : IFACE_("Mean Radius Y:"),
|
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&(tfp->ve_median[M_SKIN_Y]), 0.0, 100.0, 1, 3, TIP_("Y radius used by Skin modifier"));
|
|
|
|
}
|
2012-03-02 10:30:11 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
/* Curve... */
|
|
|
|
else if (totcurvedata == 1) {
|
|
|
|
uiDefButR(block, NUM, 0, "Weight", 0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&data_ptr, "weight_softbody", 0, 0.0, 1.0, 1, 3, NULL);
|
|
|
|
uiDefButR(block, NUM, 0, "Radius", 0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&data_ptr, "radius", 0, 0.0, 100.0, 1, 3, NULL);
|
|
|
|
uiDefButR(block, NUM, 0, "Tilt", 0, yi -= buth + but_margin, 200, buth,
|
2012-12-14 09:29:05 +00:00
|
|
|
&data_ptr, "tilt", 0, -FLT_MAX, FLT_MAX, 1, 3, NULL);
|
2012-03-02 10:30:11 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
else if (totcurvedata > 1) {
|
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, IFACE_("Mean Weight:"),
|
2012-04-20 16:17:52 +00:00
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[C_WEIGHT]), 0.0, 1.0, 1, 3, TIP_("Weight used for SoftBody Goal"));
|
2012-04-20 16:17:52 +00:00
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, IFACE_("Mean Radius:"),
|
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[C_RADIUS]), 0.0, 100.0, 1, 3, TIP_("Radius of curve control points"));
|
|
|
|
but = uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, IFACE_("Mean Tilt:"),
|
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
2012-12-14 09:29:05 +00:00
|
|
|
&(tfp->ve_median[C_TILT]), -FLT_MAX, FLT_MAX, 1, 3,
|
2012-10-16 07:53:10 +00:00
|
|
|
TIP_("Tilt of curve control points"));
|
2012-10-09 09:14:37 +00:00
|
|
|
uiButSetUnitType(but, PROP_UNIT_ROTATION);
|
2012-07-18 14:30:31 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
/* Lattice... */
|
|
|
|
else if (totlattdata == 1) {
|
|
|
|
uiDefButR(block, NUM, 0, "Weight", 0, yi -= buth + but_margin, 200, buth,
|
|
|
|
&data_ptr, "weight_softbody", 0, 0.0, 1.0, 1, 3, NULL);
|
2011-09-30 08:27:38 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
else if (totlattdata > 1) {
|
|
|
|
uiDefButF(block, NUM, B_OBJECTPANELMEDIAN, IFACE_("Mean Weight:"),
|
2012-04-20 16:17:52 +00:00
|
|
|
0, yi -= buth + but_margin, 200, buth,
|
2012-10-09 09:14:37 +00:00
|
|
|
&(tfp->ve_median[L_WEIGHT]), 0.0, 1.0, 1, 3, TIP_("Weight used for SoftBody Goal"));
|
2011-09-30 08:27:38 +00:00
|
|
|
}
|
|
|
|
|
2012-03-02 10:30:11 +00:00
|
|
|
uiBlockEndAlign(block);
|
|
|
|
uiBlockEndAlign(block);
|
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
else { /* apply */
|
2012-10-12 14:35:10 +00:00
|
|
|
int i;
|
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
memcpy(ve_median, tfp->ve_median, sizeof(tfp->ve_median));
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (v3d->flag & V3D_GLOBAL_STATS) {
|
2009-11-10 20:43:45 +00:00
|
|
|
invert_m4_m4(ob->imat, ob->obmat);
|
2012-10-09 09:14:37 +00:00
|
|
|
mul_m4_v3(ob->imat, &median[LOC_X]);
|
|
|
|
mul_m4_v3(ob->imat, &ve_median[LOC_X]);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
i = NBR_TRANSFORM_PROPERTIES;
|
|
|
|
while (i--)
|
|
|
|
median[i] = ve_median[i] - median[i];
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
if (ob->type == OB_MESH) {
|
|
|
|
Mesh *me = ob->data;
|
2010-01-28 00:45:30 +00:00
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
2012-02-12 19:11:09 +00:00
|
|
|
BMesh *bm = em->bm;
|
2010-01-28 00:45:30 +00:00
|
|
|
BMIter iter;
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (len_v3(&median[LOC_X]) > 0.000001f) {
|
2012-10-12 14:35:10 +00:00
|
|
|
BMVert *eve;
|
2010-12-15 07:15:51 +00:00
|
|
|
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eve, &iter, bm, BM_VERTS_OF_MESH) {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT)) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(eve->co, &median[LOC_X]);
|
2010-12-15 07:15:51 +00:00
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-03-27 04:46:52 +00:00
|
|
|
EDBM_mesh_normals_update(em);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[M_CREASE] != 0.0f) {
|
2013-01-10 04:43:31 +00:00
|
|
|
const int cd_edge_crease_offset = CustomData_get_offset(&bm->edata, CD_CREASE);
|
2012-10-09 09:14:37 +00:00
|
|
|
const float sca = compute_scale_factor(ve_median[M_CREASE], median[M_CREASE]);
|
2013-01-10 04:43:31 +00:00
|
|
|
BMEdge *eed;
|
2010-12-15 07:15:51 +00:00
|
|
|
|
2012-03-02 10:30:11 +00:00
|
|
|
if (ELEM(sca, 0.0f, 1.0f)) {
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
BM_ELEM_CD_SET_FLOAT(eed, cd_edge_crease_offset, sca);
|
2010-12-15 07:15:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-03-02 10:30:11 +00:00
|
|
|
else if (sca > 0.0f) {
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT) && !BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
float *crease = BM_ELEM_CD_GET_VOID_P(eed, cd_edge_crease_offset);
|
|
|
|
*crease *= sca;
|
|
|
|
CLAMP(*crease, 0.0f, 1.0f);
|
2010-12-15 07:15:51 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-02 10:30:11 +00:00
|
|
|
}
|
|
|
|
else {
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT) && !BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
float *crease = BM_ELEM_CD_GET_VOID_P(eed, cd_edge_crease_offset);
|
|
|
|
*crease = 1.0f + ((1.0f - *crease) * sca);
|
|
|
|
CLAMP(*crease, 0.0f, 1.0f);
|
2010-12-15 07:15:51 +00:00
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-02-12 18:17:30 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[M_WEIGHT] != 0.0f) {
|
2013-01-10 04:43:31 +00:00
|
|
|
const int cd_edge_bweight_offset = CustomData_get_offset(&bm->edata, CD_BWEIGHT);
|
2012-10-09 09:14:37 +00:00
|
|
|
const float sca = compute_scale_factor(ve_median[M_WEIGHT], median[M_WEIGHT]);
|
2013-01-10 04:43:31 +00:00
|
|
|
BMEdge *eed;
|
|
|
|
|
|
|
|
BLI_assert(cd_edge_bweight_offset != -1);
|
2011-09-30 08:27:38 +00:00
|
|
|
|
2012-03-02 10:30:11 +00:00
|
|
|
if (ELEM(sca, 0.0f, 1.0f)) {
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
float *bweight = BM_ELEM_CD_GET_VOID_P(eed, cd_edge_bweight_offset);
|
|
|
|
*bweight = sca;
|
2011-09-30 08:27:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-03-02 10:30:11 +00:00
|
|
|
else if (sca > 0.0f) {
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT) && !BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
float *bweight = BM_ELEM_CD_GET_VOID_P(eed, cd_edge_bweight_offset);
|
|
|
|
*bweight *= sca;
|
|
|
|
CLAMP(*bweight, 0.0f, 1.0f);
|
2011-09-30 08:27:38 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-02 10:30:11 +00:00
|
|
|
}
|
|
|
|
else {
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eed, &iter, bm, BM_EDGES_OF_MESH) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (BM_elem_flag_test(eed, BM_ELEM_SELECT) && !BM_elem_flag_test(eed, BM_ELEM_HIDDEN)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
float *bweight = BM_ELEM_CD_GET_VOID_P(eed, cd_edge_bweight_offset);
|
|
|
|
*bweight = 1.0f + ((1.0f - *bweight) * sca);
|
|
|
|
CLAMP(*bweight, 0.0f, 1.0f);
|
2011-09-30 08:27:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-07-18 14:30:31 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[M_SKIN_X] != 0.0f) {
|
2013-01-10 04:43:31 +00:00
|
|
|
const int cd_vert_skin_offset = CustomData_get_offset(&bm->vdata, CD_MVERT_SKIN);
|
2012-07-18 14:30:31 +00:00
|
|
|
/* That one is not clamped to [0.0, 1.0]. */
|
2012-10-09 09:14:37 +00:00
|
|
|
float sca = ve_median[M_SKIN_X];
|
2013-01-10 04:43:31 +00:00
|
|
|
BMVert *eve;
|
|
|
|
|
|
|
|
BLI_assert(cd_vert_skin_offset != -1);
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (ve_median[M_SKIN_X] - median[M_SKIN_X] == 0.0f) {
|
2012-07-18 14:30:31 +00:00
|
|
|
BM_ITER_MESH (eve, &iter, bm, BM_VERTS_OF_MESH) {
|
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
MVertSkin *vs = BM_ELEM_CD_GET_VOID_P(eve, cd_vert_skin_offset);
|
|
|
|
vs->radius[0] = sca;
|
2012-07-18 14:30:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2012-10-09 09:14:37 +00:00
|
|
|
sca /= (ve_median[M_SKIN_X] - median[M_SKIN_X]);
|
2012-07-18 14:30:31 +00:00
|
|
|
BM_ITER_MESH (eve, &iter, bm, BM_VERTS_OF_MESH) {
|
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
MVertSkin *vs = BM_ELEM_CD_GET_VOID_P(eve, cd_vert_skin_offset);
|
|
|
|
vs->radius[0] *= sca;
|
2012-07-18 14:30:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[M_SKIN_Y] != 0.0f) {
|
2013-01-10 04:43:31 +00:00
|
|
|
const int cd_vert_skin_offset = CustomData_get_offset(&bm->vdata, CD_MVERT_SKIN);
|
2012-07-18 14:30:31 +00:00
|
|
|
/* That one is not clamped to [0.0, 1.0]. */
|
2012-10-09 09:14:37 +00:00
|
|
|
float sca = ve_median[M_SKIN_Y];
|
2013-01-10 04:43:31 +00:00
|
|
|
BMVert *eve;
|
|
|
|
|
|
|
|
BLI_assert(cd_vert_skin_offset != -1);
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (ve_median[M_SKIN_Y] - median[M_SKIN_Y] == 0.0f) {
|
2012-07-18 14:30:31 +00:00
|
|
|
BM_ITER_MESH (eve, &iter, bm, BM_VERTS_OF_MESH) {
|
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
MVertSkin *vs = BM_ELEM_CD_GET_VOID_P(eve, cd_vert_skin_offset);
|
|
|
|
vs->radius[1] = sca;
|
2012-07-18 14:30:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2012-10-09 09:14:37 +00:00
|
|
|
sca /= (ve_median[M_SKIN_Y] - median[M_SKIN_Y]);
|
2012-07-18 14:30:31 +00:00
|
|
|
BM_ITER_MESH (eve, &iter, bm, BM_VERTS_OF_MESH) {
|
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT)) {
|
2013-01-10 04:43:31 +00:00
|
|
|
MVertSkin *vs = BM_ELEM_CD_GET_VOID_P(eve, cd_vert_skin_offset);
|
|
|
|
vs->radius[1] *= sca;
|
2012-07-18 14:30:31 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
else if (ELEM(ob->type, OB_CURVE, OB_SURF)) {
|
|
|
|
Curve *cu = ob->data;
|
2009-02-10 15:38:00 +00:00
|
|
|
Nurb *nu;
|
|
|
|
BPoint *bp;
|
|
|
|
BezTriple *bezt;
|
|
|
|
int a;
|
2012-04-28 16:49:00 +00:00
|
|
|
ListBase *nurbs = BKE_curve_editNurbs_get(cu);
|
2012-10-09 09:14:37 +00:00
|
|
|
const float scale_w = compute_scale_factor(ve_median[C_WEIGHT], median[C_WEIGHT]);
|
2010-07-25 11:57:36 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
nu = nurbs->first;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (nu) {
|
|
|
|
if (nu->type == CU_BEZIER) {
|
2012-03-03 21:42:21 +00:00
|
|
|
bezt = nu->bezt;
|
|
|
|
a = nu->pntsu;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (a--) {
|
|
|
|
if (bezt->f2 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(bezt->vec[0], &median[LOC_X]);
|
|
|
|
add_v3_v3(bezt->vec[1], &median[LOC_X]);
|
|
|
|
add_v3_v3(bezt->vec[2], &median[LOC_X]);
|
2012-03-02 10:30:11 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[C_WEIGHT] != 0.0f) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (ELEM(scale_w, 0.0f, 1.0f)) {
|
|
|
|
bezt->weight = scale_w;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
bezt->weight = scale_w > 0.0f ? bezt->weight * scale_w :
|
|
|
|
1.0f + ((1.0f - bezt->weight) * scale_w);
|
|
|
|
CLAMP(bezt->weight, 0.0f, 1.0f);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
bezt->radius += median[C_RADIUS];
|
|
|
|
bezt->alfa += median[C_TILT];
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
else {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (bezt->f1 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(bezt->vec[0], &median[LOC_X]);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-02-22 16:52:06 +00:00
|
|
|
if (bezt->f3 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(bezt->vec[2], &median[LOC_X]);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
bezt++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else {
|
2012-03-03 21:42:21 +00:00
|
|
|
bp = nu->bp;
|
2012-03-25 23:54:33 +00:00
|
|
|
a = nu->pntsu * nu->pntsv;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (a--) {
|
|
|
|
if (bp->f1 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(bp->vec, &median[LOC_X]);
|
|
|
|
bp->vec[3] += median[C_BWEIGHT];
|
2012-03-02 10:30:11 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[C_WEIGHT] != 0.0f) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (ELEM(scale_w, 0.0f, 1.0f)) {
|
|
|
|
bp->weight = scale_w;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
bp->weight = scale_w > 0.0f ? bp->weight * scale_w :
|
|
|
|
1.0f + ((1.0f - bp->weight) * scale_w);
|
|
|
|
CLAMP(bp->weight, 0.0f, 1.0f);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
bp->radius += median[C_RADIUS];
|
|
|
|
bp->alfa += median[C_TILT];
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
bp++;
|
|
|
|
}
|
|
|
|
}
|
2012-04-28 16:49:00 +00:00
|
|
|
BKE_nurb_test2D(nu);
|
|
|
|
BKE_nurb_handles_test(nu); /* test for bezier too */
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
nu = nu->next;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
else if (ob->type == OB_LATTICE) {
|
|
|
|
Lattice *lt = ob->data;
|
2009-02-10 15:38:00 +00:00
|
|
|
BPoint *bp;
|
|
|
|
int a;
|
2012-10-09 09:14:37 +00:00
|
|
|
const float scale_w = compute_scale_factor(ve_median[L_WEIGHT], median[L_WEIGHT]);
|
2012-03-02 10:30:11 +00:00
|
|
|
|
2012-03-25 23:54:33 +00:00
|
|
|
a = lt->editlatt->latt->pntsu * lt->editlatt->latt->pntsv * lt->editlatt->latt->pntsw;
|
2012-03-03 21:42:21 +00:00
|
|
|
bp = lt->editlatt->latt->def;
|
2012-02-22 16:52:06 +00:00
|
|
|
while (a--) {
|
|
|
|
if (bp->f1 & SELECT) {
|
2012-10-09 09:14:37 +00:00
|
|
|
add_v3_v3(bp->vec, &median[LOC_X]);
|
2012-03-02 10:30:11 +00:00
|
|
|
|
2012-10-09 09:14:37 +00:00
|
|
|
if (median[L_WEIGHT] != 0.0f) {
|
2012-03-02 10:30:11 +00:00
|
|
|
if (ELEM(scale_w, 0.0f, 1.0f)) {
|
|
|
|
bp->weight = scale_w;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
bp->weight = scale_w > 0.0f ? bp->weight * scale_w :
|
2012-05-08 15:55:29 +00:00
|
|
|
1.0f + ((1.0f - bp->weight) * scale_w);
|
2012-03-02 10:30:11 +00:00
|
|
|
CLAMP(bp->weight, 0.0f, 1.0f);
|
|
|
|
}
|
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
bp++;
|
|
|
|
}
|
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
/* ED_undo_push(C, "Transform properties"); */
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
|
|
|
|
/* Clean up! */
|
|
|
|
/* Location, common to all. */
|
|
|
|
#undef LOC_X
|
|
|
|
#undef LOC_Y
|
|
|
|
#undef LOC_Z
|
|
|
|
/* Meshes (and lattice)... */
|
|
|
|
#undef M_CREASE
|
|
|
|
#undef M_WEIGHT
|
|
|
|
#undef M_SKIN_X
|
|
|
|
#undef M_SKIN_Y
|
|
|
|
/* Curves... */
|
|
|
|
#undef C_BWEIGHT
|
|
|
|
#undef C_WEIGHT
|
|
|
|
#undef C_RADIUS
|
|
|
|
#undef C_TILT
|
|
|
|
/* Lattice... */
|
|
|
|
#undef L_WEIGHT
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-10-09 09:14:37 +00:00
|
|
|
#undef NBR_TRANSFORM_PROPERTIES
|
|
|
|
|
|
|
|
|
2010-01-26 17:07:47 +00:00
|
|
|
#define B_VGRP_PNL_COPY 1
|
|
|
|
#define B_VGRP_PNL_NORMALIZE 2
|
|
|
|
#define B_VGRP_PNL_EDIT_SINGLE 8 /* or greater */
|
|
|
|
#define B_VGRP_PNL_COPY_SINGLE 16384 /* or greater */
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2010-03-09 04:32:40 +00:00
|
|
|
static void act_vert_def(Object *ob, BMVert **eve, MDeformVert **dvert)
|
2010-01-25 23:12:02 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
if (ob && ob->mode & OB_MODE_EDIT && ob->type == OB_MESH && ob->defbase.first) {
|
|
|
|
Mesh *me = ob->data;
|
2010-03-09 04:32:40 +00:00
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
2012-02-25 20:58:03 +00:00
|
|
|
BMEditSelection *ese = (BMEditSelection *)em->bm->selected.last;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (ese && ese->htype == BM_VERT) {
|
2012-02-25 22:23:40 +00:00
|
|
|
*eve = (BMVert *)ese->ele;
|
|
|
|
*dvert = CustomData_bmesh_get(&em->bm->vdata, (*eve)->head.data, CD_MDEFORMVERT);
|
2010-01-25 23:12:02 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
*eve = NULL;
|
|
|
|
*dvert = NULL;
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
|
|
|
|
2010-03-09 04:32:40 +00:00
|
|
|
static void editvert_mirror_update(Object *ob, BMVert *eve, int def_nr, int index)
|
2010-01-26 17:07:47 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
Mesh *me = ob->data;
|
2011-02-27 06:19:40 +00:00
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
|
|
|
BMVert *eve_mirr;
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
eve_mirr = editbmesh_get_x_mirror_vert(ob, em, eve, eve->co, index);
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (eve_mirr && eve_mirr != eve) {
|
2012-03-03 21:42:21 +00:00
|
|
|
MDeformVert *dvert_src = CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_MDEFORMVERT);
|
|
|
|
MDeformVert *dvert_dst = CustomData_bmesh_get(&em->bm->vdata, eve_mirr->head.data, CD_MDEFORMVERT);
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dvert_dst) {
|
|
|
|
if (def_nr == -1) {
|
2010-01-26 17:07:47 +00:00
|
|
|
/* all vgroups, add groups where neded */
|
2011-10-27 07:54:32 +00:00
|
|
|
int flip_map_len;
|
2012-03-03 21:42:21 +00:00
|
|
|
int *flip_map = defgroup_flip_map(ob, &flip_map_len, TRUE);
|
2011-10-27 07:54:32 +00:00
|
|
|
defvert_sync_mapped(dvert_dst, dvert_src, flip_map, flip_map_len, TRUE);
|
2010-01-26 17:07:47 +00:00
|
|
|
MEM_freeN(flip_map);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
/* single vgroup */
|
2012-03-03 21:42:21 +00:00
|
|
|
MDeformWeight *dw = defvert_verify_index(dvert_dst, defgroup_flip_index(ob, def_nr, 1));
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dw) {
|
2012-03-03 21:42:21 +00:00
|
|
|
dw->weight = defvert_find_weight(dvert_src, def_nr);
|
2010-01-26 17:07:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void vgroup_adjust_active(Object *ob, int def_nr)
|
|
|
|
{
|
2010-03-09 04:32:40 +00:00
|
|
|
BMVert *eve_act;
|
2010-01-26 17:07:47 +00:00
|
|
|
MDeformVert *dvert_act;
|
|
|
|
|
|
|
|
act_vert_def(ob, &eve_act, &dvert_act);
|
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dvert_act) {
|
|
|
|
if (((Mesh *)ob->data)->editflag & ME_EDIT_MIRROR_X)
|
2010-02-17 19:50:42 +00:00
|
|
|
editvert_mirror_update(ob, eve_act, def_nr, -1);
|
2010-01-26 17:07:47 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-01-25 23:12:02 +00:00
|
|
|
static void vgroup_copy_active_to_sel(Object *ob)
|
|
|
|
{
|
2010-03-09 04:32:40 +00:00
|
|
|
BMVert *eve_act;
|
2010-01-25 23:12:02 +00:00
|
|
|
MDeformVert *dvert_act;
|
|
|
|
|
|
|
|
act_vert_def(ob, &eve_act, &dvert_act);
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
if (dvert_act == NULL) {
|
2010-01-25 23:12:02 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
else {
|
2012-03-03 21:42:21 +00:00
|
|
|
Mesh *me = ob->data;
|
2010-03-09 04:32:40 +00:00
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
|
|
|
BMIter iter;
|
|
|
|
BMVert *eve;
|
2010-01-25 23:12:02 +00:00
|
|
|
MDeformVert *dvert;
|
2012-03-03 21:42:21 +00:00
|
|
|
int index = 0;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-04-19 13:47:58 +00:00
|
|
|
BM_ITER_MESH (eve, &iter, em->bm, BM_VERTS_OF_MESH) {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT) && eve != eve_act) {
|
2012-03-03 21:42:21 +00:00
|
|
|
dvert = CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_MDEFORMVERT);
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dvert) {
|
2010-01-26 13:50:17 +00:00
|
|
|
defvert_copy(dvert, dvert_act);
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (me->editflag & ME_EDIT_MIRROR_X)
|
2010-02-17 19:50:42 +00:00
|
|
|
editvert_mirror_update(ob, eve, -1, index);
|
2010-01-26 17:07:47 +00:00
|
|
|
|
|
|
|
}
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
2010-03-09 04:32:40 +00:00
|
|
|
|
|
|
|
index++;
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-12-14 22:54:38 +00:00
|
|
|
static void vgroup_copy_active_to_sel_single(Object *ob, const int def_nr)
|
2010-01-25 23:12:02 +00:00
|
|
|
{
|
2010-03-09 04:32:40 +00:00
|
|
|
BMVert *eve_act;
|
2011-12-14 22:54:38 +00:00
|
|
|
MDeformVert *dv_act;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2011-12-14 22:54:38 +00:00
|
|
|
act_vert_def(ob, &eve_act, &dv_act);
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
if (dv_act == NULL) {
|
2010-01-25 23:12:02 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
else {
|
2012-03-03 21:42:21 +00:00
|
|
|
Mesh *me = ob->data;
|
2010-03-09 04:32:40 +00:00
|
|
|
BMEditMesh *em = me->edit_btmesh;
|
|
|
|
BMIter iter;
|
|
|
|
BMVert *eve;
|
2011-12-14 22:54:38 +00:00
|
|
|
MDeformVert *dv;
|
2010-01-25 23:12:02 +00:00
|
|
|
MDeformWeight *dw;
|
2011-12-14 22:54:38 +00:00
|
|
|
float weight_act;
|
2012-03-03 21:42:21 +00:00
|
|
|
int index = 0;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
dw = defvert_find_index(dv_act, def_nr);
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dw == NULL)
|
2010-01-25 23:12:02 +00:00
|
|
|
return;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
weight_act = dw->weight;
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2012-02-12 10:51:45 +00:00
|
|
|
eve = BM_iter_new(&iter, em->bm, BM_VERTS_OF_MESH, NULL);
|
2012-03-03 21:42:21 +00:00
|
|
|
for (index = 0; eve; eve = BM_iter_step(&iter), index++) {
|
2012-02-22 16:52:06 +00:00
|
|
|
if (BM_elem_flag_test(eve, BM_ELEM_SELECT) && eve != eve_act) {
|
2012-03-03 21:42:21 +00:00
|
|
|
dv = CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_MDEFORMVERT);
|
|
|
|
dw = defvert_find_index(dv, def_nr);
|
2011-12-15 23:59:02 +00:00
|
|
|
if (dw) {
|
2012-03-03 21:42:21 +00:00
|
|
|
dw->weight = weight_act;
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2011-12-15 23:59:02 +00:00
|
|
|
if (me->editflag & ME_EDIT_MIRROR_X) {
|
|
|
|
editvert_mirror_update(ob, eve, -1, index);
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (me->editflag & ME_EDIT_MIRROR_X) {
|
2010-02-17 19:50:42 +00:00
|
|
|
editvert_mirror_update(ob, eve_act, -1, -1);
|
2011-12-14 22:54:38 +00:00
|
|
|
}
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void vgroup_normalize_active(Object *ob)
|
|
|
|
{
|
2010-03-09 04:32:40 +00:00
|
|
|
BMVert *eve_act;
|
2010-01-25 23:12:02 +00:00
|
|
|
MDeformVert *dvert_act;
|
|
|
|
|
|
|
|
act_vert_def(ob, &eve_act, &dvert_act);
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
if (dvert_act == NULL)
|
2010-01-25 23:12:02 +00:00
|
|
|
return;
|
|
|
|
|
2010-01-26 13:50:17 +00:00
|
|
|
defvert_normalize(dvert_act);
|
2010-01-26 17:07:47 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (((Mesh *)ob->data)->editflag & ME_EDIT_MIRROR_X)
|
2010-02-17 19:50:42 +00:00
|
|
|
editvert_mirror_update(ob, eve_act, -1, -1);
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
|
|
|
|
2010-10-15 12:29:02 +00:00
|
|
|
static void do_view3d_vgroup_buttons(bContext *C, void *UNUSED(arg), int event)
|
2010-01-25 23:12:02 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
Scene *scene = CTX_data_scene(C);
|
|
|
|
Object *ob = OBACT;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
/* XXX TODO Use operators? */
|
|
|
|
if (event == B_VGRP_PNL_NORMALIZE) {
|
2010-01-25 23:12:02 +00:00
|
|
|
vgroup_normalize_active(ob);
|
|
|
|
}
|
2012-02-22 16:52:06 +00:00
|
|
|
else if (event == B_VGRP_PNL_COPY) {
|
2010-01-25 23:12:02 +00:00
|
|
|
vgroup_copy_active_to_sel(ob);
|
|
|
|
}
|
2012-02-22 16:52:06 +00:00
|
|
|
else if (event >= B_VGRP_PNL_COPY_SINGLE) {
|
2010-01-25 23:12:02 +00:00
|
|
|
vgroup_copy_active_to_sel_single(ob, event - B_VGRP_PNL_COPY_SINGLE);
|
|
|
|
}
|
2012-02-22 16:52:06 +00:00
|
|
|
else if (event >= B_VGRP_PNL_EDIT_SINGLE) {
|
2010-01-26 17:07:47 +00:00
|
|
|
vgroup_adjust_active(ob, event - B_VGRP_PNL_EDIT_SINGLE);
|
|
|
|
}
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
#if 0 /* TODO */
|
|
|
|
if (((Mesh *)ob->data)->editflag & ME_EDIT_MIRROR_X)
|
|
|
|
ED_vgroup_mirror(ob, 1, 1, 0);
|
|
|
|
#endif
|
2010-01-25 23:12:02 +00:00
|
|
|
|
|
|
|
/* default for now */
|
2010-12-05 18:59:23 +00:00
|
|
|
DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
|
2012-03-25 23:54:33 +00:00
|
|
|
WM_event_add_notifier(C, NC_GEOM | ND_DATA, ob->data);
|
2010-01-25 23:12:02 +00:00
|
|
|
}
|
|
|
|
|
2011-02-13 14:16:36 +00:00
|
|
|
static int view3d_panel_vgroup_poll(const bContext *C, PanelType *UNUSED(pt))
|
2010-01-25 23:12:02 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
Scene *scene = CTX_data_scene(C);
|
|
|
|
Object *ob = OBACT;
|
2010-03-09 04:32:40 +00:00
|
|
|
BMVert *eve_act;
|
2010-01-25 23:12:02 +00:00
|
|
|
MDeformVert *dvert_act;
|
|
|
|
|
|
|
|
act_vert_def(ob, &eve_act, &dvert_act);
|
|
|
|
|
|
|
|
return dvert_act ? dvert_act->totweight : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void view3d_panel_vgroup(const bContext *C, Panel *pa)
|
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
uiBlock *block = uiLayoutAbsoluteBlock(pa->layout);
|
|
|
|
Scene *scene = CTX_data_scene(C);
|
|
|
|
Object *ob = OBACT;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2010-03-09 04:32:40 +00:00
|
|
|
BMVert *eve;
|
2011-12-14 22:54:38 +00:00
|
|
|
MDeformVert *dv;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2011-12-14 22:54:38 +00:00
|
|
|
act_vert_def(ob, &eve, &dv);
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dv && dv->totweight) {
|
2010-01-25 23:12:02 +00:00
|
|
|
uiLayout *col;
|
|
|
|
bDeformGroup *dg;
|
2011-12-14 22:54:38 +00:00
|
|
|
MDeformWeight *dw = dv->dw;
|
|
|
|
unsigned int i;
|
2010-01-25 23:12:02 +00:00
|
|
|
int yco = 0;
|
|
|
|
|
|
|
|
uiBlockSetHandleFunc(block, do_view3d_vgroup_buttons, NULL);
|
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
col = uiLayoutColumn(pa->layout, FALSE);
|
2012-03-03 21:42:21 +00:00
|
|
|
block = uiLayoutAbsoluteBlock(col);
|
2010-01-25 23:12:02 +00:00
|
|
|
|
|
|
|
uiBlockBeginAlign(block);
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
for (i = dv->totweight; i != 0; i--, dw++) {
|
2012-03-25 23:54:33 +00:00
|
|
|
dg = BLI_findlink(&ob->defbase, dw->def_nr);
|
2012-02-22 16:52:06 +00:00
|
|
|
if (dg) {
|
2012-03-03 21:42:21 +00:00
|
|
|
uiDefButF(block, NUM, B_VGRP_PNL_EDIT_SINGLE + dw->def_nr, dg->name, 0, yco, 180, 20,
|
|
|
|
&dw->weight, 0.0, 1.0, 1, 3, "");
|
|
|
|
uiDefBut(block, BUT, B_VGRP_PNL_COPY_SINGLE + dw->def_nr, "C", 180, yco, 20, 20,
|
|
|
|
NULL, 0, 0, 0, 0, TIP_("Copy this group's weight to other selected verts"));
|
2010-01-25 23:12:02 +00:00
|
|
|
yco -= 20;
|
|
|
|
}
|
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
yco -= 2;
|
2010-01-25 23:12:02 +00:00
|
|
|
|
|
|
|
uiBlockEndAlign(block);
|
|
|
|
uiBlockBeginAlign(block);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiDefBut(block, BUT, B_VGRP_PNL_NORMALIZE, IFACE_("Normalize"), 0, yco, 100, 20,
|
|
|
|
NULL, 0, 0, 0, 0, TIP_("Normalize active vertex weights"));
|
|
|
|
uiDefBut(block, BUT, B_VGRP_PNL_COPY, IFACE_("Copy"), 100, yco, 100, 20,
|
2012-07-03 17:20:21 +00:00
|
|
|
NULL, 0, 0, 0, 0, TIP_("Copy active vertex to other selected verts"));
|
2010-01-25 23:12:02 +00:00
|
|
|
uiBlockEndAlign(block);
|
|
|
|
}
|
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2009-11-05 01:00:17 +00:00
|
|
|
static void v3d_transform_butsR(uiLayout *layout, PointerRNA *ptr)
|
|
|
|
{
|
|
|
|
uiLayout *split, *colsub;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
split = uiLayoutSplit(layout, 0.8f, FALSE);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2009-11-18 11:40:55 +00:00
|
|
|
if (ptr->type == &RNA_PoseBone) {
|
2009-11-05 01:00:17 +00:00
|
|
|
PointerRNA boneptr;
|
|
|
|
Bone *bone;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2009-11-05 01:00:17 +00:00
|
|
|
boneptr = RNA_pointer_get(ptr, "bone");
|
|
|
|
bone = boneptr.data;
|
|
|
|
uiLayoutSetActive(split, !(bone->parent && bone->flag & BONE_CONNECTED));
|
|
|
|
}
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "location", 0, NULL, ICON_NONE);
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemL(colsub, "", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_location", UI_ITEM_R_TOGGLE | UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
split = uiLayoutSplit(layout, 0.8f, FALSE);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
switch (RNA_enum_get(ptr, "rotation_mode")) {
|
2009-11-28 03:49:45 +00:00
|
|
|
case ROT_MODE_QUAT: /* quaternion */
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "rotation_quaternion", 0, IFACE_("Rotation"), ICON_NONE);
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotations_4d", UI_ITEM_R_TOGGLE, IFACE_("4L"), ICON_NONE);
|
2009-11-05 01:00:17 +00:00
|
|
|
if (RNA_boolean_get(ptr, "lock_rotations_4d"))
|
2012-03-25 23:54:33 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotation_w", UI_ITEM_R_TOGGLE + UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
2009-11-05 01:00:17 +00:00
|
|
|
else
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemL(colsub, "", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotation", UI_ITEM_R_TOGGLE | UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
2009-11-05 01:00:17 +00:00
|
|
|
break;
|
2009-11-28 03:49:45 +00:00
|
|
|
case ROT_MODE_AXISANGLE: /* axis angle */
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "rotation_axis_angle", 0, IFACE_("Rotation"), ICON_NONE);
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotations_4d", UI_ITEM_R_TOGGLE, IFACE_("4L"), ICON_NONE);
|
2009-11-05 01:00:17 +00:00
|
|
|
if (RNA_boolean_get(ptr, "lock_rotations_4d"))
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotation_w", UI_ITEM_R_TOGGLE | UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
2009-11-05 01:00:17 +00:00
|
|
|
else
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemL(colsub, "", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotation", UI_ITEM_R_TOGGLE | UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
2009-11-05 01:00:17 +00:00
|
|
|
break;
|
2009-11-28 03:49:45 +00:00
|
|
|
default: /* euler rotations */
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "rotation_euler", 0, IFACE_("Rotation"), ICON_NONE);
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemL(colsub, "", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_rotation", UI_ITEM_R_TOGGLE | UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
2009-11-28 03:49:45 +00:00
|
|
|
break;
|
2009-11-05 01:00:17 +00:00
|
|
|
}
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemR(layout, ptr, "rotation_mode", 0, "", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
split = uiLayoutSplit(layout, 0.8f, FALSE);
|
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "scale", 0, NULL, ICON_NONE);
|
2012-06-19 23:08:16 +00:00
|
|
|
colsub = uiLayoutColumn(split, TRUE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemL(colsub, "", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(colsub, ptr, "lock_scale", UI_ITEM_R_TOGGLE | UI_ITEM_R_ICON_ONLY, "", ICON_NONE);
|
|
|
|
|
2009-11-05 01:00:17 +00:00
|
|
|
if (ptr->type == &RNA_Object) {
|
|
|
|
Object *ob = ptr->data;
|
2011-10-03 17:29:43 +00:00
|
|
|
/* dimensions and material support just happen to be the same checks
|
|
|
|
* later we may want to add dimensions for lattice, armature etc too */
|
|
|
|
if (OB_TYPE_SUPPORT_MATERIAL(ob->type)) {
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(layout, ptr, "dimensions", 0, NULL, ICON_NONE);
|
2011-10-03 17:29:43 +00:00
|
|
|
}
|
2009-11-05 01:00:17 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-10-15 12:29:02 +00:00
|
|
|
static void v3d_posearmature_buts(uiLayout *layout, Object *ob)
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
|
|
|
bPoseChannel *pchan;
|
2009-10-22 23:22:05 +00:00
|
|
|
PointerRNA pchanptr;
|
2009-11-06 22:51:08 +00:00
|
|
|
uiLayout *col;
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2012-05-05 16:03:57 +00:00
|
|
|
pchan = BKE_pose_channel_active(ob);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-03-25 23:54:33 +00:00
|
|
|
if (!pchan) {
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemL(layout, IFACE_("No Bone Active"), ICON_NONE);
|
|
|
|
return;
|
2009-11-06 21:41:07 +00:00
|
|
|
}
|
|
|
|
|
2009-11-18 11:40:55 +00:00
|
|
|
RNA_pointer_create(&ob->id, &RNA_PoseBone, pchan, &pchanptr);
|
2009-11-05 01:00:17 +00:00
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
col = uiLayoutColumn(layout, FALSE);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2009-11-05 01:00:17 +00:00
|
|
|
/* XXX: RNA buts show data in native types (i.e. quats, 4-component axis/angle, etc.)
|
2012-03-04 04:35:12 +00:00
|
|
|
* but old-school UI shows in eulers always. Do we want to be able to still display in Eulers?
|
2009-11-05 01:00:17 +00:00
|
|
|
* Maybe needs RNA/ui options to display rotations as different types... */
|
|
|
|
v3d_transform_butsR(col, &pchanptr);
|
2.5
Smaller jobs, all in one commit!
- Moved object_do_update out of view3d drawing, into
the event system (currently after notifiers).
Depsgraph calls for setting update flags will have to
keep track of each Screen's needs, so a UI showing only
a Sequencer doesn't do objects.
- Added button in "Properties region" in 3D window to set
or disable 4-split, including the 3 options it has.
(lock, box, clip)
- Restored legacy code for UI, to make things work like
bone rename, autocomplete.
- Node editor now shows Curves widgets again
- Bugfix: composite job increased Viewer user id count
- Bugfix: Node editor, not "Enable nodes" still called
a Job, which didn't do anything
- Various code cleaning, unused vars and prototypes.
2009-02-11 16:54:55 +00:00
|
|
|
}
|
|
|
|
|
2010-10-15 12:29:02 +00:00
|
|
|
static void v3d_editarmature_buts(uiLayout *layout, Object *ob)
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
bArmature *arm = ob->data;
|
2009-02-10 15:38:00 +00:00
|
|
|
EditBone *ebone;
|
2009-11-06 22:51:08 +00:00
|
|
|
uiLayout *col;
|
2009-10-22 23:22:05 +00:00
|
|
|
PointerRNA eboneptr;
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
ebone = arm->act_edbone;
|
|
|
|
|
|
|
|
if (!ebone || (ebone->layer & arm->layer) == 0) {
|
|
|
|
uiItemL(layout, IFACE_("Nothing selected"), ICON_NONE);
|
2009-02-10 15:38:00 +00:00
|
|
|
return;
|
2011-07-13 11:52:37 +00:00
|
|
|
}
|
2012-04-10 15:47:34 +00:00
|
|
|
|
2009-10-22 23:22:05 +00:00
|
|
|
RNA_pointer_create(&arm->id, &RNA_EditBone, ebone, &eboneptr);
|
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
col = uiLayoutColumn(layout, FALSE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(col, &eboneptr, "head", 0, NULL, ICON_NONE);
|
2012-03-25 23:54:33 +00:00
|
|
|
if (ebone->parent && ebone->flag & BONE_CONNECTED) {
|
2009-11-05 02:21:04 +00:00
|
|
|
PointerRNA parptr = RNA_pointer_get(&eboneptr, "parent");
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(col, &parptr, "tail_radius", 0, IFACE_("Radius (Parent)"), ICON_NONE);
|
2012-02-22 16:52:06 +00:00
|
|
|
}
|
|
|
|
else {
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(col, &eboneptr, "head_radius", 0, IFACE_("Radius"), ICON_NONE);
|
2009-11-05 02:21:04 +00:00
|
|
|
}
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
uiItemR(col, &eboneptr, "tail", 0, NULL, ICON_NONE);
|
|
|
|
uiItemR(col, &eboneptr, "tail_radius", 0, IFACE_("Radius"), ICON_NONE);
|
|
|
|
|
|
|
|
uiItemR(col, &eboneptr, "roll", 0, NULL, ICON_NONE);
|
|
|
|
uiItemR(col, &eboneptr, "envelope_distance", 0, IFACE_("Envelope"), ICON_NONE);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
|
2010-10-15 12:29:02 +00:00
|
|
|
static void v3d_editmetaball_buts(uiLayout *layout, Object *ob)
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
2009-11-05 02:21:04 +00:00
|
|
|
PointerRNA mbptr, ptr;
|
2012-03-03 21:42:21 +00:00
|
|
|
MetaBall *mball = ob->data;
|
2009-11-06 22:51:08 +00:00
|
|
|
uiLayout *col;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
if (!mball || !(mball->lastelem))
|
|
|
|
return;
|
|
|
|
|
2009-11-05 02:21:04 +00:00
|
|
|
RNA_pointer_create(&mball->id, &RNA_MetaBall, mball, &mbptr);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2009-11-05 02:21:04 +00:00
|
|
|
RNA_pointer_create(&mball->id, &RNA_MetaElement, mball->lastelem, &ptr);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
col = uiLayoutColumn(layout, FALSE);
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemR(col, &ptr, "co", 0, NULL, ICON_NONE);
|
|
|
|
|
|
|
|
uiItemR(col, &ptr, "radius", 0, NULL, ICON_NONE);
|
|
|
|
uiItemR(col, &ptr, "stiffness", 0, NULL, ICON_NONE);
|
|
|
|
|
|
|
|
uiItemR(col, &ptr, "type", 0, NULL, ICON_NONE);
|
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
col = uiLayoutColumn(layout, TRUE);
|
2009-11-05 02:21:04 +00:00
|
|
|
switch (RNA_enum_get(&ptr, "type")) {
|
|
|
|
case MB_BALL:
|
|
|
|
break;
|
|
|
|
case MB_CUBE:
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemL(col, IFACE_("Size:"), ICON_NONE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemR(col, &ptr, "size_x", 0, "X", ICON_NONE);
|
|
|
|
uiItemR(col, &ptr, "size_y", 0, "Y", ICON_NONE);
|
|
|
|
uiItemR(col, &ptr, "size_z", 0, "Z", ICON_NONE);
|
2009-11-05 02:21:04 +00:00
|
|
|
break;
|
|
|
|
case MB_TUBE:
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemL(col, IFACE_("Size:"), ICON_NONE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemR(col, &ptr, "size_x", 0, "X", ICON_NONE);
|
2009-11-05 02:21:04 +00:00
|
|
|
break;
|
|
|
|
case MB_PLANE:
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemL(col, IFACE_("Size:"), ICON_NONE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemR(col, &ptr, "size_x", 0, "X", ICON_NONE);
|
|
|
|
uiItemR(col, &ptr, "size_y", 0, "Y", ICON_NONE);
|
2009-11-05 02:21:04 +00:00
|
|
|
break;
|
|
|
|
case MB_ELIPSOID:
|
2012-03-03 21:42:21 +00:00
|
|
|
uiItemL(col, IFACE_("Size:"), ICON_NONE);
|
2011-02-27 18:03:19 +00:00
|
|
|
uiItemR(col, &ptr, "size_x", 0, "X", ICON_NONE);
|
|
|
|
uiItemR(col, &ptr, "size_y", 0, "Y", ICON_NONE);
|
|
|
|
uiItemR(col, &ptr, "size_z", 0, "Z", ICON_NONE);
|
2012-03-03 21:42:21 +00:00
|
|
|
break;
|
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
|
2010-10-15 12:29:02 +00:00
|
|
|
static void do_view3d_region_buttons(bContext *C, void *UNUSED(index), int event)
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
Scene *scene = CTX_data_scene(C);
|
|
|
|
View3D *v3d = CTX_wm_view3d(C);
|
|
|
|
Object *ob = OBACT;
|
|
|
|
|
|
|
|
switch (event) {
|
|
|
|
|
2012-03-25 23:54:33 +00:00
|
|
|
case B_REDR:
|
|
|
|
ED_area_tag_redraw(CTX_wm_area(C));
|
|
|
|
return; /* no notifier! */
|
2012-03-03 21:42:21 +00:00
|
|
|
|
2012-03-25 23:54:33 +00:00
|
|
|
case B_OBJECTPANELMEDIAN:
|
|
|
|
if (ob) {
|
|
|
|
v3d_editvertex_buts(NULL, v3d, ob, 1.0);
|
|
|
|
DAG_id_tag_update(&ob->id, OB_RECALC_DATA);
|
|
|
|
}
|
|
|
|
break;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* default for now */
|
2012-03-25 23:54:33 +00:00
|
|
|
WM_event_add_notifier(C, NC_SPACE | ND_SPACE_VIEW3D, v3d);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
|
2009-05-23 03:24:15 +00:00
|
|
|
static void view3d_panel_object(const bContext *C, Panel *pa)
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
2009-05-23 03:24:15 +00:00
|
|
|
uiBlock *block;
|
2012-03-03 21:42:21 +00:00
|
|
|
Scene *scene = CTX_data_scene(C);
|
|
|
|
Object *obedit = CTX_data_edit_object(C);
|
|
|
|
View3D *v3d = CTX_wm_view3d(C);
|
|
|
|
Object *ob = OBACT;
|
2009-10-22 23:22:05 +00:00
|
|
|
PointerRNA obptr;
|
2012-04-10 15:47:34 +00:00
|
|
|
uiLayout *col;
|
2009-02-10 15:38:00 +00:00
|
|
|
float lim;
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
if (ob == NULL)
|
|
|
|
return;
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2012-10-23 16:21:55 +00:00
|
|
|
lim = 10000.0f * max_ff(1.0f, v3d->grid);
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
block = uiLayoutGetBlock(pa->layout);
|
2009-10-22 23:22:05 +00:00
|
|
|
uiBlockSetHandleFunc(block, do_view3d_region_buttons, NULL);
|
|
|
|
|
2012-06-19 23:08:16 +00:00
|
|
|
col = uiLayoutColumn(pa->layout, FALSE);
|
2009-10-22 23:22:05 +00:00
|
|
|
RNA_id_pointer_create(&ob->id, &obptr);
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
if (ob == obedit) {
|
|
|
|
if (ob->type == OB_ARMATURE)
|
|
|
|
v3d_editarmature_buts(col, ob);
|
|
|
|
else if (ob->type == OB_MBALL)
|
|
|
|
v3d_editmetaball_buts(col, ob);
|
|
|
|
else
|
|
|
|
v3d_editvertex_buts(col, v3d, ob, lim);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
2012-02-22 16:52:06 +00:00
|
|
|
else if (ob->mode & OB_MODE_POSE) {
|
2010-10-15 12:29:02 +00:00
|
|
|
v3d_posearmature_buts(col, ob);
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
else {
|
2009-11-05 01:00:17 +00:00
|
|
|
v3d_transform_butsR(col, &obptr);
|
2011-05-11 09:31:00 +00:00
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|
|
|
|
|
2009-05-23 03:24:15 +00:00
|
|
|
void view3d_buttons_register(ARegionType *art)
|
|
|
|
{
|
|
|
|
PanelType *pt;
|
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
pt = MEM_callocN(sizeof(PanelType), "spacetype view3d panel object");
|
2009-05-23 03:24:15 +00:00
|
|
|
strcpy(pt->idname, "VIEW3D_PT_object");
|
2009-07-14 12:32:19 +00:00
|
|
|
strcpy(pt->label, "Transform");
|
2012-03-03 21:42:21 +00:00
|
|
|
pt->draw = view3d_panel_object;
|
2009-05-23 03:24:15 +00:00
|
|
|
BLI_addtail(&art->paneltypes, pt);
|
2012-03-03 21:42:21 +00:00
|
|
|
|
|
|
|
pt = MEM_callocN(sizeof(PanelType), "spacetype view3d panel gpencil");
|
2009-09-16 17:43:09 +00:00
|
|
|
strcpy(pt->idname, "VIEW3D_PT_gpencil");
|
|
|
|
strcpy(pt->label, "Grease Pencil");
|
2012-12-17 02:34:53 +00:00
|
|
|
pt->draw_header = gpencil_panel_standard_header;
|
2012-03-03 21:42:21 +00:00
|
|
|
pt->draw = gpencil_panel_standard;
|
2009-09-16 17:43:09 +00:00
|
|
|
BLI_addtail(&art->paneltypes, pt);
|
2010-01-25 23:12:02 +00:00
|
|
|
|
2012-03-03 21:42:21 +00:00
|
|
|
pt = MEM_callocN(sizeof(PanelType), "spacetype view3d panel vgroup");
|
2010-01-25 23:12:02 +00:00
|
|
|
strcpy(pt->idname, "VIEW3D_PT_vgroup");
|
|
|
|
strcpy(pt->label, "Vertex Groups");
|
2012-03-03 21:42:21 +00:00
|
|
|
pt->draw = view3d_panel_vgroup;
|
|
|
|
pt->poll = view3d_panel_vgroup_poll;
|
2010-01-25 23:12:02 +00:00
|
|
|
BLI_addtail(&art->paneltypes, pt);
|
2009-05-23 03:24:15 +00:00
|
|
|
}
|
2009-02-10 15:38:00 +00:00
|
|
|
|
2010-10-15 01:36:14 +00:00
|
|
|
static int view3d_properties(bContext *C, wmOperator *UNUSED(op))
|
2009-02-10 15:38:00 +00:00
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
ScrArea *sa = CTX_wm_area(C);
|
|
|
|
ARegion *ar = view3d_has_buttons_region(sa);
|
|
|
|
|
2012-02-22 16:52:06 +00:00
|
|
|
if (ar)
|
2009-09-16 17:43:09 +00:00
|
|
|
ED_region_toggle_hidden(C, ar);
|
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
return OPERATOR_FINISHED;
|
|
|
|
}
|
|
|
|
|
|
|
|
void VIEW3D_OT_properties(wmOperatorType *ot)
|
|
|
|
{
|
2012-03-03 21:42:21 +00:00
|
|
|
ot->name = "Properties";
|
|
|
|
ot->description = "Toggles the properties panel display";
|
|
|
|
ot->idname = "VIEW3D_OT_properties";
|
|
|
|
|
|
|
|
ot->exec = view3d_properties;
|
|
|
|
ot->poll = ED_operator_view3d_active;
|
|
|
|
|
2009-02-10 15:38:00 +00:00
|
|
|
/* flags */
|
2012-03-03 21:42:21 +00:00
|
|
|
ot->flag = 0;
|
2009-02-10 15:38:00 +00:00
|
|
|
}
|