# coding=utf-8 # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation; either version 2 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. # # pylint: disable=invalid-name,missing-docstring """Deprecated ffgeom API""" from collections import namedtuple from inkex.deprecated import deprecate from inkex.transforms import DirectedLineSegment as NewSeg try: NaN = float('NaN') except ValueError: PosInf = 1e300000 NaN = PosInf/PosInf class Point(namedtuple('Point', 'x y')): __slots__ = () def __getitem__(self, key): if isinstance(key, str): key = 'xy'.index(key) return super(Point, self).__getitem__(key) class Segment(NewSeg): @deprecate def __init__(self, e0, e1): """inkex.transforms.Segment(((x1, y1), (x2, y2)))""" if isinstance(e0, dict): e0 = (e0['x'], e0['y']) if isinstance(e1, dict): e1 = (e1['x'], e1['y']) super(Segment, self).__init__((e0, e1)) def __getitem__(self, key): if key: return {'x': self.x.maximum, 'y': self.y.maximum} return {'x': self.x.minimum, 'y': self.y.minimum} delta_x = lambda self: self.width delta_y = lambda self: self.height run = delta_x rise = delta_y def distanceToPoint(self, p): return self.distance_to_point(p['x'], p['y']) def perpDistanceToPoint(self, p): return self.perp_distance(p['x'], p['y']) def angle(self): return super(Segment, self).angle def length(self): return super(Segment, self).length def pointAtLength(self, length): return self.point_at_length(length) def pointAtRatio(self, ratio): return self.point_at_ratio(ratio) def createParallel(self, p): self.parallel(p['x'], p['y']) @deprecate def intersectSegments(s1, s2): """transforms.Segment(s1).intersect(s2)""" return Point(*s1.intersect(s2)) @deprecate def dot(s1, s2): """transforms.Segment(s1).dot(s2)""" return s1.dot(s2)