30static float hash_rng(uint32_t seed1, uint32_t seed2,
int index)
85 const float2 &co = view_positions[point_i];
87 paint, brush, co, extension_sample,
params.multi_frame_falloff);
88 if (influence <= 0.0f) {
93 projection_fn, deformation, point_i, sideways * influence *
noise);
96 params.drawing.tag_positions_changed();
102 const float2 &co = view_positions[point_i];
104 paint, brush, co, extension_sample,
params.multi_frame_falloff);
105 if (influence <= 0.0f) {
109 opacities[point_i] =
math::clamp(opacities[point_i] + influence *
noise, 0.0f, 1.0f);
116 const float2 &co = view_positions[point_i];
118 paint, brush, co, extension_sample,
params.multi_frame_falloff);
119 if (influence <= 0.0f) {
123 radii[point_i] =
math::max(radii[point_i] + influence *
noise * 0.001f, 0.0f);
125 curves.tag_radii_changed();
134 const float2 &co = view_positions[point_i];
136 paint, brush, co, extension_sample,
params.multi_frame_falloff);
137 if (influence <= 0.0f) {
156 return std::make_unique<RandomizeOperation>(stroke_mode);
Low-level operations for curves.
Low-level operations for grease pencil.
Paint * BKE_paint_get_active_from_context(const bContext *C)
Brush * BKE_paint_brush(Paint *paint)
BLI_INLINE float BLI_hash_int_01(unsigned int k)
BLI_INLINE unsigned int BLI_hash_int_3d(unsigned int kx, unsigned int ky, unsigned int kz)
@ GP_SCULPT_FLAGMODE_APPLY_UV
@ GP_SCULPT_FLAGMODE_APPLY_POSITION
@ GP_SCULPT_FLAGMODE_APPLY_THICKNESS
@ GP_SCULPT_FLAGMODE_APPLY_STRENGTH
static unsigned long seed
static RandomNumberGenerator from_random_seed()
GSpanAttributeWriter lookup_or_add_for_write_span(StringRef attribute_id, AttrDomain domain, AttrType data_type, const AttributeInit &initializer=AttributeInitDefaultValue())
GreasePencilStrokeOperationCommon()=default
float2 mouse_delta(const InputSample &input_sample) const
void foreach_editable_drawing_with_automask(const bContext &C, FunctionRef< bool(const GreasePencilStrokeParams ¶ms, const IndexMask &points)> fn) const
void stroke_extended(const InputSample &extension_sample)
void init_stroke(const bContext &C, const InputSample &start_sample)
void init_auto_masking(const bContext &C, const InputSample &start_sample)
void on_stroke_done(const bContext &) override
void on_stroke_begin(const bContext &C, const InputSample &start_sample) override
GreasePencilStrokeOperationCommon()=default
void on_stroke_extended(const bContext &C, const InputSample &extension_sample) override
uint32_t unique_seed() const
void foreach_index(Fn &&fn) const
float brush_point_influence(const Paint &paint, const Brush &brush, const float2 &co, const InputSample &sample, float multi_frame_falloff)
std::unique_ptr< GreasePencilStrokeOperation > new_randomize_operation(BrushStrokeMode stroke_mode)
Array< float2 > calculate_view_positions(const GreasePencilStrokeParams ¶ms, const IndexMask &selection)
bke::crazyspace::GeometryDeformation get_drawing_deformation(const GreasePencilStrokeParams ¶ms)
static float hash_rng(uint32_t seed1, uint32_t seed2, int index)
float3 compute_orig_delta(const DeltaProjectionFunc &projection_fn, const bke::crazyspace::GeometryDeformation &deformation, int index, const float2 &screen_delta)
std::function< float3(const float3 position, const float2 &screen_delta)> DeltaProjectionFunc
T clamp(const T &a, const T &min, const T &max)
MatBase< T, NumCol, NumRow > normalize(const MatBase< T, NumCol, NumRow > &a)
T max(const T &a, const T &b)
VecBase< float, 2 > float2
struct BrushGpencilSettings * gpencil_settings