import cv2 import numpy as np file=r"C:/Users/58219/Desktop/1.jpg" # step1:读取照⽚ img = cv2.imread(file) # step1.2:缩放图⽚() img = cv2.resize(img, None, fx=1.5, fy=1.5) rows, cols, channels = img.shape # 展⽰图⽚ cv2.imshow("original...", img) # step2.1 图⽚转换为灰度图并显⽰ hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV) # :图⽚的⼆值化处理 # 红底变蓝底 # 将在两个阈值内的像素值设置为⽩⾊(255), #⽽不在阈值区间内的像素值设置为⿊⾊(0) # lower_red= np.array([0,125,125]) upper_red = np.array([255,255,255]) mask = cv2.inRange(hsv, lower_red, upper_red) #step2.3:腐蚀膨胀若是腐蚀膨胀后仍有⽩⾊噪点,可以增加iterations的值 erode = cv2.erode(mask, None, iterations=5) # cv2.imshow('erode', erode) dilate = cv2.dilate(erode, None, iterations=7) # step3遍历每个像素点,进⾏颜⾊的替换 ''' #若是想要将红底变成蓝底img[i,j]=(255,0,0), #若是想将蓝底变为红底则img[i,j]=(0,0,255), #若是想变⽩底img[i,j]=(255,255,255) ''' for i in range(rows): for j in range(cols): if dilate[i,j] ==255: # 像素点255表⽰⽩⾊,180为灰度 img[i,j]=(255,255,255) # 此处替换颜⾊,为BGR通道,不是RGB通道 #step4 显⽰图像 new_file=r"C:/Users/58219/Desktop/11.jpg" cv2.imwrite(new_file, img) res = cv2.imread(new_file) cv2.imshow('result...', res) # 窗⼝等待的命令,0表⽰⽆限等待 cv2.waitKey(0)