如何解决在Mac上使用Python和OpenCV时,DestroyWindow不会关闭窗口
|| 我的程序使用以下代码生成一系列窗口:def display(img,name,fun):
global clicked
cv.NamedWindow(name,1)
cv.ShowImage(name,img)
cv.SetMouseCallback(name,fun,img)
while cv.WaitKey(33) == -1:
if clicked == 1:
clicked = 0
cv.ShowImage(name,img)
cv.DestroyWindow(name)
我在gui窗口中按\“ q \”将其关闭。但是,代码将继续显示函数的下一个调用,并显示第二个gui窗口,而不会关闭第一个。我正在使用带有OpenCV 2.1的Mac,并在Terminal中运行该程序。如何关闭GUI窗口?谢谢。
解决方法
OpenCV中的GUI有一些特殊之处。除非调用
waitKey
来调用事件,否则ѭ1调用将无法关闭窗口(至少在Linux下,默认后端为Gtk +直到2.1.0)。在ѭ4after之后添加waitKey(1)
通话可能会起作用。
即使这样,也不能保证关闭。只有在窗口具有焦点的情况下才会拦截ed2 intercept函数,因此,如果在您调用destroyWindow
时窗口没有焦点,则在下一次destroyWindow
调用之前,该窗口将一直保持可见状态。
我假设这是源自Gtk +的行为;在Windows下使用该功能时,没有遇到任何麻烦。
,打开窗口后,需要运行cv.startWindowThread()
。
我遇到了同样的问题,现在这对我有用。
希望这对将来的读者有所帮助。并且还有一个cv2
绑定(我建议使用它代替cv
)。
该代码对我有用:
import cv2 as cv
import time
WINDOW_NAME = \"win\"
image = cv.imread(\"ela.jpg\",cv.CV_LOAD_IMAGE_COLOR)
cv.namedWindow(WINDOW_NAME,cv.CV_WINDOW_AUTOSIZE)
initialtime = time.time()
cv.startWindowThread()
while (time.time() - initialtime < 5):
print \"in first while\"
cv.imshow(WINDOW_NAME,image)
cv.waitKey(1000)
cv.waitKey(1)
cv.destroyAllWindows()
cv.waitKey(1)
initialtime = time.time()
while (time.time() - initialtime < 6):
print \"in second while\"
在Linux上,C ++版本也会发生相同的问题:
尝试关闭OpenCV窗口无效
,Sayem2603
我尝试了您的解决方案,它对我有用-谢谢!我进行了一些反复试验,发现循环4次对我来说是个窍门...或将相同的代码发布4次相同。
此外,我深入到:
cv2.destroyAllWindows()
cv2.waitKey(1)
cv2.waitKey(1)
cv2.waitKey(1)
cv2.waitKey(1)
或简单地调用DestroyAllWindows,然后循环4次waitKey()代码:
cv2.destroyAllWindows()
for i in range (1,5):
cv2.waitKey(1)
也一样。尽管我认为这与循环执行该代码(?)所造成的中断和延迟有关,但我还不知道为什么会这样正确地工作
MatthäusBrandl在上面说过,第三个waitKey()为他工作了,所以在每个系统上它可能略有不同吗? (我正在运行带有3.16.1内核和python 2.7的Linux Mint)
延迟本身并不能说明问题,因为仅增加waitKey()上的延迟时间并不能解决问题。 (也使print(\“ Hello \”)循环了1000次,而不是使用wiatKey()只是为了查看所创建的延迟是否有所帮助-这样做没有效果。)必须与waitKey()如何与窗口事件进行交互有更多关系。
OpenCV Docs说:\“此函数是HighGUI中唯一可以获取和处理事件的方法,因此,除非在用于处理事件的环境中使用HighGUI,否则对于正常事件处理,需要定期调用此函数。”
也许它会在GUI显示中创建各种中断,以允许destroyAllWindows()操作进行处理?
Ĵ
,此解决方案对我有效(在Ubuntu 12.04中,在外壳中打开python):
窗口“销毁”后重新调用-14。
,这对我有用:
cv2.namedWindow(\"image\")
cv2.imshow(\'image\',img)
cv2.waitKey(0) # close window when a key press is detected
cv2.destroyWindow(\'image\')
cv2.waitKey(1)
,我通过在for循环中调用ѭ16来解决了这个问题,我不知道它为什么起作用,但完成了我的工作,所以我不再烦自己。
for i in range(1,10):
cv2.destroyAllWindows()
cv2.waitkey(1)
欢迎您解释。
,如果您使用的是Spyder(Anaconda包),则存在问题。
没有一种解决方案对我有用。
我发现问题不是功能,而是Spyder上的问题。尝试使用texteditor plus在终端上运行,您可以简单地使用以下命令:
WINDOW_NAME = \"win\"
image = cv.imread(\"foto.jpg\",0)
cv.namedWindow(WINDOW_NAME,cv.CV_WINDOW_AUTOSIZE)
cv.startWindowThread()
cv.imshow(WINDOW_NAME,image)
cv.waitKey()
cv.destroyAllWindows()
,在python控制台中摆弄这个问题,我观察到以下行为:
在cv2.destroyWindow
之后发出cv2.imshow
有时会关闭窗户。尽管下一个highgui
调用再次弹出旧窗口,例如ѭ22old
每次尝试时,.20ѭ之后的cv2.waitKey
第三次调用都会关闭窗口。此外,即使随后使用cv2.namedWindow
,关闭的窗口也保持关闭状态
希望这对某人有帮助。
(我将Ubuntu 12.10与python 2.7.3结合使用,但从13.04存储库中使用OpenCV 2.4.2)
,在搜索了一段时间后,没有提供的解决方案对我有用,因此,由于该功能存在错误,而且我没有时间修复它,因此不必使用cv2窗口来显示框架。保存了几帧后,您可以在其他查看器中打开文件,例如VLC或MoviePlayer(对于Linux)。
这是我的工作方式。
import cv2
threadDie = True # change this to false elsewhere to stop getting the video
def getVideo(Message):
print Message
print \"Opening url\"
video = cv2.VideoCapture(\"rtsp://username:passwordp@IpAddress:554/axis-media/media.amp\")
print \"Opened url\"
fourcc = cv2.cv.CV_FOURCC(\'X\',\'V\',\'I\',\'D\')
fps = 25.0 # or 30.0 for a better quality stream
writer = cv2.VideoWriter(\'out.avi\',fourcc,fps,(640,480),1)
i = 0
print \"Reading frames \"
while threadDie:
ret,img = video.read()
print \"frame number: \",i
i=i+1
writer.write(img)
del(video)
print \"Finished capturing video\"
然后使用其他查看器打开文件,可能会使用其他功能,例如,如果您喜欢vlc,则可以启动它并将保存的文件作为参数传递。在终端上,我会这样做
vlc out.avi #out.avi is my video file being saved by the function above.
这在Arch Linux上对我有用。
,如果在Jupyter Notebook上运行上述解决方案,这些解决方案似乎都不适合我(关闭时窗口会挂起,并且您需要强制退出Python才能关闭窗口)。
我使用的是macOS High Sierra 10.13.4,Python 3.6.5,OpenCV 3.4.1。
如果您将其作为.py文件运行,则以下代码有效(源:https://www.learnopencv.com/read-write-and-display-a-video-using-opencv-cpp-python/)。它会打开相机,录制视频,按“ q”成功关闭窗口,然后将视频保存为.avi格式。
import cv2
import numpy as np
# Create a VideoCapture object
cap = cv2.VideoCapture(0)
# Check if camera opened successfully
if (cap.isOpened() == False):
print(\"Unable to read camera feed\")
# Default resolutions of the frame are obtained.The default resolutions are system dependent.
# We convert the resolutions from float to integer.
frame_width = int(cap.get(3))
frame_height = int(cap.get(4))
# Define the codec and create VideoWriter object.The output is stored in \'outpy.avi\' file.
out = cv2.VideoWriter(\'outpy.avi\',cv2.VideoWriter_fourcc(\'M\',\'J\',\'P\',\'G\'),10,(frame_width,frame_height))
while(True):
ret,frame = cap.read()
if ret == True:
# Write the frame into the file \'output.avi\'
out.write(frame)
# Display the resulting frame
cv2.imshow(\'frame\',frame)
# Press Q on keyboard to stop recording
if cv2.waitKey(1) & 0xFF == ord(\'q\'):
break
# Break the loop
else:
break
# When everything done,release the video capture and video write objects
cap.release()
out.release()
# Closes all the frames
cv2.destroyAllWindows()
,这在spyder中对我有用:
import cv2 as cv
cv.namedWindow(\"image\")
img = cv.imread(\"image_name.jpg\")
cv.imshow(\"image\",img)
cv.waitKey(5000) # 5 sec delay before image window closes
cv.destroyWindow(\"image\")
切记仅使用cv.waitKey(positive Integer)
即可使用
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。