cv2.WINDOW_NORMAL
时间: 2023-07-24 14:41:20 浏览: 24
cv2.WINDOW_NORMAL 是 OpenCV 中窗口的一种显示模式。这种模式下,可以通过鼠标拖动窗口的边界改变窗口大小。相对应的,cv2.WINDOW_FULLSCREEN 是窗口的另一种显示模式,这种模式下窗口会最大化,全屏显示,并且不能通过鼠标改变窗口大小。
在使用 OpenCV 显示图像时,可以使用 cv2.namedWindow() 函数创建窗口并指定窗口的显示模式。例如:
``` python
import cv2
# 读取图像
img = cv2.imread('image.jpg')
# 创建窗口
cv2.namedWindow('image', cv2.WINDOW_NORMAL)
# 显示图像
cv2.imshow('image', img)
# 等待用户按下任意键
cv2.waitKey(0)
# 关闭窗口
cv2.destroyAllWindows()
```
在此示例中,使用 cv2.namedWindow() 函数创建了一个名为 'image' 的窗口,并将其显示模式设置为 cv2.WINDOW_NORMAL。然后使用 cv2.imshow() 函数显示图像,最后使用 cv2.destroyAllWindows() 函数关闭窗口。
相关问题
import cv2 import numpy as np # 读取两幅图像 img1 = cv2.imread('D:\wzk\JIEMIAN\images\er_duibidu.jpg') img2 = cv2.imread('D:\wzk\JIEMIAN\images\yi_duibidu.jpg') # 将两幅图像转换为灰度图像 gray1 = cv2.cvtColor(img1, cv2.COLOR_BGR2GRAY) gray2 = cv2.cvtColor(img2, cv2.COLOR_BGR2GRAY) # 提取图像特征点 orb = cv2.ORB_create() kp1, des1 = orb.detectAndCompute(gray1, None) kp2, des2 = orb.detectAndCompute(gray2, None) # 匹配特征点 matcher = cv2.DescriptorMatcher_create(cv2.DESCRIPTOR_MATCHER_BRUTEFORCE_HAMMING) matches = matcher.match(des1, des2) # 选择最佳匹配点 matches = sorted(matches, key=lambda x: x.distance) good_matches = matches[:int(len(matches)*0.15)] # 绘制特征点连接图 img3 = cv2.drawMatches(img1, kp1, img2, kp2, good_matches, None, flags=cv2.DrawMatchesFlags_NOT_DRAW_SINGLE_POINTS) # 计算变换矩阵 src_pts = np.float32([kp1[m.queryIdx].pt for m in good_matches]).reshape(-1, 1, 2) dst_pts = np.float32([kp2[m.trainIdx].pt for m in good_matches]).reshape(-1, 1, 2) M, mask = cv2.findHomography(src_pts, dst_pts, cv2.RANSAC, 5.0) # 拼接图像 result = cv2.warpPerspective(img1, M, (img1.shape[1] + img2.shape[1], img1.shape[0])) result[0:img2.shape[0], 0:img2.shape[1]] = img2 # 保存连接图 cv2.imwrite('D:\wzk\JIEMIAN\Result\ORB-pz.jpg', img3) # 保存第二幅图像 cv2.imwrite('D:\wzk\JIEMIAN\Result\ORB-pj.jpg', result) # 显示结果 cv2.namedWindow("Keypoint Matches", cv2.WINDOW_NORMAL) cv2.imshow("Keypoint Matches", img3) cv2.namedWindow("Result",cv2.WINDOW_NORMAL) cv2.imshow('Result', result) cv2.waitKey(0) cv2.destroyAllWindows()改进为对文件夹内的多幅图像进行配准拼接
可以使用循环遍历文件夹内的所有图像,对每幅图像进行配准拼接,最终将所有拼接结果合并成一张大图像。
以下是示例代码:
```
import cv2
import numpy as np
import os
# 定义文件夹路径和结果保存路径
folder_path = 'D:\wzk\JIEMIAN\images'
result_path = 'D:\wzk\JIEMIAN\Result\ORB-pj.jpg'
# 获取文件夹内所有图像路径
img_paths = [os.path.join(folder_path, f) for f in os.listdir(folder_path) if f.endswith('.jpg')]
# 遍历所有图像,进行配准拼接
result = cv2.imread(img_paths[0])
for i in range(1, len(img_paths)):
img = cv2.imread(img_paths[i])
# 将两幅图像转换为灰度图像
gray1 = cv2.cvtColor(result, cv2.COLOR_BGR2GRAY)
gray2 = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# 提取图像特征点
orb = cv2.ORB_create()
kp1, des1 = orb.detectAndCompute(gray1, None)
kp2, des2 = orb.detectAndCompute(gray2, None)
# 匹配特征点
matcher = cv2.DescriptorMatcher_create(cv2.DESCRIPTOR_MATCHER_BRUTEFORCE_HAMMING)
matches = matcher.match(des1, des2)
# 选择最佳匹配点
matches = sorted(matches, key=lambda x: x.distance)
good_matches = matches[:int(len(matches)*0.15)]
# 计算变换矩阵
src_pts = np.float32([kp1[m.queryIdx].pt for m in good_matches]).reshape(-1, 1, 2)
dst_pts = np.float32([kp2[m.trainIdx].pt for m in good_matches]).reshape(-1, 1, 2)
M, mask = cv2.findHomography(src_pts, dst_pts, cv2.RANSAC, 5.0)
# 拼接图像
result = cv2.warpPerspective(result, M, (result.shape[1] + img.shape[1], result.shape[0]))
result[0:img.shape[0], result.shape[1]-img.shape[1]:] = img
# 保存拼接结果
cv2.imwrite(result_path, result)
# 显示结果
cv2.namedWindow("Result",cv2.WINDOW_NORMAL)
cv2.imshow('Result', result)
cv2.waitKey(0)
cv2.destroyAllWindows()
```
代码中使用了 `os` 模块来遍历文件夹内所有图像的路径,然后对每幅图像进行配准拼接。最终将所有拼接结果合并成一张大图像,并保存到指定路径。
import cv2 # 创建一个窗口 名字叫做Window cv2.namedWindow('Window', flags=cv2.WINDOW_NORMAL | cv2.WINDOW_KEEPRATIO | cv2.WINDOW_GUI_EXPANDED) ''' #打开USB摄像头 cap = cv2.VideoCapture(0) ''' # 摄像头的IP地址,http://用户名:密码@IP地址:端口/ # ip_camera_url = 'rtsp://admin:admin@10.106.137.190:8554/live' ip_camera_url = 'rtsp://admin:abcd1234@192.168.1.19:8001/Streaming/Channels/101' # 创建一个VideoCapture cap = cv2.VideoCapture(0,cv2.CAP_DSHOW) print('IP摄像头是否开启: {}'.format(cap.isOpened())) # 显示缓存数 print(cap.get(cv2.CAP_PROP_BUFFERSIZE)) # 设置缓存区的大小 cap.set(cv2.CAP_PROP_BUFFERSIZE, 1) # 调节摄像头分辨率 cap.set(cv2.CAP_PROP_FRAME_WIDTH, 1920) cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 1080) print(cap.get(cv2.CAP_PROP_FRAME_WIDTH)) print(cap.get(cv2.CAP_PROP_FRAME_HEIGHT)) # 设置FPS print('setfps', cap.set(cv2.CAP_PROP_FPS, 25)) print(cap.get(cv2.CAP_PROP_FPS)) while (True): # 逐帧捕获 ret, frame = cap.read() # 第一个参数返回一个布尔值(True/False),代表有没有读取到图片;第二个参数表示截取到一帧的图片 # gray = cv2.cvtColor(frame, cv2.COLOR_BGR2GRAY) cv2.imshow('Window', frame) if cv2.waitKey(1) & 0xFF == ord('q'): break # 当一切结束后,释放VideoCapture对象 cap.release() cv2.destroyAllWindows()
import cv2 是一行Python代码,用于导入OpenCV库。OpenCV是一种开源计算机视觉库,它包含许多用于处理图像和视频的函数和工具。通过导入cv2库,我们可以在Python代码中使用OpenCV库提供的各种功能来处理图像和视频。
相关推荐













