summaryrefslogtreecommitdiffstats
path: root/src/path/path-util.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/path/path-util.h')
-rw-r--r--src/path/path-util.h162
1 files changed, 162 insertions, 0 deletions
diff --git a/src/path/path-util.h b/src/path/path-util.h
new file mode 100644
index 0000000..77e3fcb
--- /dev/null
+++ b/src/path/path-util.h
@@ -0,0 +1,162 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/** @file
+ * Path utilities.
+ *//*
+ * Authors: see git history
+ *
+ * Copyright (C) 2018 Authors
+ * Released under GNU GPL v2+, read the file 'COPYING' for more information.
+ */
+#ifndef PATH_UTIL_H
+#define PATH_UTIL_H
+
+#include <2geom/forward.h>
+#include <2geom/path.h>
+
+#include "livarot/Path.h"
+#include "display/curve.h"
+
+#include <optional>
+
+class SPItem;
+
+/**
+ * Creates a Livarot Path object from the Geom::PathVector.
+ *
+ * @param pathv A reference to the pathvector to convert.
+ *
+ * @return A pointer to the livarot Path object. The caller would need
+ * to free the object after using it.
+ */
+Path *Path_for_pathvector(Geom::PathVector const &pathv);
+
+/**
+ * Creates a Livarot Path object from an SPItem. The Geom::PathVector extracted from
+ * the item would be before applying LPEs for SPPath and after applying LPEs for other shapes.
+ *
+ * @param item A pointer to the SPItem object.
+ * @param doTransformation See the same parameter in pathvector_for_curve().
+ * @param transformFull See the same parameter in pathvector_for_curve().
+ *
+ * @return A pointer to the livarot Path object. The caller would need
+ * to free the object after using it.
+ */
+Path *Path_for_item(SPItem *item, bool doTransformation, bool transformFull = true);
+
+/**
+ * Creates a Livarot Path object from the SPItem. This function ensures that the Geom::PathVector
+ * extracted is the one before applying the LPE stack.
+ *
+ * @param item A pointer to the SPItem object.
+ * @param doTransformation See the same parameter in pathvector_for_curve().
+ * @param transformFull See the same parameter in pathvector_for_curve().
+ *
+ * @return A pointer to the livarot Path object. The caller would need
+ * to free the object after using it.
+ */
+Path *Path_for_item_before_LPE(SPItem *item, bool doTransformation, bool transformFull = true);
+
+/**
+ * Gets a Geom::PathVector from the SPCurve object.
+ *
+ * TODO: see if calling this method can be optimized. All the pathvector copying might be slow.
+ *
+ * @param item A pointer to the original SPItem. This is required to get the transformation
+ * information.
+ * @param curve A pointer to the SPCurve. If this pointer is null, the function returns nullptr too.
+ * @param doTransformation If set to true, the transformation in the SPItem is applied.
+ * @param transformFull If doTransformation and transformFull are both set to true, the
+ * i2doc_affine transformation is applied, which includes the all the transformations of the
+ * ancestors and even the document viewport. If doTransformation is true but transformFull is false
+ * only the item's own transformation gets applied.
+ * @param extraPreAffine This is a Geom::Affine transformation that gets applied before any
+ * transformations from SPItem.
+ * @param extraPostAffine This is a Geom::Affine transformation that gets applied after any
+ * transformations from SPItem.
+ *
+ * @return A pointer to the Geom::PathVector. Must be freed by the caller.
+ */
+Geom::PathVector* pathvector_for_curve(SPItem *item, SPCurve *curve, bool doTransformation, bool transformFull, Geom::Affine extraPreAffine, Geom::Affine extraPostAffine);
+
+/**
+ * Gets an SPCurve from the SPItem.
+ *
+ * An SPCurve is basically a wrapper around a Geom::PathVector. This function extracts
+ * an SPCurve object from the SPItem. The behavior is a little ill-defined though. It
+ * returns the path before applying LPE stack if the item is an SPPath and the path
+ * after applying the LPE stack for all other types.
+ *
+ * For SPText, SPFlowtext and SPImage LPEs don't matter anyways (AFAIK). So, curve_for_item
+ * and curve_for_item_before_LPE behave identically. For SPShape objects, there is a difference.
+ * curve_for_item returns path before LPE only if it's SPPath and path after LPE otherwise.
+ * curve_for_item_before_LPE returns path before LPE all the time. See the inheritance diagram
+ * for these classes if this doesn't make sense.
+ *
+ * @param item Pointer to the SPItem object.
+ *
+ * @returns The extracted SPCurve
+ */
+std::optional<SPCurve> curve_for_item(SPItem *item);
+
+/**
+ * Gets an SPCurve from the SPItem before any LPE.
+ *
+ * An SPCurve is basically a wrapper around a Geom::PathVector. This function extracts
+ * an SPCurve object from the SPItem but it ensures that if LPEs are supported on that
+ * SPItem the path before the LPE is returned.
+ *
+ * For SPText, SPFlowtext and SPImage LPEs don't matter anyways (AFAIK). So, curve_for_item
+ * and curve_for_item_before_LPE behave identically. For SPShape objects, there is a difference.
+ * curve_for_item returns path before LPE only if it's SPPath and path after LPE otherwise.
+ * curve_for_item_before_LPE returns path before LPE all the time. See the inheritance diagram
+ * for these classes if this doesn't make sense.
+ *
+ * @param item Pointer to the SPItem object.
+ *
+ * @returns The extracted SPCurve
+ */
+std::optional<SPCurve> curve_for_item_before_LPE(SPItem *item);
+
+/**
+ * Get the nearest position given a Livarot Path and a point.
+ *
+ * I've not properly read the internals of the functions that get called for this function.
+ * However, if the name is correct, it seems the function returns the point in time and the
+ * piece where the path gets closest to the given point.
+ *
+ * TODO: Confirm this by checking the internals of the function that gets called.
+ *
+ * @param path A pointer to the Livarot Path object.
+ * @param p The point to which you wanna find the nearest point on the Path.
+ * @param seg If it is set to 0, all segments are considered. If set to any other number, only
+ * that segment will be considered.
+ *
+ * @return The point at time t.
+ */
+std::optional<Path::cut_position> get_nearest_position_on_Path(Path *path, Geom::Point p, unsigned seg = 0);
+
+/**
+ * Gets the point at a particular time in a particular piece in a path description.
+ *
+ * @param path Pointer to the Livarot Path object.
+ * @param piece The index of the path description. If this index is invalid, a point
+ * at the origin will be returned.
+ * @param t The time on the path description. Should be between 0 and 1.
+ *
+ * @return The cut position. This structure has both the piece index and the time for the nearest
+ * point. This cut position object is wrapped in boost::optional.
+ */
+Geom::Point get_point_on_Path(Path *path, int piece, double t);
+
+#endif // PATH_UTIL_H
+
+/*
+ Local Variables:
+ mode:c++
+ c-file-style:"stroustrup"
+ c-file-offsets:((innamespace . 0)(inline-open . 0)(case-label . +))
+ indent-tabs-mode:nil
+ fill-column:99
+ End:
+*/
+// vim: filetype=cpp:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:fileencoding=utf-8:textwidth=99 :