如何使用包含小部件的Box进行交互?

时间:2016-09-08 18:21:55

标签: ipywidgets

使用interactive对于多个小部件非常简单,例如:

interactive(foo, w1=widget1, w2=widget2, ...)

但是我想使用VBox和HBox的组合以特定的方式布局这些小部件。问题是,我如何使用盒子的交互?

我尝试了几种方法,例如使用Box的小部件调用交互式,然后显示盒子本身,但这似乎不起作用。

4 个答案:

答案 0 :(得分:2)

它位于小部件documentation中:

  

除了interact之外,IPython还提供了另一个函数interactive,当您想要重用生成的小部件或访问绑定到UI控件的数据时,它很有用。   [...]   与interact不同,interactive返回Widget实例,而不是立即显示小部件。窗口小部件是Box,它是其他窗口小部件的容器。

因此,您已经将w作为Box容器,您可以为其更改布局属性。

w = interactive(foo, w1=widget1, w2=widget2)

答案 1 :(得分:1)

我遇到了同样的问题,并且发现我们需要使用interactive_output

out = interactive_output(foo, {"w1":w1, "w2":w2, "w3":w3, "w4":w4})
vbox1 = VBox([w1, w2])
vbox2 = VBoX([w3, w4])
ui = HBox([vbox1, vbox2])

accordian = Accordian(children=[ui])
accordian.set_title(0, 'Title')

display(accordian, out)

答案 2 :(得分:0)

使用interactive_output

类似的东西:

t1 = Text(value='Hello 1', description='row 1')
t2 = Text(value='Hello 2', description='')
t3 = Text(value='Hello 3', description='')
t4 = Text(value='Hello 4', description='row 2')
t5 = Text(value='Hello 5', description='')
t6 = Text(value='Hello 6', description='')
t7 = Text(value='Hello 7', description='row 3')
t8 = Text(value='Hello 8', description='')
t9 = Text(value='Hello 9', description='')

def foo(p1,p2,p3,p4,p5,p6,p7,p8,p9):
    print(p1,p2,p3,p4,p5,p6,p7,p8,p9)

out = interactive_output(foo, {"p1":t1, "p2":t2, "p3":t3, "p4":t4, "p5":t5, "p6":t6, "p7":t7, "p8":t8, "p9":t9})
hbox1 = HBox([t1, t2, t3])
hbox2 = HBox([t4, t5, t6])
hbox3 = HBox([t7, t8, t9])
ui = VBox([hbox1, hbox2, hbox3])

display(ui, out)

答案 3 :(得分:0)

(注意:这是我第一次回答堆栈溢出问题,如果我还没有弄清楚如何在此处发布代码块,我深表歉意,但我会尽力格式化它们。)

就像其他人所说的,为此使用interactive_output。从 https://ipywidgets.readthedocs.io/en/latest/examples/Using%20Interact.html 处的文档中, 有一个示例代码说明了这一点:

a = widgets.IntSlider()
b = widgets.IntSlider()
c = widgets.IntSlider()
ui = widgets.HBox([a, b, c])
def f(a, b, c):
    print((a, b, c))

out = widgets.interactive_output(f, {'a': a, 'b': b, 'c': c})

display(ui, out)

我实际上在自己的代码中实现了这一点,我使用 HBox 和 VBox 来形成一个 2x2 的小部件网格。我正在绘制指数函数和一般正弦波的乘积,幅度、指数衰减、频率和相位通过滑块变化。代码如下:

import numpy as np
import matplotlib.pyplot as plt
import ipywidgets as wgs
from ipywidgets import HBox, VBox
%matplotlib inline

def f(A, decay, wd, phase):
    t = np.linspace(0, 2*np.pi, 501)
    fig, ax = plt.subplots(figsize=(14,4), dpi=100)
    x = A*np.exp(-decay*t)*np.sin(wd*t + phase)
    ax.plot(t, x, 'b.', linewidth = 3)
    ax.grid()
    ax.set_title(r'$ %(amp)s e^{ -%(sig)s t} sin( %(wd)s t + %(phi)s ) $' %{'amp':A, 'sig':decay, 'wd':wd, 'phi':phase,} )
    ax.set_xlabel('t')
    ax.set_ylabel('x(t)')
    ax.set_xlabel('Time (seconds)')
    ax.set_ylabel('Displacement (meters)')
    ax.set_xticks(np.linspace(min(t),max(t), 21))
    ax.set_yticks(np.linspace(-A, A,11))  
    return A, decay, wd, phase
A  = wgs.IntSlider(value = 1, min = 1, max = 10, step = 1, description = r'$ A : $', disabled=False)
decay = wgs.FloatSlider(value = 0, min = 0, max = 10, step = 0.5, description = r'$ \sigma : $', disabled=False)
wd    = wgs.IntSlider(value = 1, min = 1, max = 20, step = 1, description = r'$ \omega_d : $', disabled=False)
phase = wgs.FloatSlider(value = 0, min = -1.5, max = 1.5, step = 0.1, description = r'$ \phi : $', disabled=False)
row1 = HBox( [A, decay] )
row2 = HBox( [wd, phase] )
ui = VBox( [row1, row2] )
out = wgs.interactive_output(f, {'A':A, 'decay':decay, 'wd':wd, 'phase':phase} )
display(ui, out)