Blender V4.3
transform_mode_curveshrinkfatten.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2001-2002 NaN Holding BV. All rights reserved.
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
9#include <cstdlib>
10
11#include "BLI_math_bits.h"
12#include "BLI_math_vector.h"
13#include "BLI_string.h"
14
15#include "BKE_unit.hh"
16
17#include "ED_screen.hh"
18
19#include "UI_interface.hh"
20
21#include "BLT_translation.hh"
22
23#include "transform.hh"
24#include "transform_convert.hh"
25#include "transform_snap.hh"
26
27#include "transform_mode.hh"
28
29/* -------------------------------------------------------------------- */
34{
35 float ratio;
36 int i;
37 char str[UI_MAX_DRAW_STR];
38
39 ratio = t->values[0] + t->values_modal_offset[0];
40
41 transform_snap_increment(t, &ratio);
42
43 applyNumInput(&t->num, &ratio);
44
45 t->values_final[0] = ratio;
46
47 /* Header print for NumInput. */
48 if (hasNumInput(&t->num)) {
49 char c[NUM_STR_REP_LEN];
50
51 outputNumInput(&(t->num), c, &t->scene->unit);
52 SNPRINTF(str, IFACE_("Shrink/Fatten: %s"), c);
53 }
54 else {
55 SNPRINTF(str, IFACE_("Shrink/Fatten: %3f"), ratio);
56 }
57
59 TransData *td = tc->data;
60 for (i = 0; i < tc->data_len; i++, td++) {
61 if (td->flag & TD_SKIP) {
62 continue;
63 }
64
65 if (td->val) {
66 if (td->ival == 0.0f && ratio > 1.0f) {
67 /* Allow Shrink/Fatten for zero radius. */
68 *td->val = (ratio - 1.0f) * uint_as_float(POINTER_AS_UINT(t->custom.mode.data));
69 }
70 else {
71 *td->val = td->ival * ratio;
72 }
73
74 /* Apply proportional editing. */
75 *td->val = interpf(*td->val, td->ival, td->factor);
76 CLAMP_MIN(*td->val, 0.0f);
77 }
78 }
79 }
80
81 recalc_data(t);
82
84}
85
87{
89
91
92 t->idx_max = 0;
93 t->num.idx_max = 0;
94 t->snap[0] = 0.1f;
95 t->snap[1] = t->snap[0] * 0.1f;
96
97 copy_v3_fl(t->num.val_inc, t->snap[0]);
98 t->num.unit_sys = t->scene->unit.system;
100
101 float scale_factor = 0.0f;
102 if (((t->spacetype == SPACE_VIEW3D) && (t->region->regiontype == RGN_TYPE_WINDOW) &&
103 (t->data_len_all == 1)) ||
104 (t->data_len_all == 3 && TRANS_DATA_CONTAINER_FIRST_OK(t)->data[0].val == nullptr))
105 {
106 /* For cases where only one point on the curve is being transformed and the radius of that
107 * point is zero, use the factor to multiply the offset of the ratio and allow scaling.
108 * Note that for bezier curves, 3 TransData equals 1 point in most cases. */
109 RegionView3D *rv3d = static_cast<RegionView3D *>(t->region->regiondata);
110 scale_factor = rv3d->pixsize * t->mouse.factor * t->zfac;
111 }
112 t->custom.mode.data = POINTER_FROM_UINT(float_as_uint(scale_factor));
113}
114
118 /*flags*/ T_NO_CONSTRAINT,
119 /*init_fn*/ initCurveShrinkFatten,
120 /*transform_fn*/ applyCurveShrinkFatten,
121 /*transform_matrix_fn*/ nullptr,
122 /*handle_event_fn*/ nullptr,
123 /*snap_distance_fn*/ nullptr,
124 /*snap_apply_fn*/ nullptr,
125 /*draw_fn*/ nullptr,
126};
@ B_UNIT_NONE
Definition BKE_unit.hh:106
MINLINE float interpf(float target, float origin, float t)
MINLINE unsigned int float_as_uint(float f)
MINLINE float uint_as_float(unsigned int i)
MINLINE void copy_v3_fl(float r[3], float f)
#define SNPRINTF(dst, format,...)
Definition BLI_string.h:597
#define POINTER_AS_UINT(i)
#define POINTER_FROM_UINT(i)
#define CLAMP_MIN(a, b)
#define IFACE_(msgid)
@ RGN_TYPE_WINDOW
@ SPACE_VIEW3D
#define NUM_STR_REP_LEN
void outputNumInput(NumInput *n, char *str, const UnitSettings *unit_settings)
Definition numinput.cc:88
bool applyNumInput(NumInput *n, float *vec)
Definition numinput.cc:190
bool hasNumInput(const NumInput *n)
Definition numinput.cc:171
void ED_area_status_text(ScrArea *area, const char *str)
Definition area.cc:803
@ TFM_CURVE_SHRINKFATTEN
#define UI_MAX_DRAW_STR
#define str(s)
void * regiondata
float factor
Definition transform.hh:385
short idx_max
float val_inc[NUM_MAX_ELEMENTS]
int unit_type[NUM_MAX_ELEMENTS]
struct UnitSettings unit
TransCustomData mode
Definition transform.hh:423
eTfmMode mode
Definition transform.hh:517
char spacetype
Definition transform.hh:582
float snap[2]
Definition transform.hh:561
int data_len_all
Definition transform.hh:510
float values[4]
Definition transform.hh:624
float zfac
Definition transform.hh:665
short idx_max
Definition transform.hh:559
float values_modal_offset[4]
Definition transform.hh:627
NumInput num
Definition transform.hh:540
TransCustomDataContainer custom
Definition transform.hh:676
Scene * scene
Definition transform.hh:654
ARegion * region
Definition transform.hh:652
MouseInput mouse
Definition transform.hh:543
float values_final[4]
Definition transform.hh:632
ScrArea * area
Definition transform.hh:651
@ INPUT_SPRING
Definition transform.hh:743
#define TRANS_DATA_CONTAINER_FIRST_OK(t)
Definition transform.hh:849
@ T_NO_CONSTRAINT
Definition transform.hh:95
void initMouseInputMode(TransInfo *t, MouseInput *mi, MouseInputMode mode)
#define FOREACH_TRANS_DATA_CONTAINER(t, th)
Definition transform.hh:854
void recalc_data(TransInfo *t)
conversion and adaptation of different datablocks to a common struct.
@ TD_SKIP
transform modes used by different operators.
TransModeInfo TransMode_curveshrinkfatten
static void applyCurveShrinkFatten(TransInfo *t)
static void initCurveShrinkFatten(TransInfo *t, wmOperator *)
bool transform_snap_increment(const TransInfo *t, float *r_val)