Blender V4.3
transform_mode_customdata.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_vector.h"
12#include "BLI_string.h"
13#include "BLI_task.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/* -------------------------------------------------------------------- */
41
42static void transdata_elem_value(const TransInfo * /*t*/,
43 const TransDataContainer * /*tc*/,
44 TransData *td,
45 const float value)
46{
47 if (td->val == nullptr) {
48 return;
49 }
50
51 *td->val = td->ival + value * td->factor;
52 CLAMP(*td->val, 0.0f, 1.0f);
53}
54
55static void transdata_elem_value_fn(void *__restrict iter_data_v,
56 const int iter,
57 const TaskParallelTLS *__restrict /*tls*/)
58{
59 TransDataArgs_Value *data = static_cast<TransDataArgs_Value *>(iter_data_v);
60 TransData *td = &data->tc->data[iter];
61 if (td->flag & TD_SKIP) {
62 return;
63 }
64 transdata_elem_value(data->t, data->tc, td, data->value);
65}
66
69/* -------------------------------------------------------------------- */
73static void apply_value_impl(TransInfo *t, const char *value_name)
74{
75 float value;
76 int i;
77 char str[UI_MAX_DRAW_STR];
78
79 value = t->values[0] + t->values_modal_offset[0];
80
81 CLAMP_MAX(value, 1.0f);
82
83 transform_snap_increment(t, &value);
84
85 applyNumInput(&t->num, &value);
86
87 t->values_final[0] = value;
88
89 /* Header print for NumInput. */
90 if (hasNumInput(&t->num)) {
91 char c[NUM_STR_REP_LEN];
92
93 outputNumInput(&(t->num), c, &t->scene->unit);
94
95 if (value >= 0.0f) {
96 SNPRINTF(str, "%s: +%s %s", value_name, c, t->proptext);
97 }
98 else {
99 SNPRINTF(str, "%s: %s %s", value_name, c, t->proptext);
100 }
101 }
102 else {
103 /* Default header print. */
104 if (value >= 0.0f) {
105 SNPRINTF(str, "%s: +%.3f %s", value_name, value, t->proptext);
106 }
107 else {
108 SNPRINTF(str, "%s: %.3f %s", value_name, value, t->proptext);
109 }
110 }
111
113 if (tc->data_len < TRANSDATA_THREAD_LIMIT) {
114 TransData *td = tc->data;
115 for (i = 0; i < tc->data_len; i++, td++) {
116 if (td->flag & TD_SKIP) {
117 continue;
118 }
119 transdata_elem_value(t, tc, td, value);
120 }
121 }
122 else {
123 TransDataArgs_Value data{};
124 data.t = t;
125 data.tc = tc;
126 data.value = value;
127 TaskParallelSettings settings;
129 BLI_task_parallel_range(0, tc->data_len, &data, transdata_elem_value_fn, &settings);
130 }
131 }
132
133 recalc_data(t);
134
136}
137
138static void applyCrease(TransInfo *t)
139{
140 apply_value_impl(t, IFACE_("Crease"));
141}
142
144{
145 apply_value_impl(t, IFACE_("Bevel Weight"));
146}
147
149{
151
152 t->idx_max = 0;
153 t->num.idx_max = 0;
154 t->snap[0] = 0.1f;
155 t->snap[1] = t->snap[0] * 0.1f;
156
157 copy_v3_fl(t->num.val_inc, t->snap[0]);
158 t->num.unit_sys = t->scene->unit.system;
159 t->num.unit_type[0] = B_UNIT_NONE;
160}
161
162static void initEgdeCrease(TransInfo *t, wmOperator * /*op*/)
163{
166}
167
168static void initVertCrease(TransInfo *t, wmOperator * /*op*/)
169{
172}
173
174static void initBevelWeight(TransInfo *t, wmOperator * /*op*/)
175{
177 t->mode = TFM_BWEIGHT;
178}
179
183 /*flags*/ T_NO_CONSTRAINT | T_NO_PROJECT,
184 /*init_fn*/ initEgdeCrease,
185 /*transform_fn*/ applyCrease,
186 /*transform_matrix_fn*/ nullptr,
187 /*handle_event_fn*/ nullptr,
188 /*snap_distance_fn*/ nullptr,
189 /*snap_apply_fn*/ nullptr,
190 /*draw_fn*/ nullptr,
191};
192
194 /*flags*/ T_NO_CONSTRAINT | T_NO_PROJECT,
195 /*init_fn*/ initVertCrease,
196 /*transform_fn*/ applyCrease,
197 /*transform_matrix_fn*/ nullptr,
198 /*handle_event_fn*/ nullptr,
199 /*snap_distance_fn*/ nullptr,
200 /*snap_apply_fn*/ nullptr,
201 /*draw_fn*/ nullptr,
202};
203
205 /*flags*/ T_NO_CONSTRAINT | T_NO_PROJECT,
206 /*init_fn*/ initBevelWeight,
207 /*transform_fn*/ applyBevelWeight,
208 /*transform_matrix_fn*/ nullptr,
209 /*handle_event_fn*/ nullptr,
210 /*snap_distance_fn*/ nullptr,
211 /*snap_apply_fn*/ nullptr,
212 /*draw_fn*/ nullptr,
213};
@ B_UNIT_NONE
Definition BKE_unit.hh:106
MINLINE void copy_v3_fl(float r[3], float f)
#define SNPRINTF(dst, format,...)
Definition BLI_string.h:597
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 CLAMP(a, b, c)
#define CLAMP_MAX(a, c)
#define IFACE_(msgid)
#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_VERT_CREASE
@ TFM_BWEIGHT
@ TFM_EDGE_CREASE
#define UI_MAX_DRAW_STR
#define str(s)
short idx_max
float val_inc[NUM_MAX_ELEMENTS]
int unit_type[NUM_MAX_ELEMENTS]
struct UnitSettings unit
const TransDataContainer * tc
eTfmMode mode
Definition transform.hh:517
float snap[2]
Definition transform.hh:561
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
NumInput num
Definition transform.hh:540
Scene * scene
Definition transform.hh:654
MouseInput mouse
Definition transform.hh:543
float values_final[4]
Definition transform.hh:632
ScrArea * area
Definition transform.hh:651
@ INPUT_SPRING_DELTA
Definition transform.hh:745
@ T_NO_PROJECT
Definition transform.hh:121
@ 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
#define TRANSDATA_THREAD_LIMIT
transform modes used by different operators.
static void apply_value_impl(TransInfo *t, const char *value_name)
static void initVertCrease(TransInfo *t, wmOperator *)
static void init_mode_impl(TransInfo *t)
static void transdata_elem_value(const TransInfo *, const TransDataContainer *, TransData *td, const float value)
TransModeInfo TransMode_vertcrease
static void applyCrease(TransInfo *t)
static void initBevelWeight(TransInfo *t, wmOperator *)
static void applyBevelWeight(TransInfo *t)
TransModeInfo TransMode_bevelweight
static void transdata_elem_value_fn(void *__restrict iter_data_v, const int iter, const TaskParallelTLS *__restrict)
static void initEgdeCrease(TransInfo *t, wmOperator *)
TransModeInfo TransMode_edgecrease
bool transform_snap_increment(const TransInfo *t, float *r_val)