Initialization. Does not take ownership of "polyline".
An edge, consisting of two vertices "v0" and "v1". Zero-length edges are allowed, and can be used to represent points.
A range of edge ids corresponding to a chain of zero or more connected edges, specified as a (start, length) pair. The chain is defined to consist of edge ids {start, start + 1, ..., start + length - 1}.
The position of an edge within a given edge chain, specified as a (chain_id, offset) pair. Chains are numbered sequentially starting from zero, and offsets are measured from the start of each chain.
A ReferencePoint consists of a point P and a boolean indicating whether P is contained by a particular shape.
Returns the number of edges in this shape. Edges have ids ranging from 0 to num_edges() - 1.
Returns the endpoints of the given edge id.
Returns the dimension of the geometry represented by this shape.
Convenience function that returns true if this shape has an interior.
Returns an arbitrary point P along with a boolean indicating whether P is contained by the shape. (The boolean value must be false for shapes that do not have an interior.)
Returns the number of contiguous edge chains in the shape. For example, a shape whose edges are [AB, BC, CD, AE, EF] would consist of two chains (AB,BC,CD and AE,EF). Every chain is assigned a "chain id" numbered sequentially starting from zero.
Returns the range of edge ids corresponding to the given edge chain. The edge chains must form contiguous, non-overlapping ranges that cover the entire range of edge ids. This is spelled out more formally below:
Returns the edge at offset "offset" within edge chain "chain_id". Equivalent to "shape.edge(shape.chain(chain_id).start + offset)" but may be more efficient.
Finds the chain containing the given edge, and returns the position of that edge as a (chain_id, offset) pair.
A unique id assigned to this shape by S2ShapeIndex. Shape ids are assigned sequentially starting from 0 in the order shapes are added.
Virtual methods that return pointers of your choice.
Assigned by MutableS2ShapeIndex when the shape is added.
Wrapper class for indexing a polyline (see S2ShapeIndex). Once this object is inserted into an S2ShapeIndex it is owned by that index, and will be automatically deleted when no longer needed by the index. Note that this class does not take ownership of the polyline itself (see OwningShape below). You can also subtype this class to store additional data (see S2Shape for details).