49#include "RNA_prototypes.hh"
100 if (omd->object !=
nullptr) {
124 const IndexRange points = src_offsets[curve_i];
125 const int point_num = points.
size();
126 const int point_start = points.start();
128 if (points.size() < 2) {
129 array_utils::fill_index_range(point_indices, point_start);
134 const int offset_raw = curve_offsets[curve_i];
135 const int offset = offset_raw >= 0 ? offset_raw % points.size() :
136 points.size() - ((-offset_raw) % points.size());
137 BLI_assert(0 <= offset && offset < points.size());
143 const int point_middle = point_start + offset;
160 if (positions.is_empty()) {
166 for (
const int i : positions.index_range().drop_front(1)) {
168 if (dist_squared < min_dist_squared) {
170 min_dist_squared = dist_squared;
206 drawing, curves_mask, viewmat, omd.
subdiv, radius, outline_offset, mat_nr);
210 const OffsetIndices points_by_curve = curves.points_by_curve();
213 Array<int> offset_by_curve(curves.curves_num());
214 for (
const int i : curves.curves_range()) {
226 curves.curves_num());
245 if (!scene->camera) {
248 const float4x4 viewinv = scene->camera->world_to_object();
254 const int frame = grease_pencil.
runtime->eval_frame;
258 grease_pencil, omd.influence, mask_memory);
261 grease_pencil, layer_mask, frame);
263 const Layer &layer = grease_pencil.layer(info.layer_index);
264 const float4x4 viewmat = viewinv * layer.to_world_space(*ctx->
object);
286 if (scene->camera ==
nullptr) {
287 uiItemL(layout,
RPT_(
"Outline requires an active camera"), ICON_ERROR);
291 C, layout,
ptr,
"open_influence_panel",
IFACE_(
"Influence")))
323 "GreasePencilOutline",
325 "GreasePencilOutlineModifierData",
327 &RNA_GreasePencilOutlineModifier,
Scene * CTX_data_scene(const bContext *C)
Low-level operations for curves.
Low-level operations for grease pencil.
General operations, lookup, etc. for materials.
int BKE_object_material_index_get(Object *ob, const Material *ma)
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 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)
void DEG_add_object_relation(DepsNodeHandle *node_handle, Object *object, eDepsObjectComponentType component, const char *description)
Scene * DEG_get_evaluated_scene(const Depsgraph *graph)
#define DNA_struct_default_get(struct_name)
struct GreasePencilOutlineModifierData GreasePencilOutlineModifierData
@ MOD_GREASE_PENCIL_OUTLINE_KEEP_SHAPE
@ eModifierType_GreasePencilOutline
ModifierTypeInfo modifierType_GreasePencilOutline
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)
void uiItemL(uiLayout *layout, const char *name, int icon)
void uiLayoutSetPropSep(uiLayout *layout, bool is_sep)
PanelLayout uiLayoutPanelProp(const bContext *C, uiLayout *layout, PointerRNA *open_prop_owner, const char *open_prop_name)
void uiItemR(uiLayout *layout, PointerRNA *ptr, const char *propname, eUI_Item_Flag flag, const char *name, int icon)
constexpr MutableSpan take_back(const int64_t n) const
constexpr MutableSpan take_front(const int64_t n) const
constexpr int64_t size() const
static VArray ForSingle(T value, const int64_t size)
OffsetIndices< int > points_by_curve() const
MutableAttributeAccessor attributes_for_write()
AttributeAccessor attributes() const
bke::CurvesGeometry & strokes_for_write()
const bke::CurvesGeometry & strokes() const
void tag_topology_changed()
void foreach_index(Fn &&fn) const
void fill_index_range(MutableSpan< T > span, const T start=0)
constexpr float LEGACY_RADIUS_CONVERSION_FACTOR
void gather_attributes(AttributeAccessor src_attributes, AttrDomain src_domain, AttrDomain dst_domain, const AttributeFilter &attribute_filter, const IndexMask &selection, MutableAttributeAccessor dst_attributes)
bke::CurvesGeometry create_curves_outline(const bke::greasepencil::Drawing &drawing, const IndexMask &strokes, const float4x4 &transform, const int corner_subdivisions, const float outline_radius, const float outline_offset, const int material_index)
CurvesGeometry resample_to_length(const CurvesGeometry &src_curves, const IndexMask &selection, const VArray< float > &sample_lengths, const ResampleCurvesOutputAttributeIDs &output_ids={})
T length(const VecBase< T, Size > &a)
T distance_squared(const VecBase< T, Size > &a, const VecBase< T, Size > &b)
T max(const T &a, const T &b)
VecBase< T, 3 > transform_direction(const MatBase< T, 3, 3 > &mat, const VecBase< T, 3 > &direction)
void read_influence_data(BlendDataReader *reader, GreasePencilModifierInfluenceData *influence_data)
void init_influence_data(GreasePencilModifierInfluenceData *influence_data, const bool has_custom_curve)
Vector< LayerDrawingInfo > get_drawing_infos_by_layer(GreasePencil &grease_pencil, const IndexMask &layer_mask, const int frame)
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_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 ensure_no_bezier_curves(Drawing &drawing)
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 int find_closest_point(const Span< float3 > positions, const float3 &target)
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 bke::CurvesGeometry reorder_cyclic_curve_points(const bke::CurvesGeometry &src_curves, const IndexMask &curve_selection, const Span< int > curve_offsets)
static void modify_geometry_set(ModifierData *md, const ModifierEvalContext *ctx, bke::GeometrySet *geometry_set)
static void free_data(ModifierData *md)
static void panel_register(ARegionType *region_type)
static void modify_drawing(const GreasePencilArrayModifierData &mmd, const ModifierEvalContext &ctx, bke::greasepencil::Drawing &drawing)
static void update_depsgraph(ModifierData *md, const ModifierUpdateDepsgraphContext *ctx)
static void blend_read(BlendDataReader *reader, ModifierData *md)
GreasePencilModifierInfluenceData influence
struct Material * outline_material
GreasePencilRuntimeHandle * runtime
bool has_grease_pencil() const
GreasePencil * get_grease_pencil_for_write()