Blender V4.3
transform_mode_shrink_fatten.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#include <fmt/format.h>
11
12#include "BLI_math_vector.h"
13#include "BLI_task.h"
14
15#include "BKE_report.hh"
16#include "BKE_unit.hh"
17
18#include "ED_screen.hh"
19
20#include "WM_api.hh"
21#include "WM_types.hh"
22
23#include "BLT_translation.hh"
24
25#include "transform.hh"
26#include "transform_convert.hh"
27#include "transform_snap.hh"
28
29#include "transform_mode.hh"
30
31/* -------------------------------------------------------------------- */
43
45 const TransDataContainer * /*tc*/,
46 TransData *td,
47 const float distance)
48{
49 /* Get the final offset. */
50 float tdistance = distance * td->factor;
51 if (td->ext && (t->flag & T_ALT_TRANSFORM) != 0) {
52 tdistance *= td->ext->isize[0]; /* Shell factor. */
53 }
54
55 madd_v3_v3v3fl(td->loc, td->iloc, td->axismtx[2], tdistance);
56}
57
58static void transdata_elem_shrink_fatten_fn(void *__restrict iter_data_v,
59 const int iter,
60 const TaskParallelTLS *__restrict /*tls*/)
61{
62 TransDataArgs_ShrinkFatten *data = static_cast<TransDataArgs_ShrinkFatten *>(iter_data_v);
63 TransData *td = &data->tc->data[iter];
64 if (td->flag & TD_SKIP) {
65 return;
66 }
67 transdata_elem_shrink_fatten(data->t, data->tc, td, data->distance);
68}
69
72/* -------------------------------------------------------------------- */
77{
79 const wmKeyMapItem *kmi = static_cast<const wmKeyMapItem *>(t->custom.mode.data);
80 if (kmi && event->type == kmi->type && event->val == kmi->val) {
81 /* Allows the "Even Thickness" effect to be enabled as a toggle. */
83 return TREDRAW_HARD;
84 }
85 return TREDRAW_NOTHING;
86}
87
89{
90 float distance;
91 int i;
92 fmt::memory_buffer str;
93 UnitSettings *unit = &t->scene->unit;
94
95 distance = t->values[0] + t->values_modal_offset[0];
96
97 transform_snap_increment(t, &distance);
98
99 applyNumInput(&t->num, &distance);
100
101 t->values_final[0] = distance;
102
103 /* Header print for NumInput. */
104 fmt::format_to(fmt::appender(str), IFACE_("Shrink/Fatten: "));
105 if (hasNumInput(&t->num)) {
106 char c[NUM_STR_REP_LEN];
107 outputNumInput(&(t->num), c, unit);
108 fmt::format_to(fmt::appender(str), c);
109 }
110 else {
111 /* Default header print. */
112 if (unit != nullptr) {
113 char unit_str[64];
115 unit_str, sizeof(unit_str), distance * unit->scale_length, 4, B_UNIT_LENGTH, unit, true);
116 fmt::format_to(fmt::appender(str), unit_str);
117 }
118 else {
119 fmt::format_to(fmt::appender(str), "{:.4f}", distance);
120 }
121 }
122
123 if (t->proptext[0]) {
124 fmt::format_to(fmt::appender(str), " {}", t->proptext);
125 }
126 fmt::format_to(fmt::appender(str), ", (");
127
128 const wmKeyMapItem *kmi = static_cast<const wmKeyMapItem *>(t->custom.mode.data);
129 if (kmi) {
130 str.append(WM_keymap_item_to_string(kmi, false).value_or(""));
131 }
132
133 fmt::format_to(fmt::appender(str),
134 IFACE_(" or Alt) Even Thickness {}"),
136 /* Done with header string. */
137
139 if (tc->data_len < TRANSDATA_THREAD_LIMIT) {
140 TransData *td = tc->data;
141 for (i = 0; i < tc->data_len; i++, td++) {
142 if (td->flag & TD_SKIP) {
143 continue;
144 }
145 transdata_elem_shrink_fatten(t, tc, td, distance);
146 }
147 }
148 else {
150 data.t = t;
151 data.tc = tc;
152 data.distance = distance;
153 TaskParallelSettings settings;
155 BLI_task_parallel_range(0, tc->data_len, &data, transdata_elem_shrink_fatten_fn, &settings);
156 }
157 }
158
159 recalc_data(t);
160
161 ED_area_status_text(t->area, fmt::to_string(str).c_str());
162}
163
164static void initShrinkFatten(TransInfo *t, wmOperator * /*op*/)
165{
166 if ((t->flag & T_EDIT) == 0 || (t->obedit_type != OB_MESH)) {
167 BKE_report(t->reports, RPT_ERROR, "'Shrink/Fatten' meshes is only supported in edit mode");
168 t->state = TRANS_CANCEL;
169 }
170
172
174
175 t->idx_max = 0;
176 t->num.idx_max = 0;
177 t->snap[0] = 1.0f;
178 t->snap[1] = t->snap[0] * 0.1f;
179
180 copy_v3_fl(t->num.val_inc, t->snap[0]);
181 t->num.unit_sys = t->scene->unit.system;
183
184 if (t->keymap) {
185 /* Workaround to use the same key as the modal keymap. */
187 }
188}
189
193 /*flags*/ T_NO_CONSTRAINT,
194 /*init_fn*/ initShrinkFatten,
195 /*transform_fn*/ applyShrinkFatten,
196 /*transform_matrix_fn*/ nullptr,
197 /*handle_event_fn*/ shrinkfatten_handleEvent,
198 /*snap_distance_fn*/ nullptr,
199 /*snap_apply_fn*/ nullptr,
200 /*draw_fn*/ nullptr,
201};
void BKE_report(ReportList *reports, eReportType type, const char *message)
Definition report.cc:125
@ B_UNIT_LENGTH
Definition BKE_unit.hh:107
size_t BKE_unit_value_as_string(char *str, int str_maxncpy, double value, int prec, int type, const UnitSettings *settings, bool pad)
Definition unit.cc:1876
#define BLI_assert(a)
Definition BLI_assert.h:50
MINLINE void copy_v3_fl(float r[3], float f)
MINLINE void madd_v3_v3v3fl(float r[3], const float a[3], const float b[3], float f)
void BLI_task_parallel_range(int start, int stop, void *userdata, TaskParallelRangeFunc func, const TaskParallelSettings *settings)
Definition task_range.cc:99
BLI_INLINE void BLI_parallel_range_settings_defaults(TaskParallelSettings *settings)
Definition BLI_task.h:230
#define IFACE_(msgid)
@ OB_MESH
#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_SHRINKFATTEN
#define str(s)
float distance(float a, float b)
short idx_max
float val_inc[NUM_MAX_ELEMENTS]
int unit_type[NUM_MAX_ELEMENTS]
struct UnitSettings unit
TransCustomData mode
Definition transform.hh:423
float axismtx[3][3]
TransDataExtension * ext
eTfmMode mode
Definition transform.hh:517
float snap[2]
Definition transform.hh:561
ReportList * reports
Definition transform.hh:661
float values[4]
Definition transform.hh:624
char proptext[20]
Definition transform.hh:548
short idx_max
Definition transform.hh:559
float values_modal_offset[4]
Definition transform.hh:627
eTState state
Definition transform.hh:527
NumInput num
Definition transform.hh:540
TransCustomDataContainer custom
Definition transform.hh:676
Scene * scene
Definition transform.hh:654
eTFlag flag
Definition transform.hh:523
MouseInput mouse
Definition transform.hh:543
short obedit_type
Definition transform.hh:584
float values_final[4]
Definition transform.hh:632
wmKeyMap * keymap
Definition transform.hh:659
ScrArea * area
Definition transform.hh:651
short val
Definition WM_types.hh:724
short type
Definition WM_types.hh:722
@ INPUT_VERTICAL_ABSOLUTE
Definition transform.hh:752
eRedrawFlag
Definition transform.hh:214
@ TREDRAW_NOTHING
Definition transform.hh:215
@ TREDRAW_HARD
Definition transform.hh:217
@ TFM_MODAL_RESIZE
Definition transform.hh:251
@ T_ALT_TRANSFORM
Definition transform.hh:126
@ T_NO_CONSTRAINT
Definition transform.hh:95
@ T_EDIT
Definition transform.hh:91
@ TRANS_CANCEL
Definition transform.hh:210
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
#define TRANSDATA_THREAD_LIMIT
transform modes used by different operators.
static void applyShrinkFatten(TransInfo *t)
static eRedrawFlag shrinkfatten_handleEvent(TransInfo *t, const wmEvent *event)
static void transdata_elem_shrink_fatten_fn(void *__restrict iter_data_v, const int iter, const TaskParallelTLS *__restrict)
TransModeInfo TransMode_shrinkfatten
static void initShrinkFatten(TransInfo *t, wmOperator *)
static void transdata_elem_shrink_fatten(const TransInfo *t, const TransDataContainer *, TransData *td, const float distance)
bool transform_snap_increment(const TransInfo *t, float *r_val)
const wmKeyMapItem * WM_modalkeymap_find_propvalue(const wmKeyMap *km, const int propvalue)
std::optional< std::string > WM_keymap_item_to_string(const wmKeyMapItem *kmi, const bool compact)
const char * WM_bool_as_string(bool test)