Skip to content

Commit

Permalink
Merge branch 'main' of github.com:zyddnys/manga-image-translator
Browse files Browse the repository at this point in the history
  • Loading branch information
zyddnys committed Jun 16, 2024
2 parents 256e79d + b6b684e commit 55d1c35
Showing 1 changed file with 39 additions and 16 deletions.
55 changes: 39 additions & 16 deletions manga_translator/utils/generic.py
Original file line number Diff line number Diff line change
Expand Up @@ -345,17 +345,50 @@ def to_points(self):
@property
def xywh(self):
return np.array([self.x, self.y, self.w, self.h], dtype=np.int32)


def sort_pnts(pts: np.ndarray):
'''
Direction must be provided for sorting.
The longer structure vector (mean of long side vectors) of input points is used to determine the direction.
It is reliable enough for text lines but not for blocks.
'''

if isinstance(pts, List):
pts = np.array(pts)
assert isinstance(pts, np.ndarray) and pts.shape == (4, 2)
pairwise_vec = (pts[:, None] - pts[None]).reshape((16, -1))
pairwise_vec_norm = np.linalg.norm(pairwise_vec, axis=1)
long_side_ids = np.argsort(pairwise_vec_norm)[[8, 10]]
long_side_vecs = pairwise_vec[long_side_ids]
inner_prod = (long_side_vecs[0] * long_side_vecs[1]).sum()
if inner_prod < 0:
long_side_vecs[0] = -long_side_vecs[0]
struc_vec = np.abs(long_side_vecs.mean(axis=0))
is_vertical = struc_vec[0] <= struc_vec[1]

if is_vertical:
pts = pts[np.argsort(pts[:, 1])]
pts = pts[[*np.argsort(pts[:2, 0]), *np.argsort(pts[2:, 0])[::-1] + 2]]
return pts, is_vertical
else:
pts = pts[np.argsort(pts[:, 0])]
pts_sorted = np.zeros_like(pts)
pts_sorted[[0, 3]] = sorted(pts[[0, 1]], key=lambda x: x[1])
pts_sorted[[1, 2]] = sorted(pts[[2, 3]], key=lambda x: x[1])
return pts_sorted, is_vertical


class Quadrilateral(object):
"""
Helper for storing textlines that contains various helper functions.
"""
def __init__(self, pts: np.ndarray, text: str, prob: float, fg_r: int = 0, fg_g: int = 0, fg_b: int = 0, bg_r: int = 0, bg_g: int = 0, bg_b: int = 0):
self.pts = pts
# Sort coordinates to start at the top left and go clockwise
self.pts = self.pts[np.argsort(self.pts[:,1])]
self.pts = self.pts[[*np.argsort(self.pts[:2,0]), *np.argsort(self.pts[2:,0])[::-1] + 2]]

def __init__(self, pts: np.ndarray, text: str, prob: float, fg_r: int = 0, fg_g: int = 0, fg_b: int = 0, bg_r: int = 0, bg_g: int = 0, bg_b: int = 0):
self.pts, is_vertical = sort_pnts(pts)
if is_vertical:
self.direction = 'v'
else:
self.direction = 'h'
self.text = text
self.prob = prob
self.fg_r = fg_r
Expand Down Expand Up @@ -484,16 +517,6 @@ def is_approximate_axis_aligned(self) -> bool:
return True
return False

@functools.cached_property
def direction(self) -> str:
[l1a, l1b, l2a, l2b] = [a.astype(np.float32) for a in self.structure]
v_vec = l1b - l1a
h_vec = l2b - l2a
if np.linalg.norm(v_vec) > np.linalg.norm(h_vec):
return 'v'
else:
return 'h'

@functools.cached_property
def cosangle(self) -> float:
[l1a, l1b, l2a, l2b] = [a.astype(np.float32) for a in self.structure]
Expand Down

0 comments on commit 55d1c35

Please sign in to comment.