38#include "RNA_prototypes.hh"
83 const bool normalize_u)
98 if (!u_translations || !rotations || !u_scales) {
105 const IndexRange points = points_by_curve[curve_i];
110 u_translations.
span[curve_i] += offset;
111 u_scales.span[curve_i] *= scale *
norm;
112 for (
const int point_i : points) {
113 rotations.span[point_i] += rotation;
126 return float2(p.x * cos_angle - p.y * sin_angle, p.x * sin_angle + p.y * cos_angle);
139 if (positions.
size() < 2) {
144 const float3 &pt0 = positions[0];
145 const float3 &pt1 = positions[1];
146 const float3 &pt3 = positions[int(positions.
size() * 0.75f)];
152 const float3 local_3 = (positions.
size() == 2) ? (pt3 * 0.001f) - pt0 : pt3 - pt0;
170 const float rotation,
207 float4x2 &texture_matrix = texture_matrices[curve_i];
215 const float3x2 uv_matrix = texture_matrix * stroke_to_layer;
216 const float2 uv_translation = uv_matrix[2];
221 const float uv_rotation =
math::atan2(axis_u[1], axis_u[0]);
226 const float legacy_uv_rotation = uv_rotation;
227 const float2 legacy_uv_scale = 0.5f * uv_scale;
229 const float2 legacy_uv_translation_new = legacy_uv_translation + offset;
230 const float legacy_uv_rotation_new = legacy_uv_rotation + rotation;
231 const float2 legacy_uv_scale_new = legacy_uv_scale *
scale;
233 const float2 uv_translation_new =
234 (
rotate_by_angle(legacy_uv_translation_new, legacy_uv_rotation_new) + 0.5f) *
236 const float uv_rotation_new = legacy_uv_rotation_new;
237 const float2 uv_scale_new = 2.0f * legacy_uv_scale_new;
239 const float cos_uv_rotation_new =
math::cos(uv_rotation_new);
240 const float sin_uv_rotation_new =
math::sin(uv_rotation_new);
243 inv_uv_scale_new[0] *
float2(cos_uv_rotation_new, sin_uv_rotation_new),
244 inv_uv_scale_new[1] *
float2(-sin_uv_rotation_new, cos_uv_rotation_new),
246 texture_matrix = uv_matrix_new * layer_to_stroke;
295 grease_pencil, tmd.influence, mask_memory);
296 const int frame = grease_pencil.
runtime->eval_frame;
298 grease_pencil, layer_mask, frame);
337 C,
ptr,
"open_influence_panel",
IFACE_(
"Influence")))
369 "GreasePencilTexture",
370 N_(
"TextureMapping"),
371 "GreasePencilTextureModifierData",
373 &RNA_GreasePencilTextureModifier,
Low-level operations for curves.
Low-level operations for grease pencil.
void(*)(void *user_data, Object *ob, ID **idpoin, LibraryForeachIDCallbackFlag cb_flag) IDWalkFunc
void BKE_modifier_copydata_generic(const ModifierData *md, ModifierData *md_dst, int flag)
@ eModifierTypeFlag_SupportsMapping
@ eModifierTypeFlag_AcceptsGreasePencil
@ eModifierTypeFlag_EnableInEditmode
@ eModifierTypeFlag_SupportsEditmode
#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 DNA_struct_default_get(struct_name)
@ eModifierType_GreasePencilTexture
GreasePencilTextureModifierMode
@ MOD_GREASE_PENCIL_TEXTURE_STROKE_AND_FILL
@ MOD_GREASE_PENCIL_TEXTURE_FILL
@ MOD_GREASE_PENCIL_TEXTURE_STROKE
@ MOD_GREASE_PENCIL_TEXTURE_FIT_STROKE
static double angle(const Eigen::Vector3d &v1, const Eigen::Vector3d &v2)
ModifierTypeInfo modifierType_GreasePencilTexture
PanelType * modifier_panel_register(ARegionType *region_type, ModifierType type, PanelDrawFn draw)
PointerRNA * modifier_panel_get_property_pointers(Panel *panel, PointerRNA *r_ob_ptr)
void modifier_error_message_draw(uiLayout *layout, PointerRNA *ptr)
SIMD_FORCE_INLINE btScalar norm() const
Return the norm (length) of the vector.
constexpr Span slice(int64_t start, int64_t size) const
constexpr int64_t size() const
constexpr const T & last(const int64_t n=0) const
static VArray from_single(T value, const int64_t size)
OffsetIndices< int > points_by_curve() const
MutableAttributeAccessor attributes_for_write()
Span< float > evaluated_lengths_for_curve(int curve_index, bool cyclic) const
Span< float3 > positions() const
void ensure_evaluated_lengths() const
VArray< bool > cyclic() const
GSpanAttributeWriter lookup_or_add_for_write_span(StringRef attribute_id, AttrDomain domain, AttrType data_type, const AttributeInit &initializer=AttributeInitDefaultValue())
Span< float4x2 > texture_matrices() const
bke::CurvesGeometry & strokes_for_write()
const bke::CurvesGeometry & strokes() const
void set_texture_matrices(Span< float4x2 > matrices, const IndexMask &selection)
void foreach_index(Fn &&fn) const
dot(value.rgb, luminance_coefficients)") DEFINE_VALUE("REDUCE(lhs
static bool is_cyclic(const Nurb *nu)
VecBase< float, D > normalize(VecOp< float, D >) RET
VecBase< float, 3 > cross(VecOp< float, 3 >, VecOp< float, 3 >) RET
T cos(const AngleRadianBase< T > &a)
MatBase< T, NumCol, NumRow > transpose(const MatBase< T, NumRow, NumCol > &mat)
MatBase< T, NumCol, NumRow > scale(const MatBase< T, NumCol, NumRow > &mat, const VectorT &scale)
QuaternionBase< T > normalize_and_get_length(const QuaternionBase< T > &q, T &out_length)
T atan2(const T &y, const T &x)
T sin(const AngleRadianBase< T > &a)
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_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)
static IndexMask get_filtered_layer_mask(const GreasePencil &grease_pencil, const std::optional< StringRef > tree_node_name_filter, const std::optional< int > layer_pass_filter, const bool layer_filter_invert, const bool layer_pass_filter_invert, IndexMaskMemory &memory)
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 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)
static void copy_data(const ModifierData *md, ModifierData *target, const int flag)
static void blend_write(BlendWriter *writer, const ID *, const ModifierData *md)
static float2 rotate_by_angle(const float2 &p, const float angle)
static void modify_curves(ModifierData &md, const ModifierEvalContext &ctx, Drawing &drawing, bke::GreasePencilDrawingEditHints *edit_hints)
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)
static void write_fill_transforms(bke::greasepencil::Drawing &drawing, const IndexMask &curves_mask, const float2 &offset, const float rotation, const float scale)
MatBase< float, 3, 4 > float3x4
VecBase< float, 4 > float4
static void modify_geometry_set(ModifierData *md, const ModifierEvalContext *ctx, bke::GeometrySet *geometry_set)
VecBase< float, 2 > float2
static void free_data(ModifierData *md)
MatBase< float, 4, 2 > float4x2
static void panel_register(ARegionType *region_type)
MatBase< float, 3, 2 > float3x2
static void write_stroke_transforms(bke::greasepencil::Drawing &drawing, const IndexMask &curves_mask, const float offset, const float rotation, const float scale, const bool normalize_u)
MatBase< float, 4, 3 > float4x3
static void get_legacy_stroke_matrix(const Span< float3 > positions, float3x4 &stroke_to_layer, float4x3 &layer_to_stroke)
VecBase< float, 3 > float3
static void blend_read(BlendDataReader *reader, ModifierData *md)
GreasePencilModifierInfluenceData influence
GreasePencilRuntimeHandle * runtime
static MatBase identity()
bool has_grease_pencil() const
GreasePencil * get_grease_pencil_for_write()
MutableVArraySpan< T > span
PanelLayout panel_prop(const bContext *C, PointerRNA *open_prop_owner, blender::StringRefNull open_prop_name)
uiLayout & column(bool align)
void separator(float factor=1.0f, LayoutSeparatorType type=LayoutSeparatorType::Auto)
void use_property_split_set(bool value)
void prop(PointerRNA *ptr, PropertyRNA *prop, int index, int value, eUI_Item_Flag flag, std::optional< blender::StringRef > name_opt, int icon, std::optional< blender::StringRef > placeholder=std::nullopt)