在Mac上使用Python和OpenCV时,DestroyWindow不会关闭窗口

如何解决在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 举报,一经查实,本站将立刻删除。

相关推荐


依赖报错 idea导入项目后依赖报错,解决方案:https://blog.csdn.net/weixin_42420249/article/details/81191861 依赖版本报错:更换其他版本 无法下载依赖可参考:https://blog.csdn.net/weixin_42628809/a
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下 2021-12-03 13:33:33.927 ERROR 7228 [ main] o.s.b.d.LoggingFailureAnalysisReporter : *************************** APPL
错误1:gradle项目控制台输出为乱码 # 解决方案:https://blog.csdn.net/weixin_43501566/article/details/112482302 # 在gradle-wrapper.properties 添加以下内容 org.gradle.jvmargs=-Df
错误还原:在查询的过程中,传入的workType为0时,该条件不起作用 &lt;select id=&quot;xxx&quot;&gt; SELECT di.id, di.name, di.work_type, di.updated... &lt;where&gt; &lt;if test=&qu
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct redisServer’没有名为‘server_cpulist’的成员 redisSetCpuAffinity(server.server_cpulist); ^ server.c: 在函数‘hasActiveC
解决方案1 1、改项目中.idea/workspace.xml配置文件,增加dynamic.classpath参数 2、搜索PropertiesComponent,添加如下 &lt;property name=&quot;dynamic.classpath&quot; value=&quot;tru
删除根组件app.vue中的默认代码后报错:Module Error (from ./node_modules/eslint-loader/index.js): 解决方案:关闭ESlint代码检测,在项目根目录创建vue.config.js,在文件中添加 module.exports = { lin
查看spark默认的python版本 [root@master day27]# pyspark /home/software/spark-2.3.4-bin-hadoop2.7/conf/spark-env.sh: line 2: /usr/local/hadoop/bin/hadoop: No s
使用本地python环境可以成功执行 import pandas as pd import matplotlib.pyplot as plt # 设置字体 plt.rcParams[&#39;font.sans-serif&#39;] = [&#39;SimHei&#39;] # 能正确显示负号 p
错误1:Request method ‘DELETE‘ not supported 错误还原:controller层有一个接口,访问该接口时报错:Request method ‘DELETE‘ not supported 错误原因:没有接收到前端传入的参数,修改为如下 参考 错误2:cannot r
错误1:启动docker镜像时报错:Error response from daemon: driver failed programming external connectivity on endpoint quirky_allen 解决方法:重启docker -&gt; systemctl r
错误1:private field ‘xxx‘ is never assigned 按Altʾnter快捷键,选择第2项 参考:https://blog.csdn.net/shi_hong_fei_hei/article/details/88814070 错误2:启动时报错,不能找到主启动类 #
报错如下,通过源不能下载,最后警告pip需升级版本 Requirement already satisfied: pip in c:\users\ychen\appdata\local\programs\python\python310\lib\site-packages (22.0.4) Coll
错误1:maven打包报错 错误还原:使用maven打包项目时报错如下 [ERROR] Failed to execute goal org.apache.maven.plugins:maven-resources-plugin:3.2.0:resources (default-resources)
错误1:服务调用时报错 服务消费者模块assess通过openFeign调用服务提供者模块hires 如下为服务提供者模块hires的控制层接口 @RestController @RequestMapping(&quot;/hires&quot;) public class FeignControl
错误1:运行项目后报如下错误 解决方案 报错2:Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.1:compile (default-compile) on project sb 解决方案:在pom.
参考 错误原因 过滤器或拦截器在生效时,redisTemplate还没有注入 解决方案:在注入容器时就生效 @Component //项目运行时就注入Spring容器 public class RedisBean { @Resource private RedisTemplate&lt;String
使用vite构建项目报错 C:\Users\ychen\work&gt;npm init @vitejs/app @vitejs/create-app is deprecated, use npm init vite instead C:\Users\ychen\AppData\Local\npm-