8

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

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

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

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

4

4 回答 4

2

我遇到了同样的问题,发现我们需要使用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)
于 2018-02-17T20:17:20.907 回答
2

它在小部件文档中:

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

因此,在这里您已经拥有w一个 Box 容器,您可以为其更改布局属性。

w = interactive(foo, w1=widget1, w2=widget2)
于 2016-09-09T14:57:21.027 回答
1

使用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)
于 2018-02-28T16:36:11.180 回答
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)
于 2021-06-29T07:17:56.773 回答