Blender V4.3
MOD_grease_pencil_tint.cc
Go to the documentation of this file.
1/* SPDX-FileCopyrightText: 2024 Blender Authors
2 *
3 * SPDX-License-Identifier: GPL-2.0-or-later */
4
8
9#include "MEM_guardedalloc.h"
10
11#include "BLI_math_matrix.hh"
12
13#include "DNA_defaults.h"
14#include "DNA_material_types.h"
15#include "DNA_modifier_types.h"
16#include "DNA_scene_types.h"
17
18#include "BKE_colorband.hh"
19#include "BKE_curves.hh"
20#include "BKE_geometry_set.hh"
21#include "BKE_grease_pencil.hh"
22#include "BKE_lib_query.hh"
23#include "BKE_material.h"
24#include "BKE_modifier.hh"
25#include "BKE_screen.hh"
26
27#include "BLO_read_write.hh"
28
30
31#include "UI_interface.hh"
32#include "UI_resources.hh"
33
34#include "BLT_translation.hh"
35
36#include "WM_types.hh"
37
38#include "RNA_access.hh"
39#include "RNA_enum_types.hh"
40#include "RNA_prototypes.hh"
41
43#include "MOD_modifiertypes.hh"
44#include "MOD_ui_common.hh"
45
46namespace blender {
47
49
50static void init_data(ModifierData *md)
51{
52 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
53
55
58
59 /* Add default color ramp. */
60 tmd->color_ramp = BKE_colorband_add(false);
61 if (tmd->color_ramp) {
62 BKE_colorband_init(tmd->color_ramp, true);
63 CBData *data = tmd->color_ramp->data;
64 data[0].r = data[0].g = data[0].b = data[0].a = 1.0f;
65 data[0].pos = 0.0f;
66 data[1].r = data[1].g = data[1].b = 0.0f;
67 data[1].a = 1.0f;
68 data[1].pos = 1.0f;
69
70 tmd->color_ramp->tot = 2;
71 }
72}
73
74static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
75{
76 const auto *tmd = reinterpret_cast<const GreasePencilTintModifierData *>(md);
77 auto *ttmd = reinterpret_cast<GreasePencilTintModifierData *>(target);
78
80 MEM_SAFE_FREE(ttmd->color_ramp);
81
83 modifier::greasepencil::copy_influence_data(&tmd->influence, &ttmd->influence, flag);
84
85 if (tmd->color_ramp) {
86 ttmd->color_ramp = static_cast<ColorBand *>(MEM_dupallocN(tmd->color_ramp));
87 }
88}
89
90static void free_data(ModifierData *md)
91{
92 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
94
95 MEM_SAFE_FREE(tmd->color_ramp);
96}
97
98static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
99{
100 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
101 modifier::greasepencil::foreach_influence_ID_link(&tmd->influence, ob, walk, user_data);
102 walk(user_data, ob, (ID **)&tmd->object, IDWALK_CB_NOP);
103}
104
105static bool is_disabled(const Scene * /*scene*/, ModifierData *md, bool /*use_render_params*/)
106{
107 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
108 if (tmd->tint_mode == MOD_GREASE_PENCIL_TINT_GRADIENT) {
109 return tmd->object == nullptr;
110 }
111 return false;
112}
113
115{
116 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
117 if (tmd->object != nullptr) {
119 ctx->node, tmd->object, DEG_OB_COMP_TRANSFORM, "Grease Pencil Tint Modifier");
120 }
122 ctx->node, ctx->object, DEG_OB_COMP_TRANSFORM, "Grease Pencil Tint Modifier");
123}
124
126 const ColorGeometry4f &material_color)
127{
128 /* When input alpha is zero, replace with material color. */
129 return (input_color.a == 0.0f && material_color.a > 0.0f) ? material_color : input_color;
130}
131
133 const ColorGeometry4f &input_color,
134 const float factor)
135{
136 const float3 rgb = math::interpolate(
137 float3(input_color.r, input_color.g, input_color.b), float3(tmd.color), factor);
138 /* Alpha is unchanged. */
139 return ColorGeometry4f(rgb[0], rgb[1], rgb[2], input_color.a);
140}
141
143 const float4x4 &matrix,
144 const float3 &position,
145 const ColorGeometry4f &input_color,
146 const float factor)
147{
148 const float3 gradient_pos = math::transform_point(matrix, position);
149 const float gradient_factor = std::clamp(
150 math::safe_divide(math::length(gradient_pos), tmd.radius), 0.0f, 1.0f);
151
152 float4 gradient_color;
153 BKE_colorband_evaluate(tmd.color_ramp, gradient_factor, gradient_color);
154
155 const float3 input_rgb = {input_color.r, input_color.g, input_color.b};
156 /* GP2 compatibility: ignore vertex group factor and use the plain modifier setting for
157 * RGB mixing. */
158 const float3 rgb = math::interpolate(
159 input_rgb, gradient_color.xyz(), tmd.factor * gradient_color.w);
160 /* GP2 compatibility: use vertex group factor for alpha. */
161 return ColorGeometry4f(rgb[0], rgb[1], rgb[2], factor);
162}
163
166 bke::CurvesGeometry &curves,
167 const IndexMask &curves_mask,
168 const MutableSpan<ColorGeometry4f> vertex_colors)
169{
170 const bool use_weight_as_factor = (tmd.flag & MOD_GREASE_PENCIL_TINT_USE_WEIGHT_AS_FACTOR);
171 const bool invert_vertex_group = (tmd.influence.flag &
173 const OffsetIndices<int> points_by_curve = curves.points_by_curve();
174
175 bke::AttributeAccessor attributes = curves.attributes();
176 const VArray<int> stroke_materials = *attributes.lookup_or_default<int>(
177 "material_index", bke::AttrDomain::Curve, 0);
179 curves, tmd.influence);
180
181 /* Common input color and base factor calculation. */
182 auto get_material_color = [&](const int64_t curve_i) {
183 const Material *ma = BKE_object_material_get(&ob, stroke_materials[curve_i] + 1);
184 const MaterialGPencilStyle *gp_style = ma ? ma->gp_style : nullptr;
185 return (gp_style ? ColorGeometry4f(gp_style->stroke_rgba) :
186 ColorGeometry4f(0.0f, 0.0f, 0.0f, 0.0f));
187 };
188
189 auto get_point_factor = [&](const int64_t point_i) {
190 if (use_weight_as_factor) {
191 const float weight = vgroup_weights[point_i];
192 return invert_vertex_group ? 1.0f - weight : weight;
193 }
194 return tmd.factor;
195 };
196
198 switch (tint_mode) {
200 curves_mask.foreach_index(GrainSize(512), [&](const int64_t curve_i) {
201 const ColorGeometry4f material_color = get_material_color(curve_i);
202
203 const IndexRange points = points_by_curve[curve_i];
204 for (const int64_t point_i : points) {
205 vertex_colors[point_i] = apply_uniform_tint(
206 tmd,
207 get_base_color(vertex_colors[point_i], material_color),
208 get_point_factor(point_i));
209 }
210 });
211 break;
212 }
214 if (tmd.object == nullptr) {
215 return;
216 }
217
218 const OffsetIndices<int> points_by_curve = curves.points_by_curve();
219 const Span<float3> positions = curves.positions();
220 /* Transforms points to the gradient object space. */
221 const float4x4 matrix = tmd.object->world_to_object() * ob.object_to_world();
222
223 curves_mask.foreach_index(GrainSize(512), [&](const int64_t curve_i) {
224 const ColorGeometry4f material_color = get_material_color(curve_i);
225
226 const IndexRange points = points_by_curve[curve_i];
227 for (const int64_t point_i : points) {
228 vertex_colors[point_i] = apply_gradient_tint(
229 tmd,
230 matrix,
231 positions[point_i],
232 get_base_color(vertex_colors[point_i], material_color),
233 get_point_factor(point_i));
234 }
235 });
236 break;
237 }
238 }
239}
240
241static void modify_fill_color(Object &ob,
243 Drawing &drawing,
244 const IndexMask &curves_mask)
245{
246 const bool use_weight_as_factor = (tmd.flag & MOD_GREASE_PENCIL_TINT_USE_WEIGHT_AS_FACTOR);
247 const bool invert_vertex_group = (tmd.influence.flag &
249 const bke::CurvesGeometry &curves = drawing.strokes();
250 const OffsetIndices<int> points_by_curve = curves.points_by_curve();
252
253 /* Check early before getting attribute writers. */
254 if (tint_mode == MOD_GREASE_PENCIL_TINT_GRADIENT && tmd.object == nullptr) {
255 return;
256 }
257
259 /* Fill color per stroke. */
261 const VArray<int> stroke_materials = *attributes.lookup_or_default<int>(
262 "material_index", bke::AttrDomain::Curve, 0);
264 curves, tmd.influence);
265
266 /* Common input color and base factor calculation. */
267 auto get_material_color = [&](const int64_t curve_i) {
268 const Material *ma = BKE_object_material_get(&ob, stroke_materials[curve_i] + 1);
269 const MaterialGPencilStyle *gp_style = ma ? ma->gp_style : nullptr;
270 return (gp_style ? ColorGeometry4f(gp_style->fill_rgba) :
271 ColorGeometry4f(0.0f, 0.0f, 0.0f, 0.0f));
272 };
273
274 auto get_curve_factor = [&](const int64_t curve_i) {
275 if (use_weight_as_factor) {
276 /* Use the first stroke point as vertex weight. */
277 const IndexRange points = points_by_curve[curve_i];
278 const float weight = points.is_empty() ? 1.0f : vgroup_weights[points.first()];
279 return invert_vertex_group ? 1.0f - weight : weight;
280 }
281 return tmd.factor;
282 };
283
284 switch (tint_mode) {
286 curves_mask.foreach_index(GrainSize(512), [&](int64_t curve_i) {
287 const ColorGeometry4f material_color = get_material_color(curve_i);
288 fill_colors[curve_i] = apply_uniform_tint(
289 tmd, get_base_color(fill_colors[curve_i], material_color), get_curve_factor(curve_i));
290 });
291 break;
292 }
294 const OffsetIndices<int> points_by_curve = curves.points_by_curve();
295 const Span<float3> positions = curves.positions();
296 /* Transforms points to the gradient object space. */
297 const float4x4 matrix = tmd.object->world_to_object() * ob.object_to_world();
298
299 curves_mask.foreach_index(GrainSize(512), [&](int64_t curve_i) {
300 const ColorGeometry4f material_color = get_material_color(curve_i);
301 /* Use the first stroke point for gradient position. */
302 const IndexRange points = points_by_curve[curve_i];
303 const float3 pos = points.is_empty() ? float3(0.0f, 0.0f, 0.0f) :
304 positions[points.first()];
305
306 fill_colors[curve_i] = apply_gradient_tint(
307 tmd,
308 matrix,
309 pos,
310 get_base_color(fill_colors[curve_i], material_color),
311 get_curve_factor(curve_i));
312 });
313 break;
314 }
315 }
316}
317
319 bke::CurvesGeometry &curves,
320 const IndexMask &curves_mask)
321{
322 /* Only when factor is greater than 1. */
323 if (tmd.factor <= 1.0f) {
324 return;
325 }
326
327 const OffsetIndices<int> points_by_curve = curves.points_by_curve();
330 "opacity", bke::AttrDomain::Point);
331
332 curves_mask.foreach_index(GrainSize(512), [&](const int64_t curve_i) {
333 const IndexRange points = points_by_curve[curve_i];
334 for (const int64_t point_i : points) {
335 opacities.span[point_i] = std::clamp(
336 opacities.span[point_i] + tmd.factor - 1.0f, 0.0f, 1.0f);
337 }
338 });
339
340 opacities.finish();
341}
342
343static void modify_curves(ModifierData &md, const ModifierEvalContext &ctx, Drawing &drawing)
344{
345 auto &tmd = reinterpret_cast<GreasePencilTintModifierData &>(md);
346 bke::CurvesGeometry &curves = drawing.strokes_for_write();
347
348 IndexMaskMemory mask_memory;
350 ctx.object, curves, tmd.influence, mask_memory);
351
352 /* Factor > 1.0 also affects the opacity of the stroke. */
353 modify_opacity(tmd, curves, curves_mask);
354
355 switch (tmd.color_mode) {
358 *ctx.object, tmd, curves, curves_mask, drawing.vertex_colors_for_write());
359 break;
361 modify_fill_color(*ctx.object, tmd, drawing, curves_mask);
362 break;
365 *ctx.object, tmd, curves, curves_mask, drawing.vertex_colors_for_write());
366 modify_fill_color(*ctx.object, tmd, drawing, curves_mask);
367 break;
370 break;
371 }
372}
373
375 const ModifierEvalContext *ctx,
376 bke::GeometrySet *geometry_set)
377{
378 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
379
380 if (!geometry_set->has_grease_pencil()) {
381 return;
382 }
383 GreasePencil &grease_pencil = *geometry_set->get_grease_pencil_for_write();
384 const int frame = grease_pencil.runtime->eval_frame;
385
386 IndexMaskMemory mask_memory;
388 grease_pencil, tmd->influence, mask_memory);
390 grease_pencil, layer_mask, frame);
392 [&](Drawing *drawing) { modify_curves(*md, *ctx, *drawing); });
393}
394
395static void panel_draw(const bContext *C, Panel *panel)
396{
397 uiLayout *layout = panel->layout;
398
399 PointerRNA ob_ptr;
401
402 uiLayoutSetPropSep(layout, true);
403
405 RNA_enum_get(ptr, "tint_mode"));
406 const bool use_weight_as_factor = RNA_boolean_get(ptr, "use_weight_as_factor");
407
408 uiItemR(layout, ptr, "color_mode", UI_ITEM_NONE, nullptr, ICON_NONE);
409
410 uiLayout *row = uiLayoutRow(layout, true);
411 uiLayoutSetActive(row, !use_weight_as_factor);
412 uiItemR(row, ptr, "factor", UI_ITEM_NONE, nullptr, ICON_NONE);
413 uiItemR(row, ptr, "use_weight_as_factor", UI_ITEM_NONE, "", ICON_MOD_VERTEX_WEIGHT);
414
415 uiItemR(layout, ptr, "tint_mode", UI_ITEM_R_EXPAND, nullptr, ICON_NONE);
416 switch (tint_mode) {
418 uiItemR(layout, ptr, "color", UI_ITEM_NONE, nullptr, ICON_NONE);
419 break;
421 uiLayout *col = uiLayoutColumn(layout, false);
422 uiLayoutSetPropSep(col, false);
423 uiTemplateColorRamp(col, ptr, "color_ramp", true);
424 uiItemS(layout);
425 uiItemR(layout, ptr, "object", UI_ITEM_NONE, nullptr, ICON_NONE);
426 uiItemR(layout, ptr, "radius", UI_ITEM_NONE, nullptr, ICON_NONE);
427 break;
428 }
429
430 if (uiLayout *influence_panel = uiLayoutPanelProp(
431 C, layout, ptr, "open_influence_panel", IFACE_("Influence")))
432 {
437 }
438
439 modifier_panel_end(layout, ptr);
440}
441
446
447static void blend_write(BlendWriter *writer, const ID * /*id_owner*/, const ModifierData *md)
448{
449 const auto *tmd = reinterpret_cast<const GreasePencilTintModifierData *>(md);
450
452 modifier::greasepencil::write_influence_data(writer, &tmd->influence);
453 if (tmd->color_ramp) {
454 BLO_write_struct(writer, ColorBand, tmd->color_ramp);
455 }
456}
457
458static void blend_read(BlendDataReader *reader, ModifierData *md)
459{
460 auto *tmd = reinterpret_cast<GreasePencilTintModifierData *>(md);
461
462 modifier::greasepencil::read_influence_data(reader, &tmd->influence);
463 BLO_read_struct(reader, ColorBand, &tmd->color_ramp);
464}
465
466} // namespace blender
467
469 /*idname*/ "GreasePencilTint",
470 /*name*/ N_("Tint"),
471 /*struct_name*/ "GreasePencilTintModifierData",
472 /*struct_size*/ sizeof(GreasePencilTintModifierData),
473 /*srna*/ &RNA_GreasePencilTintModifier,
477 /*icon*/ ICON_MOD_TINT,
478
479 /*copy_data*/ blender::copy_data,
480
481 /*deform_verts*/ nullptr,
482 /*deform_matrices*/ nullptr,
483 /*deform_verts_EM*/ nullptr,
484 /*deform_matrices_EM*/ nullptr,
485 /*modify_mesh*/ nullptr,
486 /*modify_geometry_set*/ blender::modify_geometry_set,
487
488 /*init_data*/ blender::init_data,
489 /*required_data_mask*/ nullptr,
490 /*free_data*/ blender::free_data,
491 /*is_disabled*/ blender::is_disabled,
492 /*update_depsgraph*/ blender::update_depsgraph,
493 /*depends_on_time*/ nullptr,
494 /*depends_on_normals*/ nullptr,
495 /*foreach_ID_link*/ blender::foreach_ID_link,
496 /*foreach_tex_link*/ nullptr,
497 /*free_runtime_data*/ nullptr,
498 /*panel_register*/ blender::panel_register,
499 /*blend_write*/ blender::blend_write,
500 /*blend_read*/ blender::blend_read,
501};
bool BKE_colorband_evaluate(const ColorBand *coba, float in, float out[4])
Definition colorband.cc:396
ColorBand * BKE_colorband_add(bool rangetype)
Definition colorband.cc:298
void BKE_colorband_init(ColorBand *coba, bool rangetype)
Definition colorband.cc:22
Low-level operations for curves.
Low-level operations for grease pencil.
@ IDWALK_CB_NOP
General operations, lookup, etc. for materials.
struct Material * BKE_object_material_get(struct Object *ob, short act)
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_SupportsMapping
@ eModifierTypeFlag_AcceptsGreasePencil
@ eModifierTypeFlag_EnableInEditmode
@ eModifierTypeFlag_SupportsEditmode
void(*)(void *user_data, Object *ob, ID **idpoin, int cb_flag) IDWalkFunc
#define BLI_assert_unreachable()
Definition BLI_assert.h:97
#define BLI_assert(a)
Definition BLI_assert.h:50
#define MEMCMP_STRUCT_AFTER_IS_ZERO(struct_var, member)
#define MEMCPY_STRUCT_AFTER(struct_dst, struct_src, member)
#define BLO_write_struct(writer, struct_name, data_ptr)
#define BLO_read_struct(reader, struct_name, ptr_p)
#define IFACE_(msgid)
void DEG_add_object_relation(DepsNodeHandle *node_handle, Object *object, eDepsObjectComponentType component, const char *description)
@ DEG_OB_COMP_TRANSFORM
#define DNA_struct_default_get(struct_name)
@ GREASE_PENCIL_INFLUENCE_INVERT_VERTEX_GROUP
@ MOD_GREASE_PENCIL_COLOR_FILL
@ MOD_GREASE_PENCIL_COLOR_STROKE
@ MOD_GREASE_PENCIL_COLOR_BOTH
@ MOD_GREASE_PENCIL_COLOR_HARDNESS
GreasePencilTintModifierMode
@ MOD_GREASE_PENCIL_TINT_UNIFORM
@ MOD_GREASE_PENCIL_TINT_GRADIENT
@ MOD_GREASE_PENCIL_TINT_USE_WEIGHT_AS_FACTOR
@ eModifierType_GreasePencilTint
static bool is_disabled
Read Guarded memory(de)allocation.
#define MEM_SAFE_FREE(v)
ModifierTypeInfo modifierType_GreasePencilTint
void modifier_panel_end(uiLayout *layout, PointerRNA *ptr)
PanelType * modifier_panel_register(ARegionType *region_type, ModifierType type, PanelDrawFn draw)
PointerRNA * modifier_panel_get_property_pointers(Panel *panel, PointerRNA *r_ob_ptr)
#define C
Definition RandGen.cpp:29
void uiLayoutSetActive(uiLayout *layout, bool active)
uiLayout * uiLayoutRow(uiLayout *layout, bool align)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
void uiItemS(uiLayout *layout)
void uiTemplateColorRamp(uiLayout *layout, PointerRNA *ptr, const char *propname, bool expand)
#define UI_ITEM_NONE
PanelLayout uiLayoutPanelProp(const bContext *C, uiLayout *layout, PointerRNA *open_prop_owner, const char *open_prop_name)
uiLayout * uiLayoutColumn(uiLayout *layout, bool align)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
@ UI_ITEM_R_EXPAND
ChannelStorageType r
Definition BLI_color.hh:88
ChannelStorageType g
Definition BLI_color.hh:88
ChannelStorageType b
Definition BLI_color.hh:88
ChannelStorageType a
Definition BLI_color.hh:88
constexpr int64_t first() const
constexpr bool is_empty() const
GAttributeReader lookup_or_default(StringRef attribute_id, AttrDomain domain, eCustomDataType data_type, const void *default_value=nullptr) const
OffsetIndices< int > points_by_curve() const
MutableAttributeAccessor attributes_for_write()
Span< float3 > positions() const
GSpanAttributeWriter lookup_or_add_for_write_span(StringRef attribute_id, AttrDomain domain, eCustomDataType data_type, const AttributeInit &initializer=AttributeInitDefaultValue())
bke::CurvesGeometry & strokes_for_write()
const bke::CurvesGeometry & strokes() const
MutableSpan< ColorGeometry4f > fill_colors_for_write()
MutableSpan< ColorGeometry4f > vertex_colors_for_write()
void foreach_index(Fn &&fn) const
uint col
void *(* MEM_dupallocN)(const void *vmemh)
Definition mallocn.cc:39
T safe_divide(const T &a, const T &b)
T length(const VecBase< T, Size > &a)
T interpolate(const T &a, const T &b, const FactorT &t)
VecBase< T, 3 > transform_point(const CartesianBasis &basis, const VecBase< T, 3 > &v)
void read_influence_data(BlendDataReader *reader, GreasePencilModifierInfluenceData *influence_data)
void init_influence_data(GreasePencilModifierInfluenceData *influence_data, const bool has_custom_curve)
static IndexMask get_filtered_layer_mask(const GreasePencil &grease_pencil, const std::optional< StringRef > layer_name_filter, const std::optional< int > layer_pass_filter, const bool layer_filter_invert, const bool layer_pass_filter_invert, IndexMaskMemory &memory)
static IndexMask get_filtered_stroke_mask(const Object *ob, const bke::CurvesGeometry &curves, const Material *material_filter, const std::optional< int > material_pass_filter, const bool material_filter_invert, const bool material_pass_filter_invert, IndexMaskMemory &memory)
void write_influence_data(BlendWriter *writer, const GreasePencilModifierInfluenceData *influence_data)
void draw_vertex_group_settings(const bContext *, uiLayout *layout, PointerRNA *ptr)
VArray< float > get_influence_vertex_weights(const bke::CurvesGeometry &curves, const GreasePencilModifierInfluenceData &influence_data)
Vector< bke::greasepencil::Drawing * > get_drawings_for_write(GreasePencil &grease_pencil, const IndexMask &layer_mask, const int frame)
void draw_material_filter_settings(const bContext *, uiLayout *layout, PointerRNA *ptr)
void draw_layer_filter_settings(const bContext *, uiLayout *layout, PointerRNA *ptr)
void draw_custom_curve_settings(const bContext *, uiLayout *layout, PointerRNA *ptr)
void free_influence_data(GreasePencilModifierInfluenceData *influence_data)
void foreach_influence_ID_link(GreasePencilModifierInfluenceData *influence_data, Object *ob, IDWalkFunc walk, void *user_data)
void copy_influence_data(const GreasePencilModifierInfluenceData *influence_data_src, GreasePencilModifierInfluenceData *influence_data_dst, const int)
void parallel_for_each(Range &&range, const Function &function)
Definition BLI_task.hh:58
static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
static void blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
static ColorGeometry4f apply_uniform_tint(const GreasePencilTintModifierData &tmd, const ColorGeometry4f &input_color, const float factor)
static void modify_curves(ModifierData &md, const ModifierEvalContext &ctx, Drawing &drawing)
static void init_data(ModifierData *md)
static void foreach_ID_link(ModifierData *md, Object *ob, IDWalkFunc walk, void *user_data)
static void panel_draw(const bContext *C, Panel *panel)
MatBase< float, 4, 4 > float4x4
VecBase< float, 4 > float4
static void modify_geometry_set(ModifierData *md, const ModifierEvalContext *ctx, bke::GeometrySet *geometry_set)
static void modify_fill_color(Object &ob, const GreasePencilColorModifierData &cmd, Drawing &drawing, const IndexMask &curves_mask)
static ColorGeometry4f get_base_color(const ColorGeometry4f &input_color, const ColorGeometry4f &material_color)
static void free_data(ModifierData *md)
static void panel_register(ARegionType *region_type)
static ColorGeometry4f apply_gradient_tint(const GreasePencilTintModifierData &tmd, const float4x4 &matrix, const float3 &position, const ColorGeometry4f &input_color, const float factor)
static void modify_stroke_color(Object &ob, const GreasePencilColorModifierData &cmd, bke::CurvesGeometry &curves, const IndexMask &curves_mask, const MutableSpan< ColorGeometry4f > vertex_colors)
static void modify_opacity(const GreasePencilTintModifierData &tmd, bke::CurvesGeometry &curves, const IndexMask &curves_mask)
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
ColorSceneLinear4f< eAlpha::Premultiplied > ColorGeometry4f
Definition BLI_color.hh:337
VecBase< float, 3 > float3
static bool is_disabled(const Scene *, ModifierData *md, bool)
static void blend_read(BlendDataReader *reader, ModifierData *md)
bool RNA_boolean_get(PointerRNA *ptr, const char *name)
int RNA_enum_get(PointerRNA *ptr, const char *name)
__int64 int64_t
Definition stdint.h:89
GreasePencilModifierInfluenceData influence
GreasePencilRuntimeHandle * runtime
Definition DNA_ID.h:413
struct MaterialGPencilStyle * gp_style
struct uiLayout * layout
VecBase< T, 3 > xyz() const
GreasePencil * get_grease_pencil_for_write()
#define N_(msgid)
PointerRNA * ptr
Definition wm_files.cc:4126
uint8_t flag
Definition wm_window.cc:138