Blender V4.3
transform_mode_tosphere.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_matrix.h"
12#include "BLI_math_vector.h"
13#include "BLI_string.h"
14#include "BLI_task.h"
15
16#include "MEM_guardedalloc.h"
17
18#include "BKE_unit.hh"
19
20#include "ED_screen.hh"
21
22#include "UI_interface.hh"
23
24#include "BLT_translation.hh"
25
26#include "transform.hh"
27#include "transform_convert.hh"
28#include "transform_snap.hh"
29
30#include "transform_mode.hh"
31
32/* -------------------------------------------------------------------- */
38 float radius;
39};
40
43{
44 ToSphereInfo *data = static_cast<ToSphereInfo *>(t->custom.mode.data);
45 float radius = 0.0f;
46 float vec[3];
47
48 const bool is_local_center = transdata_check_local_center(t, t->around);
49 const bool is_data_space = (t->options & CTX_POSE_BONE) != 0;
50
51 if (t->flag & T_PROP_EDIT_ALL) {
52 int factor_accum = 0.0f;
54 TransData *td = tc->data;
55 for (int i = 0; i < tc->data_len; i++, td++) {
56 if (td->factor == 0.0f) {
57 continue;
58 }
59 const float *center = is_local_center ? td->center : tc->center_local;
60 if (is_data_space) {
61 copy_v3_v3(vec, td->center);
62 }
63 else {
64 copy_v3_v3(vec, td->iloc);
65 }
66
67 sub_v3_v3(vec, center);
68 radius += td->factor * len_v3(vec);
69 factor_accum += td->factor;
70 }
71 }
72 if (factor_accum != 0.0f) {
73 radius /= factor_accum;
74 }
75 }
76 else {
78 TransData *td = tc->data;
79 for (int i = 0; i < tc->data_len; i++, td++) {
80 const float *center = is_local_center ? td->center : tc->center_local;
81 if (is_data_space) {
82 copy_v3_v3(vec, td->center);
83 }
84 else {
85 copy_v3_v3(vec, td->iloc);
86 }
87
88 sub_v3_v3(vec, center);
89 radius += len_v3(vec);
90 }
91 }
92 radius /= float(t->data_len_all);
93 }
94
95 data->prop_size_prev = t->prop_size;
96 data->radius = radius;
97}
98
101/* -------------------------------------------------------------------- */
116
117static void transdata_elem_to_sphere(const TransInfo * /*t*/,
118 const TransDataContainer *tc,
119 TransData *td,
120 const float ratio,
121 const ToSphereInfo *to_sphere_info,
122 const bool is_local_center,
123 const bool is_data_space)
124{
125 float vec[3];
126 const float *center = is_local_center ? td->center : tc->center_local;
127 if (is_data_space) {
128 copy_v3_v3(vec, td->center);
129 }
130 else {
131 copy_v3_v3(vec, td->iloc);
132 }
133
134 sub_v3_v3(vec, center);
135 const float radius = normalize_v3(vec);
136 const float tratio = ratio * td->factor;
137 mul_v3_fl(vec, radius * (1.0f - tratio) + to_sphere_info->radius * tratio);
138 add_v3_v3(vec, center);
139
140 if (is_data_space) {
141 sub_v3_v3(vec, td->center);
142 mul_m3_v3(td->smtx, vec);
143 add_v3_v3(vec, td->iloc);
144 }
145
146 copy_v3_v3(td->loc, vec);
147}
148
149static void transdata_elem_to_sphere_fn(void *__restrict iter_data_v,
150 const int iter,
151 const TaskParallelTLS *__restrict /*tls*/)
152{
153 TransDataArgs_ToSphere *data = static_cast<TransDataArgs_ToSphere *>(iter_data_v);
154 TransData *td = &data->tc->data[iter];
155 if (td->flag & TD_SKIP) {
156 return;
157 }
159 data->tc,
160 td,
161 data->ratio,
162 &data->to_sphere_info,
163 data->is_local_center,
164 data->is_data_space);
165}
166
169/* -------------------------------------------------------------------- */
174{
175 const bool is_local_center = transdata_check_local_center(t, t->around);
176 const bool is_data_space = (t->options & CTX_POSE_BONE) != 0;
177
178 float ratio;
179 int i;
180 char str[UI_MAX_DRAW_STR];
181
182 ratio = t->values[0] + t->values_modal_offset[0];
183
184 transform_snap_increment(t, &ratio);
185
186 applyNumInput(&t->num, &ratio);
187
188 CLAMP(ratio, 0.0f, 1.0f);
189
190 t->values_final[0] = ratio;
191
192 /* Header print for NumInput. */
193 if (hasNumInput(&t->num)) {
194 char c[NUM_STR_REP_LEN];
195
196 outputNumInput(&(t->num), c, &t->scene->unit);
197
198 SNPRINTF(str, IFACE_("To Sphere: %s %s"), c, t->proptext);
199 }
200 else {
201 /* Default header print. */
202 SNPRINTF(str, IFACE_("To Sphere: %.4f %s"), ratio, t->proptext);
203 }
204
205 const ToSphereInfo *to_sphere_info = static_cast<const ToSphereInfo *>(t->custom.mode.data);
206 if (to_sphere_info->prop_size_prev != t->prop_size) {
208 }
209
211 if (tc->data_len < TRANSDATA_THREAD_LIMIT) {
212 TransData *td = tc->data;
213 for (i = 0; i < tc->data_len; i++, td++) {
214 if (td->flag & TD_SKIP) {
215 continue;
216 }
217 transdata_elem_to_sphere(t, tc, td, ratio, to_sphere_info, is_local_center, is_data_space);
218 }
219 }
220 else {
222 data.t = t;
223 data.tc = tc;
224 data.ratio = ratio;
225 data.to_sphere_info = *to_sphere_info;
226 data.is_local_center = is_local_center;
227 data.is_data_space = is_data_space;
228
229 TaskParallelSettings settings;
231 BLI_task_parallel_range(0, tc->data_len, &data, transdata_elem_to_sphere_fn, &settings);
232 }
233 }
234
235 recalc_data(t);
236
238}
239
240static void initToSphere(TransInfo *t, wmOperator * /*op*/)
241{
242 t->mode = TFM_TOSPHERE;
243
245
246 t->idx_max = 0;
247 t->num.idx_max = 0;
248 t->snap[0] = 0.1f;
249 t->snap[1] = t->snap[0] * 0.1f;
250
251 copy_v3_fl(t->num.val_inc, t->snap[0]);
252 t->num.unit_sys = t->scene->unit.system;
253 t->num.unit_type[0] = B_UNIT_NONE;
254
256
257 ToSphereInfo *data = static_cast<ToSphereInfo *>(MEM_callocN(sizeof(*data), __func__));
258 t->custom.mode.data = data;
259 t->custom.mode.use_free = true;
260
262}
263
267 /*flags*/ T_NO_CONSTRAINT,
268 /*init_fn*/ initToSphere,
269 /*transform_fn*/ applyToSphere,
270 /*transform_matrix_fn*/ nullptr,
271 /*handle_event_fn*/ nullptr,
272 /*snap_distance_fn*/ nullptr,
273 /*snap_apply_fn*/ nullptr,
274 /*draw_fn*/ nullptr,
275};
@ B_UNIT_NONE
Definition BKE_unit.hh:106
void mul_m3_v3(const float M[3][3], float r[3])
MINLINE void sub_v3_v3(float r[3], const float a[3])
MINLINE void mul_v3_fl(float r[3], float f)
MINLINE void copy_v3_v3(float r[3], const float a[3])
MINLINE void copy_v3_fl(float r[3], float f)
MINLINE void add_v3_v3(float r[3], const float a[3])
MINLINE float normalize_v3(float n[3])
MINLINE float len_v3(const float a[3]) ATTR_WARN_UNUSED_RESULT
#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 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
@ NUM_NO_NEGATIVE
@ NUM_NULL_ONE
bool hasNumInput(const NumInput *n)
Definition numinput.cc:171
void ED_area_status_text(ScrArea *area, const char *str)
Definition area.cc:803
@ TFM_TOSPHERE
Read Guarded memory(de)allocation.
#define UI_MAX_DRAW_STR
draw_view in_light_buf[] float
#define str(s)
void *(* MEM_callocN)(size_t len, const char *str)
Definition mallocn.cc:42
short idx_max
short val_flag[NUM_MAX_ELEMENTS]
float val_inc[NUM_MAX_ELEMENTS]
int unit_type[NUM_MAX_ELEMENTS]
struct UnitSettings unit
TransCustomData mode
Definition transform.hh:423
unsigned int use_free
Definition transform.hh:410
const TransDataContainer * tc
float center_local[3]
Definition transform.hh:475
float smtx[3][3]
eTfmMode mode
Definition transform.hh:517
short around
Definition transform.hh:580
float snap[2]
Definition transform.hh:561
int data_len_all
Definition transform.hh:510
float prop_size
Definition transform.hh:546
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
TransCustomDataContainer custom
Definition transform.hh:676
Scene * scene
Definition transform.hh:654
eTFlag flag
Definition transform.hh:523
MouseInput mouse
Definition transform.hh:543
float values_final[4]
Definition transform.hh:632
eTContext options
Definition transform.hh:521
ScrArea * area
Definition transform.hh:651
@ INPUT_HORIZONTAL_RATIO
Definition transform.hh:749
@ CTX_POSE_BONE
Definition transform.hh:73
@ T_NO_CONSTRAINT
Definition transform.hh:95
#define T_PROP_EDIT_ALL
Definition transform.hh:157
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
bool transdata_check_local_center(const TransInfo *t, short around)
transform modes used by different operators.
static void initToSphere(TransInfo *t, wmOperator *)
static void transdata_elem_to_sphere(const TransInfo *, const TransDataContainer *tc, TransData *td, const float ratio, const ToSphereInfo *to_sphere_info, const bool is_local_center, const bool is_data_space)
TransModeInfo TransMode_tosphere
static void transdata_elem_to_sphere_fn(void *__restrict iter_data_v, const int iter, const TaskParallelTLS *__restrict)
static void to_sphere_radius_update(TransInfo *t)
static void applyToSphere(TransInfo *t)
bool transform_snap_increment(const TransInfo *t, float *r_val)