跳转至

将交互式滑块添加到博克图

原文:https://www.geesforgeks.org/add-interactive-slider-to-bokeh-plots/

Bokeh 是 Python 的交互式数据可视化库。它可用于创建交互式绘图、仪表板和数据应用程序。小部件只不过是附加的视觉元素,您可以将其添加到绘图中,以交互方式控制您的 Bokeh 文档。有各种类型的小部件,如按钮、div、微调器、滑块等。在本文中,我们将了解 bokeh 中的滑块小部件。

滑块部件

Bokeh 滑块可以配置开始和结束值、步长、初始值和标题。基本上,您需要从 bokeh.models 导入 Slider 小部件。

语法:

从 bokeh.models 导入 CustomJS,Slider

Slider()函数可用于创建滑块。

语法:

滑块(开始=0,结束=10,值=1,步长=.1,标题=“填充”)

参数:

  • 开始:代表滑块开始值。
  • 结束:表示滑块结束值。
  • 值:表示滑块的当前值。
  • :表示滑块移动的间隔。
  • 标题:表示滑块小部件的标题。

现在使用当 on_change 事件发生时调用的 CustomJS 添加回调功能。

语法:

js_on_change("value ",custom js(code = " "…)。"""))

js_on_change 是滑块 on_change 事件发生时调用的回调函数。而 customJS(code= " " " ")表示一旦事件发生就要执行的代码。现在使用 slider 对象调用回调函数,并创建一个您想要在浏览器上显示的所有元素的布局。

示例:使用 bokeh 创建滑块

计算机编程语言

from bokeh.layouts import column
from bokeh.models import ColumnDataSource, Slider, CustomJS
from bokeh.plotting import figure, output_file, show
import numpy as np

x = np.linspace(0, 10, 500)
y = np.sin(x)

source = ColumnDataSource(data=dict(x=x, y=y))

# Create plots and widgets
plot = figure()

plot.line('x', 'y', source=source, line_width=3, line_alpha=0.5)

# Create Slider object
slider = Slider(start=0, end=6, value=2,
                step=0.2, title='Number of points')

# Adding callback code
callback = CustomJS(args=dict(source=source, val=slider),
                    code="""
    const data = source.data;
    const freq = val.value;
    const x = data['x'];
    const y = data['y'];
   for (var i = 0; i < x.length; i++) {
        y[i] = Math.sin(freq*x[i]);
    }

    source.change.emit();
""")

slider.js_on_change('value', callback)

# Arrange plots and widgets in layouts
layout = column(slider, plot)

output_file('exam.html')

show(layout)

输出:



回到顶部