gpt4 book ai didi

python - 如何优化从 PyCBitmap 到 OpenCV 图像的转换

转载 作者:太空宇宙 更新时间:2023-11-03 15:45:40 27 4
gpt4 key购买 nike

我有这段代码,它可以工作......但它运行得很慢:

hwin = win32gui.GetDesktopWindow()
width = win32api.GetSystemMetrics(win32con.SM_CXVIRTUALSCREEN)
height = win32api.GetSystemMetrics(win32con.SM_CYVIRTUALSCREEN)
left = win32api.GetSystemMetrics(win32con.SM_XVIRTUALSCREEN)
top = win32api.GetSystemMetrics(win32con.SM_YVIRTUALSCREEN)
hwindc = win32gui.GetWindowDC(hwin)
srcdc = win32ui.CreateDCFromHandle(hwindc)
memdc = srcdc.CreateCompatibleDC()
bmp = win32ui.CreateBitmap()
bmp.CreateCompatibleBitmap(srcdc, width, height)
memdc.SelectObject(bmp)
memdc.BitBlt((0, 0), (width, height), srcdc, (left, top), win32con.SRCCOPY)

signedIntsArray = bmp.GetBitmapBits(False)
img = np.array(signedIntsArray).astype(dtype="uint8") # This is REALLY slow!
img.shape = (height,width,4)

srcdc.DeleteDC()
memdc.DeleteDC()
win32gui.ReleaseDC(hwin, hwindc)
win32gui.DeleteObject(bmp.GetHandle())

return cv2.cvtColor(img, cv2.COLOR_RGBA2RGB)

这段代码抓取整个 Windows 桌面(两个显示器)并将其转换为我稍后使用的 OpenCV 图像。我相信如果稍微修改一下的话,这个转换的运行速度会比原来慢。具体来说, np.array(signedIntsArray) 调用非常慢!

关于如何更快地将桌面捕获转换为 OpenCV 图像有什么想法吗?

最佳答案

第一次使用Python。我想我现在对数据结构有了更好的理解。以下是可以极大提高性能的修复:

更改:

signedIntsArray = bmp.GetBitmapBits(False)
img = np.array(signedIntsArray).astype(dtype="uint8")

至:

signedIntsArray = bmp.GetBitmapBits(True)
img = np.fromstring(signedIntsArray, dtype='uint8')

并且速度大大提高!

这是因为 np 库从字符串创建数组比从元组创建数组要快得多。

关于python - 如何优化从 PyCBitmap 到 OpenCV 图像的转换,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41785831/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com