Как установить обновленное значение Slider всегда в центре? - PullRequest
0 голосов
/ 12 ноября 2018

После демонстрации слайдера Matplotlib https://matplotlib.org/gallery/widgets/slider_demo.html, Я хотел бы обновить диапазоны слайдера, чтобы при каждом изменении значений слайдера они снова центрировались в слайдере.

Я попытался определить ползунки как

sfreq = Slider(axfreq, 'Freq', freq-10, freq+10, valinit=freq)
samp = Slider(axamp, 'Amp', amp-5, amp+5, valinit=amp)

но поскольку функция update () ничего не возвращает, это не работает. Я также попытался сделать эти переменные глобальными внутри функции, что тоже не сработало. Я наконец попытался определить ползунки внутри функции обновления,

def update(val):
    amp = samp.val
    freq = sfreq.val
    l.set_ydata(amp*np.sin(2*np.pi*freq*t))
    fig.canvas.draw_idle()
    Slider(axfreq, 'Freq', freq-10, freq+10, valinit=freq)
    Slider(axamp, 'Amp', amp-5, amp+5, valinit=amp)

, но это все больше и больше накладывает ползунки, когда я меняю значения. Есть предложения?

1 Ответ

0 голосов
/ 14 ноября 2018

Поэтому я просто решил сделать так, чтобы диапазон ползунка покрывал несколько порядков величины параметра, и отображал значения в логарифмическом масштабе.Если кто-то задается вопросом и следит за демонстрацией matplotlib:

import numpy as np
import matplotlib.pyplot as plt
from matplotlib.widgets import Slider, Button, RadioButtons

fig, ax = plt.subplots()
plt.subplots_adjust(left=0.25, bottom=0.25)
t = np.arange(0.0, 1.0, 0.001)
a0 = 5
f0 = 10
delta_f = 5.0
s = a0*np.sin(2*np.pi*f0*t)
l, = plt.plot(t, s, lw=2, color='red')
plt.axis([0, 1, -10, 10])

axcolor = 'lightgoldenrodyellow'
axfreq = plt.axes([0.25, 0.1, 0.65, 0.03], facecolor=axcolor)
axamp = plt.axes([0.25, 0.15, 0.65, 0.03], facecolor=axcolor)

sfreq = Slider(axfreq, 'Freq', np.log(1), np.log10(1000), valinit=np.log10(f0), valfmt='%4.2E')
samp = Slider(axamp, 'Amp', a0-5, a0+5, valinit=a0)

def update(val):
    amp = samp.val
    freq = sfreq.val
    sfreq.valtext.set_text('{:4.2E}'.format(10**freq))
    l.set_ydata(amp*np.sin(2*np.pi*10**freq*t))
    fig.canvas.draw_idle()
sfreq.on_changed(update)
samp.on_changed(update)

resetax = plt.axes([0.8, 0.025, 0.1, 0.04] )
button = Button(resetax, 'Reset', color=axcolor, hovercolor='0.975')

def reset(event):
    sfreq.reset()
    samp.reset()
button.on_clicked(reset)

rax = plt.axes([0.025, 0.5, 0.15, 0.15], facecolor=axcolor)
radio = RadioButtons(rax, ('red', 'blue', 'green'), active=0)

def colorfunc(label):
    l.set_color(label)
    fig.canvas.draw_idle()
radio.on_clicked(colorfunc)

plt.show()
...