-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathLineMatcher.py
27 lines (22 loc) · 931 Bytes
/
LineMatcher.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
import numpy as np
class LineMatcher():
def __init__(self, _yTolerance, _xTolerance=None):
self.currentCoords = (-1, -1, -1, -1)
self.yTolerance = _yTolerance
self.xTolerance = _xTolerance
def compare(self, lineCoords):
different = np.abs(
lineCoords[1] - self.currentCoords[1]) > self.yTolerance or np.abs(
lineCoords[3] - self.currentCoords[3]) > self.yTolerance
if not different and self.xTolerance is not None:
different = different and (
np.abs(lineCoords[0] - self.currentCoords[0]) > self.xTolerance
or np.abs(lineCoords[2] - self.currentCoords[2]) >
self.xTolerance)
if different:
self.setCurrentCoords(lineCoords)
return True
else:
return False
def setCurrentCoords(self, _newCoords):
self.currentCoords = _newCoords