2012-08-27 14:11:33 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2012 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
2012-03-27 13:23:51 +00:00
|
|
|
#ifndef CurveIntersection_DEFINE
|
|
|
|
#define CurveIntersection_DEFINE
|
|
|
|
|
2012-02-03 22:07:47 +00:00
|
|
|
#include "DataTypes.h"
|
|
|
|
|
|
|
|
class Intersections;
|
|
|
|
|
|
|
|
// unit-testable utilities
|
2012-04-26 21:01:06 +00:00
|
|
|
double axialIntersect(const Quadratic& q1, const _Point& p, bool vert);
|
2012-02-03 22:07:47 +00:00
|
|
|
bool bezier_clip(const Cubic& cubic1, const Cubic& cubic2, double& minT, double& maxT);
|
|
|
|
bool bezier_clip(const Quadratic& q1, const Quadratic& q2, double& minT, double& maxT);
|
|
|
|
int convex_hull(const Cubic& cubic, char order[4]);
|
|
|
|
bool convex_x_hull(const Cubic& cubic, char connectTo0[2], char connectTo3[2]);
|
|
|
|
bool implicit_matches(const Cubic& cubic1, const Cubic& cubic2);
|
|
|
|
bool implicit_matches(const _Line& line1, const _Line& line2);
|
2012-04-17 11:40:34 +00:00
|
|
|
bool implicit_matches_ulps(const _Line& one, const _Line& two, int ulps);
|
2012-02-03 22:07:47 +00:00
|
|
|
bool implicit_matches(const Quadratic& quad1, const Quadratic& quad2);
|
|
|
|
void tangent(const Cubic& cubic, double t, _Point& result);
|
|
|
|
void tangent(const _Line& line, _Point& result);
|
|
|
|
void tangent(const Quadratic& quad, double t, _Point& result);
|
|
|
|
|
|
|
|
// main functions
|
|
|
|
enum ReduceOrder_Flags {
|
|
|
|
kReduceOrder_NoQuadraticsAllowed,
|
|
|
|
kReduceOrder_QuadraticsAllowed
|
|
|
|
};
|
|
|
|
int reduceOrder(const Cubic& cubic, Cubic& reduction, ReduceOrder_Flags );
|
|
|
|
int reduceOrder(const _Line& line, _Line& reduction);
|
|
|
|
int reduceOrder(const Quadratic& quad, Quadratic& reduction);
|
|
|
|
int horizontalIntersect(const Cubic& cubic, double y, double tRange[3]);
|
2012-03-30 18:47:02 +00:00
|
|
|
int horizontalIntersect(const Cubic& cubic, double left, double right, double y,
|
|
|
|
double tRange[3]);
|
2012-04-26 21:01:06 +00:00
|
|
|
int horizontalIntersect(const Cubic& cubic, double left, double right, double y,
|
|
|
|
bool flipped, Intersections&);
|
|
|
|
int horizontalIntersect(const _Line& line, double left, double right,
|
|
|
|
double y, bool flipped, Intersections& );
|
2012-03-30 18:47:02 +00:00
|
|
|
int horizontalIntersect(const Quadratic& quad, double left, double right,
|
|
|
|
double y, double tRange[2]);
|
2012-04-26 21:01:06 +00:00
|
|
|
int horizontalIntersect(const Quadratic& quad, double left, double right,
|
|
|
|
double y, bool flipped, Intersections& );
|
2012-02-03 22:07:47 +00:00
|
|
|
bool intersect(const Cubic& cubic1, const Cubic& cubic2, Intersections& );
|
2013-01-17 21:02:47 +00:00
|
|
|
// the following flavor uses quadratic approximation instead of convex hulls
|
|
|
|
bool intersect2(const Cubic& cubic1, const Cubic& cubic2, Intersections& );
|
|
|
|
bool intersect(const Cubic& cubic, Intersections& i); // return true if cubic self-intersects
|
|
|
|
int intersect(const Cubic& cubic, const Quadratic& quad, Intersections& );
|
|
|
|
int intersect(const Cubic& cubic, const _Line& line, Intersections& );
|
2013-02-04 14:06:49 +00:00
|
|
|
int intersectRay(const Cubic& quad, const _Line& line, Intersections& i);
|
2012-02-03 22:07:47 +00:00
|
|
|
bool intersect(const Quadratic& q1, const Quadratic& q2, Intersections& );
|
2012-08-24 15:24:36 +00:00
|
|
|
int intersect(const Quadratic& quad, const _Line& line, Intersections& );
|
2012-09-14 14:19:30 +00:00
|
|
|
// the following flavor uses the implicit form instead of convex hulls
|
|
|
|
bool intersect2(const Quadratic& q1, const Quadratic& q2, Intersections& i);
|
|
|
|
int intersectRay(const Quadratic& quad, const _Line& line, Intersections& i);
|
|
|
|
|
|
|
|
|
2012-05-07 20:49:36 +00:00
|
|
|
bool isLinear(const Quadratic& quad, int startIndex, int endIndex);
|
|
|
|
bool isLinear(const Cubic& cubic, int startIndex, int endIndex);
|
2012-04-26 21:01:06 +00:00
|
|
|
double leftMostT(const Cubic& , double startT, double endT);
|
|
|
|
double leftMostT(const _Line& , double startT, double endT);
|
|
|
|
double leftMostT(const Quadratic& , double startT, double endT);
|
|
|
|
int verticalIntersect(const Cubic& cubic, double top, double bottom, double x,
|
|
|
|
bool flipped, Intersections& );
|
|
|
|
int verticalIntersect(const _Line& line, double top, double bottom, double x,
|
|
|
|
bool flipped, Intersections& );
|
|
|
|
int verticalIntersect(const Quadratic& quad, double top, double bottom,
|
|
|
|
double x, bool flipped, Intersections& );
|
2012-03-27 13:23:51 +00:00
|
|
|
|
|
|
|
#endif
|