Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/python/297.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 将交互式Matplotlib绘图嵌入Tkinter?_Python_Matplotlib_Tkinter - Fatal编程技术网

Python 将交互式Matplotlib绘图嵌入Tkinter?

Python 将交互式Matplotlib绘图嵌入Tkinter?,python,matplotlib,tkinter,Python,Matplotlib,Tkinter,我有一个交互式绘图的代码,它允许通过鼠标滚动滚动切片来查看3D图像。它还包括一个用于调整对比度的滑动条 我一直在尝试将其嵌入Tkinter GUI,例如,借助以下示例代码: 但我真的不明白我的代码应该放在哪里 这是我目前拥有的应用程序: import matplotlib.pyplot as plt import numpy as np from matplotlib.widgets import Slider class IndexTracker(object): def __ini

我有一个交互式绘图的代码,它允许通过鼠标滚动滚动切片来查看3D图像。它还包括一个用于调整对比度的滑动条

我一直在尝试将其嵌入Tkinter GUI,例如,借助以下示例代码:

但我真的不明白我的代码应该放在哪里

这是我目前拥有的应用程序:

import matplotlib.pyplot as plt
import numpy as np
from matplotlib.widgets import Slider

class IndexTracker(object):
    def __init__(self, ax, X):
        self.ax = ax
        ax.set_title('use scroll wheel to navigate images')
        self.X = X
        rows, cols, self.slices = X.shape
        self.ind = self.slices//2
        self.im = ax.imshow(self.X[:, :, self.ind], cmap='gray')
        self.update()

    def onscroll(self, event):
        print("%s %s" % (event.button, event.step))
        if event.button == 'up':
            self.ind = (self.ind + 1) % self.slices
        else:
            self.ind = (self.ind - 1) % self.slices        
        self.update()

    def contrast(self, event):
        print('Changing contrast')
        print(smax.val)
        self.im.set_clim([0,smax.val])        
        self.update()

    def update(self):
        self.im.set_data(self.X[:, :, self.ind])
        self.ax.set_ylabel('slice %s' % self.ind)
        self.im.axes.figure.canvas.draw()


##### Create some random volumetric data

im = np.array(np.random.rand(10,10,10))

##### Initialize Tracker object with the data and Slider

fig, ax = plt.subplots(1,1)    
axmax  = fig.add_axes([0.25, 0.01, 0.65, 0.03])
smax = Slider(axmax, 'Max', 0, np.max(im), valinit=50)
tracker = IndexTracker(ax, im)
fig.canvas.mpl_connect('scroll_event', tracker.onscroll)
smax.on_changed(tracker.contrast)

plt.show()

我不明白我需要在Tkinter应用程序中嵌入什么,是
fig
,还是
IndexTracker
?如何替换
fig.canvas.mpl\u connect('scroll\u event',tracker.onscroll)
使其在TKinter GUI中工作?

将其嵌入到
TKinter
中没有什么特别之处-您首先创建一个
FigureCanvasTkAgg
对象,然后执行其余操作。您唯一需要更改的是使用您引用的示例中显示的
,而不是
plt

import numpy as np
from matplotlib.widgets import Slider
from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg
from matplotlib.figure import Figure

class IndexTracker(object):
    ...


import tkinter as tk
root = tk.Tk()
fig = Figure()
canvas = FigureCanvasTkAgg(fig, root)
canvas.get_tk_widget().pack(fill="both", expand=True)

im = np.array(np.random.rand(10,10,10))

ax = fig.subplots(1,1)

axmax  = fig.add_axes([0.25, 0.01, 0.65, 0.03])
smax = Slider(axmax, 'Max', 0, np.max(im), valinit=50)
tracker = IndexTracker(ax, im)
canvas.mpl_connect('scroll_event', tracker.onscroll)
canvas.mpl_connect('button_release_event', tracker.contrast) #add this for contrast change
root.mainloop()

将其嵌入到
tkinter
中没有什么特别之处-首先创建一个
figureCastKagg
对象,然后执行其余操作。您唯一需要更改的是使用您引用的示例中显示的
,而不是
plt

import numpy as np
from matplotlib.widgets import Slider
from matplotlib.backends.backend_tkagg import FigureCanvasTkAgg
from matplotlib.figure import Figure

class IndexTracker(object):
    ...


import tkinter as tk
root = tk.Tk()
fig = Figure()
canvas = FigureCanvasTkAgg(fig, root)
canvas.get_tk_widget().pack(fill="both", expand=True)

im = np.array(np.random.rand(10,10,10))

ax = fig.subplots(1,1)

axmax  = fig.add_axes([0.25, 0.01, 0.65, 0.03])
smax = Slider(axmax, 'Max', 0, np.max(im), valinit=50)
tracker = IndexTracker(ax, im)
canvas.mpl_connect('scroll_event', tracker.onscroll)
canvas.mpl_connect('button_release_event', tracker.contrast) #add this for contrast change
root.mainloop()