我在散景图中的一列中有多个图形。我想同时对所有图像应用相同的工具变换,即,如果我缩放一个图形,则所有图应缩放,如果平移一个,则它们都应平移,如果重置一个,则它们都应重置(真的不在乎悬停,我会欣喜若狂地缩放,平移和重置)。
是否有一种散景的方式链接数字,或者我需要一些自定义Javascript(如果可以的话)?
谢谢。
编辑:
感谢@bigreddot和@Abhinav提供解决方案。您需要两个答案,如此处所述:view。该范围有助于平移,而相同的数据源则有助于缩放,
来自布局示例的修改后的解决方案:
from bokeh.io import output_file, show
from bokeh.layouts import column
from bokeh.plotting import figure
from bokeh.models import ColumnDataSource
from bokeh.models import PanTool,ResetTool,BoxZoomTool
output_file("layout.html")
x = list(range(11))
y0 = x
y1 = [10 - i for i in x]
y2 = [abs(i - 5) for i in x]
tools=[BoxZoomTool(), PanTool(), ResetTool()]
datasource = ColumnDataSource({'x': x, 'y0': y0, 'y1': y1, 'y2': y2})
# create a new plot
s1 = figure(plot_width=250, plot_height=250, title=None,tools=tools)
s1.circle('x', 'y0', size=10, color="navy", alpha=0.5, source=datasource)
# create another one
s2 = figure(plot_width=250, plot_height=250, title=None,tools=tools,x_range=s1.x_range,y_range=s1.y_range)
s2.triangle('x', 'y1', size=10, color="firebrick", alpha=0.5, source=datasource)
# create and another
s3 = figure(plot_width=250, plot_height=250, title=None,tools=tools,x_range=s1.x_range,y_range=s1.y_range)
s3.square('x', 'y2', size=10, color="olive", alpha=0.5, source=datasource)
# put the results in a column and show
show(column(s1, s2, s3))
答案 0 :(得分:2)
这在文档Linking Plots下。
TLDR:如果要让图共享范围,则共享其实际范围对象:
# create a new plot
s1 = figure()
s1.circle(x, y0, size=10, color="navy", alpha=0.5)
# create a new plot and share both ranges
s2 = figure(x_range=s1.x_range, y_range=s1.y_range)
s2.triangle(x, y1, size=10, color="firebrick", alpha=0.5)
答案 1 :(得分:1)
您应该从数据中创建一个ColumnDataSource对象,并在创建图形中的字形时使用它。只要这些图共享相同的数据源,它们将具有相同的工具效果。使用ColumnDataSource
时,您需要使用数据源中的列名指定数据,而不是直接传递数组本身。例如:
from bokeh.io import output_file, show
from bokeh.layouts import column
from bokeh.plotting import figure
from bokeh.models import ColumnDataSource
from bokeh.models import PanTool,ResetTool,HoverTool,WheelZoomTool,SaveTool,BoxZoomTool
output_file("layout.html")
x = list(range(11))
y0 = x
y1 = [10 - i for i in x]
y2 = [abs(i - 5) for i in x]
#tools='hover,xpan,xwheel_zoom,box_zoom,save,reset'
tools=[HoverTool(),BoxZoomTool(dimensions='width'), PanTool(dimensions='width'), SaveTool(), ResetTool()]
datasource = ColumnDataSource({'x': x, 'y0': y0, 'y1': y1, 'y2': y2})
# create a new plot
s1 = figure(plot_width=250, plot_height=250, title=None,tools=tools)
s1.circle('x', 'y0', size=10, color="navy", alpha=0.5, source=datasource)
# create another one
s2 = figure(plot_width=250, plot_height=250, title=None,tools=tools)
s2.triangle('x', 'y1', size=10, color="firebrick", alpha=0.5, source=datasource)
# create and another
s3 = figure(plot_width=250, plot_height=250, title=None,tools=tools)
s3.square('x', 'y2', size=10, color="olive", alpha=0.5, source=datasource)
# put the results in a column and show
show(column(s1, s2, s3))