yuandong513
feat: init
17cd746
import cv2
import numpy as np
import numbers
def plot_points(vis, points, radius=1, color=(255, 255, 0), shift=4, indexes=0, is_index=False):
if isinstance(points, list):
num_point = len(points)
elif isinstance(points, np.numarray):
num_point = points.shape[0]
else:
raise NotImplementedError
if isinstance(radius, numbers.Number):
radius = np.zeros((num_point)) + radius
if isinstance(indexes, numbers.Number):
indexes = [indexes + i for i in range(num_point)]
elif isinstance(indexes, list):
pass
else:
raise NotImplementedError
factor = (1 << shift)
for (index, p, s) in zip(indexes, points, radius):
cv2.circle(vis, (int(p[0] * factor + 0.5), int(p[1] * factor + 0.5)),
int(s * factor), color, 1, cv2.LINE_AA, shift=shift)
if is_index:
vis = cv2.putText(vis, str(index), (int(p[0]), int(p[1])), cv2.FONT_HERSHEY_SIMPLEX, 0.2,
(255, 255, 255), 1)
return vis