- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是 Python 和 OpenCV 的新手,所以如果我说/问的任何事情听起来不明智或不知情,我深表歉意。我们在我的数字图像处理类(class)中以一种非常具体的方式学到了东西,所以虽然我下面的代码有效,但我想大大提高它的速度,但主要是它的 UI。该代码的主要目的是创建绿屏图像的二进制 mask ,然后将其应用于图像以将前景与背景分开。至于功能:
keyer 根据所需的 mask 类型(colorDifference 或 chromaKey)创建输入图像的阈值 mask 。
thresholdAdjust 允许用户通过 Open CV UI 操纵阈值 slider 。它还会实时更新图像(当按下 Enter 键时)以反射(reflect)原始 mask 如何根据所选阈值发生变化。由于我对这些功能完全陌生,所以我看到的所有示例都使用了类似 tracker 的功能。不过我不确定是否有必要。
最后,keyMultiplier 将在 thresholdAdjust 中生成的 mask 应用于输入图像并显示分离的前景。
(没有必要通读所有的 keyer 代码,因为它可以正常工作,但速度有点慢。我把所有代码都包括在内以防万一。)
import numpy as np
import cv2
def keyer(image, matteType, threshold1, threshold2, maxCount=255):
numberRows = image.shape[0]
numberColumns = image.shape[1]
if image.ndim > 2:
numberBands = image.shape[2]
else:
numberBands == 1
if numberBands != 3:
raise RuntimeError('Input image must be an RGB image.')
dataType = image.dtype
matte = np.zeros((numberRows, numberColumns, 1))
imageNorm = image / float(maxCount)
if matteType == 'colorDifference':
blue, green, red = cv2.split(imageNorm)
for row in range(numberRows):
for column in range(numberColumns):
pixel = green[row, column] - max(red[row, column], blue[row, column])
matte[row, column] = pixel
elif matteType == 'chromaKey':
imageYCbCr = cv2.cvtColor(image, cv2.COLOR_BGR2YCrCb)
imageYCbCrNorm = imageYCbCr / float(maxCount)
Y, Cr, Cb = cv2.split(imageYCbCrNorm)
CbScreen = Cb[0, 0]
CrScreen = Cr[0, 0]
for row in range(numberRows):
for column in range(numberColumns):
pixel = float(np.sqrt(((CbScreen - Cb[row, column])**2) + \
((CrScreen - Cr[row, column])**2)))
matte[row, column] = pixel
else:
raise RuntimeError('Please enter a valid "matteType".')
matte = np.clip(matte, 0.0, 1.0)
if matteType == 'colorDifference':
matte = 1.0 - matte
for row in range(numberRows):
for column in range(numberColumns):
if matte[row, column] < threshold1:
matte[row, column] = 0
elif matte[row, column] > threshold2:
matte[row, column] = 1
else:
matte[row, column] = ((matte[row, column] - threshold1) / \
(threshold2 - threshold1))
return (matte * float(maxCount)).astype(dataType)
def tracker(*arg):
pass
def thresholdAdjust(image, matteType, maxCount):
numberRows = image.shape[0]
numberColumns = image.shape[1]
if matteType == 'colorDifference':
matteName = '(Color Difference)'
else:
matteName = '(Chroma Key)'
windowName = 'Adjust Matte Parameters ' + matteName
threshold1TrackbarName = 'Clip Black'
threshold2TrackbarName = 'Clip White'
cv2.namedWindow(windowName)
cv2.createTrackbar(threshold1TrackbarName, windowName, 0, maxCount, tracker)
cv2.createTrackbar(threshold2TrackbarName, windowName, 0, maxCount, tracker)
cv2.setTrackbarPos(threshold2TrackbarName, windowName, maxCount)
while True:
threshold1 = (cv2.getTrackbarPos(threshold1TrackbarName, windowName) / \
float(maxCount))
threshold2 = (cv2.getTrackbarPos(threshold2TrackbarName, windowName) / \
float(maxCount))
window = keyer(image, matteType, threshold1, threshold2, maxCount)
cv2.imshow(windowName, window)
k = cv2.waitKey(0)
if k == 27:
break
cv2.destroyAllWindows()
return threshold1, threshold2
def keyMultiplier(image, matteType, maxCount):
dataType = image.dtype
threshold1, threshold2 = thresholdAdjust(image, matteType, maxCount)
matte = keyer(image, matteType, threshold1, threshold2, maxCount)
return ((cv2.GaussianBlur((matte / float(maxCount)), (3, 3), 0)[..., np.newaxis]) * \
image).astype(dataType)
if __name__ == '__main__':
import cv2
filename = 'C:/Users/Matt/Documents/circle_test.tif'
image = cv2.imread(filename)
difference = keyMultiplier(image, matteType='colorDifference', maxCount=255) # 163, 215
chroma = keyMultiplier(image, matteType='chromaKey', maxCount=255) # 25, 50
cv2.imshow('Original Image', image)
cv2.imshow('Color Difference', difference)
cv2.imshow('Chroma Key', chroma)
cv2.waitKey(0)
cv2.destroyAllWindows()
我想用这段代码做的是将它与 Tkinter UI 一起使用,因为它比 OpenCV 更好并且有更多选项。我一直在查看大量线程,但没有找到任何可以帮助我理解我的具体问题的东西。我确实在这个 Stack Overflow 上找到了一个答案,它提供了以下代码,我重新格式化以反射(reflect)我的代码的目的。每次释放 slider 控件时,它都会打印 slider 的值。
from Tkinter import *
class App():
def __init__(self):
self.root = Tk()
self.root.title('Adjust Matte Parameters')
self.clipBlack = Scale(self.root, from_=0, to=255, orient=HORIZONTAL, \
label='Clip Black', length=500)
self.clipBlack.bind("<ButtonRelease-1>", self.updateValue)
self.clipBlack.pack(anchor=CENTER)
self.clipWhite = Scale(self.root, from_=0, to=255, orient=HORIZONTAL, \
label='Clip White', length=500)
self.clipWhite.set(255)
self.clipWhite.bind("<ButtonRelease-1>", self.updateValue)
self.clipWhite.pack(anchor=CENTER)
self.root.mainloop()
def updateValue(self, event):
print 'Clip Black = ' + str(self.clipBlack.get())
print 'Clip White = ' + str(self.clipWhite.get())
app = App()
但是,这会引发更多问题。虽然我真的很喜欢它会立即检索 slider 位置,但它所做的只是打印它们。我希望将这些值插入到 keyer 函数中,正如我在 thresholdAdjust 中实现的那样。这样,我想更新图像,但我没有运气在 Tkinter 窗口打开时使用 OpenCV 显示图像,因为“root.mainloop()”行似乎不允许它。我找到了一些关于同时显示 Tkinter 和 OpenCV 窗口以及使用 Tkinter 显示图像的帮助,但这些选项无关紧要,直到我可以使用新的阈值更新 mask 。
我也不太明白如何处理其中的类和函数。我只习惯于通过创建如下所示的测试工具来运行代码
if __name__ == '__main__':
在第一个代码块中,所以我不知道如何在不对其进行硬编码的情况下确定我想要使用的图像和 mask 类型。
如果有人能帮助我,那将不胜感激!我知道很多,我很乐意消除任何困惑。一旦我知道如何使用 slider 完成此操作,我应该也能够将它应用于单选按钮。同样,我想:
谢谢!
最佳答案
好的,所以我已经为此倾注了几个小时,我想我终于找到了一个解决方案(你需要一个 .png
文件名 picture.png
为了运行下面的相同目录):
from tkinter import *
from PIL import Image, ImageTk
class App(Frame):
def __init__(self, master):
Frame.__init__(self, master)
self.frame1 = Frame(self)
self.frame2 = Frame(self)
self.original = Image.open('picture.png')
self.image = ImageTk.PhotoImage(self.original)
self.display = Canvas(self.frame1)
self.xscale = Scale(self.frame2, from_=1, to=1000, orient=HORIZONTAL, command=self.resize)
self.yscale = Scale(self.frame2, from_=1, to=1000, orient=VERTICAL, command=self.resize)
self.display.pack(fill=BOTH, expand=1)
self.xscale.pack()
self.yscale.pack()
self.pack(fill=BOTH, expand=1)
self.frame1.pack(fill=BOTH, expand=1)
self.frame2.pack()
self.bind("<Configure>", self.resize)
def resize(self, *args):
size = (self.xscale.get(), self.yscale.get())
resized = self.original.resize(size,Image.ANTIALIAS)
self.image = ImageTk.PhotoImage(resized)
self.display.delete("IMG")
self.display.create_image(self.display.winfo_width()/2, self.display.winfo_height()/2, anchor=CENTER, image=self.image, tags="IMG")
root = Tk()
app = App(root)
app.mainloop()
所以它所做的是创建一个 canvas
和两个 scale
,只要其中一个 scale
发生变化,它就会调用 def
resize
从 Canvas 中清除带有标签 IMG
的项目,然后绘制一个 width
等于xscale
的值和高度等于 yscale
的标签为 IMG
。当您沿着 scale
拖动 slider 时,会产生实时大小更新的错觉。
但是,我想不出一种方法来将 scale
的上限值限制为 canvas
的宽度(以像素为单位)以防止用户扩展图像在 canvas
的边界之外。
这可以类似地应用于允许您使用 slider 值实时更新您需要更新的图像的任何属性。
关于python - 如何使用 tkinter 比例修改图像?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36657126/
在 How to make a Tkinter window jump to the front? 中提出的问题之后的一个问题 我希望有一个顶层窗口(我用它来导航我的其他主窗口)总是在前面。但我希望它
有没有办法在 Tkinter 中保持小部件(特别是图像)的堆叠顺序一致?例如,我可能在 Canvas 上的同一位置有两个矩形、两个三角形和一个圆。圆圈移动到最后一次点击鼠标的地方,但我总是希望它被绘制
这是一个简单的 GUI 程序,用于创建 5x16 按钮矩阵。 from tkinter import * root = Tk() button = [[0 for x in range(16)] fo
有一个错误:“AttributeError: module 'tkinter' has no attribute 'messagebox'” 即使 import tkinter 一开始就已经给出了,为
我知道 menu.tk_popup() 可用于在特定坐标处打开上下文菜单,但也不知道如何从中打开子菜单,如果这有意义的话。这是我编写的代码: import tkinter as tk root = t
我正在尝试在禁用自动换行和水平滚动条的文本窗口中书写,如下所示: root = Toplevel() root.geometry("%dx%d+0+0" % (350,400)) af=Frame(r
已经将文本变量分配给小部件后,如何将其删除? widget.config(textvariable=None)只是不工作。在谷歌或这里找不到任何东西。 最佳答案 将您的变量分配给一个空字符串以实现此目
Jython 支持 Tkinter 吗?如果我用 Python 编写一个程序并放一个 使用 Tkinter 的 GUI 前端,做同样的事情有多难 Jython 中的程序?或者对于 Jython GUI
因此,我尝试创建一个 tkinter 窗口,显示当前时间和日期以及自定义短语。不过,我遇到的问题是,我似乎无法在第二天刷新日期。 我可以传递截至运行代码时的当前日期,但之后它变为静态。 这是我目前的程
我的理解是在初始化 __init__ 中的所有框架和小部件之后方法,tkinter 窗口会调整大小以适合所有这些组件。 我想将窗口的初始化大小设置为其最小大小。我希望能够最大化并放大窗口,但我从不希望
此代码仅水平居中,如何使进度条也垂直居中? import Tkinter import ttk root = Tkinter.Tk() root.geometry("=500x500") root.p
使用 Python 2.7 和 Tkinter 模块,我创建了一个菜单按钮并为其分配了一个菜单。现在每次我在特定位置发布菜单时,菜单的宽度都会根据字符数自动设置。有没有办法在菜单小部件中设置静态宽度?
我想将我的 tkinter 应用程序的主题更改为 clam。 代码是什么,我把它放在哪里?我试过了: from tkinter import * from tkinter.ttk import * s
我有以下代码: from Tkinter import * from urllib import urlretrieve import webbrowser import ttk def get_la
我知道,如果我将滚动条控制的框架绑定(bind)到函数 ( onFrameConfigure ),您可以获得滚动条位置,如下所示:self.calendar_frame.bind("", self.o
许多网站都说菜单小部件有一个选项“字体”,但我一直无法设置它。系统是在 Windows 8.1 中运行的 Python 3.5。脚本开始: 从 tkinter 导入 * 根 = Tk() root.g
我正在阅读本教程,它帮助我同时学习 tkinter 和 wxWidgets,但我想深入挖掘,所以想知道哪个 GUI 工具更适合深入学习,为什么? 最佳答案 不可能说哪个“更好”。两者均可用于最常见的用
看书学python,tkinter.END用在一段代码里不用解释 import tkinter def count(text, out_data): """ Update out_data w
我正在尝试使用 Python 2.7 将 Tkinter 导入到我的项目中,但我收到了错误: ImportError: No module named tkinter 在有人说之前,我已经尝试了“Tk
当我回答 Tkinter 问题时,我通常会尝试自己运行代码,但有时我会收到此错误: Traceback (most recent call last): File "C:\Python27\pyg
我是一名优秀的程序员,十分优秀!