cv2.resize
传的大小是宽高不是高宽, 是[width, height]
, 不是[height, width]
图像坐标和python numpy矩阵
opencv关于图像坐标和numpy 数组关于同样位置坐标问题。在opencv中,图片以左上角为起点,向右是x坐标,向下是y坐标,而在numpy中,向右是列,向下是行,在图片中的坐标(x,y)
,在numpy中则是(y,x)
,因此在对坐标操作的时候需要考虑到这一点。
BGR to RGB
Python 通过cv2.imread
读取的图像是BGR通道的,一般其它程序使用都是RGB通道,因此读完之后需要进行通道转换, 建议使用b,g,r = cv2.split(img) img = cv2.merge([r,g,b])
这种方法来进行通道转换. 使用img = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
,程序是建议先进行img /= 255.
操作,使得img
变成0~1
范围.所以建议还是直接使用第一种方法, 简单快捷明确又不会对原图造成其它影响.
读取视频流时从某一帧开始读
video_capture = cv2.VideoCapture(video_path)
fps = video_capture.get(cv2.CAP_PROP_FPS)
video_capture.set(cv2.CAP_PROP_POS_FRAMES, fps*(start_frame_idx))
图片上画点, 画线, 写文字
cv::line(img, single_point_1, single_point_2, (30, 144, 255), 2)
cv2.circle(img, (x,y), 2, (0, 255, 0), -1)
cv2.putText(img, str(i), (x,y), cv2.FONT_HERSHEY_COMPLEX, 1, (0, 0, 255), 1)
cv2.rectangle(img, (bbox[0], bbox[1]), (bbox[2], bbox[3]), (255, 0, 0))