blob: b6c3a222ad48698e4042bc4b226a193e6ac3cf52 [file] [log] [blame]
/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkOffsetPolygon_DEFINED
#define SkOffsetPolygon_DEFINED
#include <functional>
#include "SkTDArray.h"
#include "SkPoint.h"
/**
* Generates a polygon that is inset a given distance from the boundary of a given convex polygon.
*
* @param inputPolygonVerts Array of points representing the vertices of the original polygon.
* It should be convex and have no coincident points.
* @param inputPolygonSize Number of vertices in the original polygon.
* @param insetDistanceFunc How far we wish to inset the polygon for a given index in the array.
* This should return a positive value.
* @param insetPolygon The resulting inset polygon, if any.
* @return true if an inset polygon exists, false otherwise.
*/
bool SkInsetConvexPolygon(const SkPoint* inputPolygonVerts, int inputPolygonSize,
std::function<SkScalar(int index)> insetDistanceFunc,
SkTDArray<SkPoint>* insetPolygon);
inline bool SkInsetConvexPolygon(const SkPoint* inputPolygonVerts, int inputPolygonSize,
SkScalar inset, SkTDArray<SkPoint>* insetPolygon) {
return SkInsetConvexPolygon(inputPolygonVerts, inputPolygonSize,
[inset](int) { return inset; },
insetPolygon);
}
/**
* Generates a simple polygon (if possible) that is offset a given distance from the boundary of a
* given simple polygon.
*
* @param inputPolygonVerts Array of points representing the vertices of the original polygon.
* @param inputPolygonSize Number of vertices in the original polygon.
* @param offset How far we wish to offset the polygon.
* Positive value means inset, negative value means outset.
* @param offsetPolgon The resulting offset polygon, if any.
* @param polygonIndices The indices of the original polygon that map to the new one.
* @return true if an offset simple polygon exists, false otherwise.
*/
bool SkOffsetSimplePolygon(const SkPoint* inputPolygonVerts, int inputPolygonSize,
SkScalar offset, SkTDArray<SkPoint>* offsetPolygon,
SkTDArray<int>* polygonIndices = nullptr);
/**
* Offset a segment by the given distance at each point.
* Uses the outer tangents of two circles centered on each endpoint.
* See: https://en.wikipedia.org/wiki/Tangent_lines_to_circles
*
* @param p0 First endpoint.
* @param p1 Second endpoint.
* @param d0 Offset distance from first endpoint.
* @param d1 Offset distance from second endpoint.
* @param side Indicates whether we want to offset to the left (1) or right (-1) side of segment.
* @param offset0 First endpoint of offset segment.
* @param offset1 Second endpoint of offset segment.
* @return true if an offset segment exists, false otherwise.
*/
bool SkOffsetSegment(const SkPoint& p0, const SkPoint& p1, SkScalar d0, SkScalar d1,
int side, SkPoint* offset0, SkPoint* offset1);
#endif