散景:自动刷新散景图

时间:2016-07-10 11:39:31

标签: bokeh

我正在尝试使用示例Bokeh Application(以“单一模块格式”)从数据集生成图表。在给定的示例中,网页上的用户可以单击按钮,图表将使用最新数据进行更新。我试图弄清楚如何在不要求用户点击按钮的情况下实现相同的行为。也就是说,我希望图表能够以指定的间隔自动更新/刷新/重新加载,而无需用户交互。理想情况下,我只需要在myapp.py中更改一些内容即可实现此目的。

散景版是0.12.0。

为方便起见,这里复制了演示代码:

# myapp.py

import numpy as np

from bokeh.layouts import column
from bokeh.models import Button
from bokeh.palettes import RdYlBu3
from bokeh.plotting import figure, curdoc

# create a plot and style its properties
p = figure(x_range=(0, 100), y_range=(0, 100), toolbar_location=None)
p.border_fill_color = 'black'
p.background_fill_color = 'black'
p.outline_line_color = None
p.grid.grid_line_color = None

# add a text renderer to out plot (no data yet)
r = p.text(x=[], y=[], text=[], text_color=[], text_font_size="20pt",
           text_baseline="middle", text_align="center")

i = 0

ds = r.data_source

# create a callback that will add a number in a random location
def callback():
    global i
    ds.data['x'].append(np.random.random()*70 + 15)
    ds.data['y'].append(np.random.random()*70 + 15)
    ds.data['text_color'].append(RdYlBu3[i%3])
    ds.data['text'].append(str(i))
    ds.trigger('data', ds.data, ds.data)
    i = i + 1

# add a button widget and configure with the call back
button = Button(label="Press Me")
button.on_click(callback)

# put the button and plot in a layout and add to the document
curdoc().add_root(column(button, p))

2 个答案:

答案 0 :(得分:12)

原来在Document对象中有一个方法:

add_periodic_callback(callback, period_milliseconds)

不确定为什么在API之外没有提到这个......

答案 1 :(得分:1)

是的,add_periodic_callback()

import numpy as np
from bokeh.layouts import column
from bokeh.models import Button
from bokeh.palettes import RdYlBu3
from bokeh.plotting import figure, curdoc


p = figure(x_range=(0, 100), y_range=(0, 100), toolbar_location=None)
p.border_fill_color = 'black'
p.background_fill_color = 'black'
p.outline_line_color = None
p.grid.grid_line_color = None

r = p.text(x=[], y=[], text=[], text_color=[], text_font_size="20pt",
           text_baseline="middle", text_align="center")

i = 0

ds = r.data_source

def callback():
    global i
    ds.data['x'].append(np.random.random()*70 + 15)
    ds.data['y'].append(np.random.random()*70 + 15)
    ds.data['text_color'].append(RdYlBu3[i%3])
    ds.data['text'].append(str(i))
    ds.trigger('data', ds.data, ds.data)
    i = i + 1

curdoc().add_root(column(p))
curdoc().add_periodic_callback(callback, 1000)