使用interactive
对于多个小部件非常简单,例如:
interactive(foo, w1=widget1, w2=widget2, ...)
但是我想使用VBox和HBox的组合以特定的方式布局这些小部件。问题是,我如何使用盒子的交互?
我尝试了几种方法,例如使用Box的小部件调用交互式,然后显示盒子本身,但这似乎不起作用。
答案 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)
类似的东西:
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)