/// <summary> /// /// </summary> /// <param name="cubicBezier"></param> /// <param name="v"></param> /// <param name="threshold"></param> /// <param name="dx"></param> /// <param name="dy"></param> /// <returns></returns> public static BaseShape HitTestCubicBezier(XCubicBezier cubicBezier, Vector2 v, double threshold, double dx, double dy) { if (RectangleBounds.GetPointBounds(cubicBezier.Point1, threshold, dx, dy).Contains(v)) { return(cubicBezier.Point1); } if (RectangleBounds.GetPointBounds(cubicBezier.Point2, threshold, dx, dy).Contains(v)) { return(cubicBezier.Point2); } if (RectangleBounds.GetPointBounds(cubicBezier.Point3, threshold, dx, dy).Contains(v)) { return(cubicBezier.Point3); } if (RectangleBounds.GetPointBounds(cubicBezier.Point4, threshold, dx, dy).Contains(v)) { return(cubicBezier.Point4); } if (ConvexHullBounds.Contains(cubicBezier.GetPoints().ToImmutableArray(), v, dx, dy)) { return(cubicBezier); } return(null); }
/// <summary> /// /// </summary> /// <param name="path"></param> /// <param name="v"></param> /// <param name="threshold"></param> /// <param name="dx"></param> /// <param name="dy"></param> /// <returns></returns> public static BaseShape HitTestPath(XPath path, Vector2 v, double threshold, double dx, double dy) { if (path.Geometry != null) { var points = path.GetPoints().ToImmutableArray(); foreach (var point in points) { if (RectangleBounds.GetPointBounds(point, threshold, dx, dy).Contains(v)) { return(point); } } if (ConvexHullBounds.Contains(points, v, dx, dy)) { return(path); } } return(null); }