path: Add gsk_path_measure_is_closed ()

This commit is contained in:
Benjamin Otte
2020-12-17 05:00:10 +01:00
parent 8397d10c20
commit 828ccc51d9
3 changed files with 27 additions and 0 deletions

View File

@@ -386,6 +386,7 @@ gsk_path_measure_get_n_contours
gsk_path_measure_restrict_to_contour
<SUBSECTION>
gsk_path_measure_get_length
gsk_path_measure_is_closed
gsk_path_measure_get_point
gsk_path_measure_get_closest_point
gsk_path_measure_get_closest_point_full

View File

@@ -275,6 +275,30 @@ gsk_path_measure_get_length (GskPathMeasure *self)
return self->length;
}
/**
* gsk_path_measure_is_closed:
* @self: a #GskPathMeasure
*
* Returns if the path being measured represents a single closed
* contour.
*
* Returns: %TRUE if the current path is closed
**/
gboolean
gsk_path_measure_is_closed (GskPathMeasure *self)
{
const GskContour *contour;
g_return_val_if_fail (self != NULL, FALSE);
/* XXX: is the empty path closed? Currently it's not */
if (self->last - self->first != 1)
return FALSE;
contour = gsk_path_get_contour (self->path, self->first);
return gsk_contour_get_flags (contour) & GSK_PATH_CLOSED ? TRUE : FALSE;
}
static float
gsk_path_measure_clamp_distance (GskPathMeasure *self,
float distance)

View File

@@ -58,6 +58,8 @@ void gsk_path_measure_restrict_to_contour (GskPathMeasure
GDK_AVAILABLE_IN_ALL
float gsk_path_measure_get_length (GskPathMeasure *self);
GDK_AVAILABLE_IN_ALL
gboolean gsk_path_measure_is_closed (GskPathMeasure *self);
GDK_AVAILABLE_IN_ALL
void gsk_path_measure_get_point (GskPathMeasure *self,
float distance,
graphene_point_t *pos,