在Bokeh中隐藏图例旁边的注释

2024-09-22 20:23:16 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个互动的博克图,可以在点击图例时隐藏某些圆形图。现在,当我通过单击禁用打印时,打印的圆将消失,但注释仍保留。有人能给我解释一下,我怎么能同时打开/关闭这些开关,或者有人有快速修复方法吗

with

这里有一张关闭时的图片:

without

我用以下代码绘制圆圈+图例:

q.circle('lng', 'lat', source = source2, name='vri', color='red', size=5, hover_line_color="black", legend_label = 'VRI')

vri_labels = LabelSet(x='lng', y='lat', text='kruispuntn', x_offset=5, y_offset=5, source=source2, text_font_size = '10pt')

q.legend.location = "bottom_left"
q.legend.click_policy="hide"

q.add_layout(vri_labels)

show(q)

Tags: 方法textsourcesizelabels圆形offsetcolor
1条回答
网友
1楼 · 发布于 2024-09-22 20:23:16

您可以通过CustomJS回调链接visible属性:

from bokeh.io import show
from bokeh.models import ColumnDataSource, LabelSet, CustomJS
from bokeh.plotting import figure

p = figure()
cds = ColumnDataSource(data=dict(x=[0, 1], y=[0, 1], z=[1, 0]))

for var, params in [('y', {}),
                    ('z', {'color': 'green'})]:
    renderer = p.circle('x', var, source=cds, legend_label=var, size=20, **params)
    label_set = LabelSet(x='x', y=var, text=var, source=cds, x_offset=5, y_offset=5)
    p.add_layout(label_set)
    renderer.js_on_change('visible', CustomJS(args=dict(ls=label_set),
                                              code="ls.visible = cb_obj.visible;"))

p.legend.click_policy = 'hide'

show(p)

相关问题 更多 >