37 const float radius_squared = radius * radius;
46 float3 average_color(0.0f);
51 params, use_selection_masking, memory);
52 if (!point_selection.
is_empty() && do_points) {
59 view_positions[point_i]) < radius_squared)
67 params, use_selection_masking, memory);
68 if (!fill_selection.is_empty() && do_fill) {
73 fill_selection.foreach_index([&](
const int64_t curve_i) {
74 const IndexRange points = points_by_curve[curve_i];
78 curve_view_positions) < radius)
88 if (color_count <= 0) {
91 average_color = average_color / color_count;
93 const ColorGeometry4f mix_color(average_color.x, average_color.y, average_color.z, 1.0f);
98 params, use_selection_masking, memory);
99 if (!point_selection.
is_empty() && do_points) {
105 paint, brush, view_positions[point_i], extension_sample,
params.multi_frame_falloff);
113 params, use_selection_masking, memory);
114 if (!fill_selection.is_empty() && do_fill) {
120 const IndexRange points = points_by_curve[curve_i];
123 paint, brush, curve_view_positions, extension_sample,
params.multi_frame_falloff);
137 return std::make_unique<VertexAverageOperation>();
Scene * CTX_data_scene(const bContext *C)
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)
Span< T > as_span() const
GreasePencilStrokeOperationCommon()=default
void init_stroke(const bContext &C, const InputSample &start_sample)
void foreach_editable_drawing(const bContext &C, FunctionRef< bool(const GreasePencilStrokeParams ¶ms, const DeltaProjectionFunc &projection_fn)> fn) const
void on_stroke_begin(const bContext &C, const InputSample &start_sample) override
void on_stroke_done(const bContext &C) override
void on_stroke_extended(const bContext &C, const InputSample &extension_sample) override
void foreach_index(Fn &&fn) const
bool ED_grease_pencil_any_vertex_mask_selection(const ToolSettings *tool_settings)
float closest_distance_to_surface_2d(const float2 pt, const Span< float2 > verts)
IndexMask fill_mask_for_stroke_operation(const GreasePencilStrokeParams ¶ms, bool use_selection_masking, IndexMaskMemory &memory)
bool do_vertex_color_fill(const Brush &brush)
IndexMask point_mask_for_stroke_operation(const GreasePencilStrokeParams ¶ms, bool use_selection_masking, IndexMaskMemory &memory)
float brush_point_influence(const Paint &paint, const Brush &brush, const float2 &co, const InputSample &sample, float multi_frame_falloff)
Array< float2 > calculate_view_positions(const GreasePencilStrokeParams ¶ms, const IndexMask &selection)
float brush_fill_influence(const Paint &paint, const Brush &brush, Span< float2 > fill_positions, const InputSample &sample, float multi_frame_falloff)
std::unique_ptr< GreasePencilStrokeOperation > new_vertex_average_operation()
bool do_vertex_color_points(const Brush &brush)
float brush_radius(const Paint &paint, const Brush &brush, float pressure)
T interpolate(const T &a, const T &b, const FactorT &t)
T distance_squared(const VecBase< T, Size > &a, const VecBase< T, Size > &b)
ColorSceneLinear4f< eAlpha::Premultiplied > ColorGeometry4f
VecBase< float, 3 > float3
struct ToolSettings * toolsettings