ツールバーにリセットボタンがあるボケ味のフィギュアがあります。基本的に、図にプロットしているデータを更新するときに、図を「リセット」したいと思います。どうやってやるの?
UPDATE:この機能のPRが送信されました。ボケの後0.12.16
がリリースされると、以下が機能します。
from bokeh.io import show
from bokeh.layouts import column
from bokeh.models import Button, CustomJS
from bokeh.plotting import figure
p = figure(tools="reset,pan,wheel_zoom,lasso_select")
p.circle(list(range(10)), list(range(10)))
b = Button()
b.js_on_click(CustomJS(args=dict(p=p), code="""
p.reset.emit()
"""))
show(column(p, b))
ボケの時点で0.12.1
これを行うための組み込み関数はありません。これを行う カスタム拡張 を作成することは可能です。ただし、それには少しの作業と実験と対話が必要になります。そのオプションを追求したい場合は、SOよりも反復的なコラボレーションとディスカッションに適した 公開メーリングリスト にアクセスすることをお勧めします。または、 プロジェクト課題トラッカー で機能リクエストを開いてください。
ラジオグループコールバックの例。これは、プロットの変更中にリセットするのに最適な方法です。データの範囲を取得して、次の範囲に設定するだけです。
from bokeh.plotting import Figure
from bokeh.models import ColumnDataSource, CustomJS, RadioGroup
from bokeh.layouts import gridplot
from bokeh.resources import CDN
from bokeh.embed import file_html
x0 = range(10)
x1 = range(100)
y0 = [i for i in x0]
y1 = [i*2 for i in x1][::-1]
fig=Figure()
source1=ColumnDataSource(data={"x":[],"y":[]})
source2=ColumnDataSource(data={"x0":x0,"x1":x1,"y0":y0,"y1":y1})
p = fig.line(x='x',y='y',source=source1)
callback=CustomJS(args=dict(s1=source1,s2=source2,px=fig.x_range,py=fig.y_range), code="""
var d1 = s1.get("data");
var d2 = s2.get("data");
var val = cb_obj.active;
d1["y"] = [];
var y = d2["y"+val];
var x = d2["x"+val];
var min = Math.min( ...y );
var max = Math.max( ...y );
py.set("start",min);
py.set("end",max);
var min = Math.min( ...x );
var max = Math.max( ...x );
px.set("start",min);
px.set("end",max);
for(i=0;i<=y.length;i++){
d1["y"].Push(d2["y"+val][i]);
d1["x"].Push(d2["x"+val][i]);
}
s1.trigger("change");
""")
radiogroup=RadioGroup(labels=['First plot','Second plot'],active=0,callback=callback)
grid = gridplot([[fig,radiogroup]])
outfile=open('TEST.html','w')
outfile.write(file_html(grid,CDN,'Reset'))
outfile.close()
Bokeh Webサイトには、さまざまなウィジェットのコールバックを設定するさまざまな方法の例が大幅に不足しています。