在散景中悬停多行字形时如何显示单个值?

Dmi*_*nin 4 python multiline hover python-3.x bokeh

至于现在我看到 Bokeh 支持多行字形的 HoverTool。但问题是,如果我想显示点的特定值 - 它会显示所有值列表而不是它。

请看下面的例子:

from bokeh.plotting import show, figure
from bokeh.models import ColumnDataSource, HoverTool

df = {'X_value': [[1, 2, 3, 4], [1, 2, 3, 4], [1, 2, 3, 4], [1, 2, 3, 4]], 
      'model': ['m1', 'm1', 'm2', 'm2'], 
      'color': ['red', 'red', 'blue', 'blue'],
      'Y_value': [[0.50, 0.66, 0.70, 0.67], [0.65, 0.68, 0.71, 0.66], [0.80, 0.79, 0.84, 0.80], [0.80, 0.83, 0.76, 0.64]]}

source = ColumnDataSource(df)

p = figure(plot_height=400)
p.multi_line(xs='X_value', ys='Y_value', legend="model", color='color',
             line_width=5, line_alpha=0.6, hover_line_alpha=1.0,
             source=source)

p.add_tools(HoverTool(show_arrow=False, line_policy='next', tooltips=[
    ('X_value', '@X_value'),
    ('Y_value', '@Y_value')
]))

show(p)
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

我知道 $x, $y 能力,但这在鼠标下显示协调,并且当您移动鼠标时它们会发生变化,这不是所需的行为。

有没有办法在 multi_line 字形中显示悬停点的精确值?

ps 创建隐形线不是解决方案,因为我有更高级的图,包括过滤和链接图等等。

谢谢!

Che*_*uCR 5

如果您更新到散景版本 0.12.16,您可以CustomJSHover像这样使用新类:

from bokeh.plotting import show, figure
from bokeh.models import ColumnDataSource, HoverTool
from bokeh.models.tools import CustomJSHover


df = {'X_value': [[1, 2, 3, 4], [1, 2, 3, 4], [1, 2, 3, 4], [1, 2, 3, 4]], 
      'model': ['m1', 'm1', 'm2', 'm2'], 
      'color': ['red', 'red', 'blue', 'blue'],
      'Y_value': [[0.50, 0.66, 0.70, 0.67], [0.65, 0.68, 0.71, 0.66], [0.80, 0.79, 0.84, 0.80], [0.80, 0.83, 0.76, 0.64]]}

source = ColumnDataSource(df)

p = figure(plot_height=400)
p.multi_line(xs='X_value', ys='Y_value', legend="model", color='color',
             line_width=5, line_alpha=0.6, hover_line_alpha=1.0,
             source=source)

x_custom = CustomJSHover(code="""
    return '' + special_vars.data_x
""")

y_custom = CustomJSHover(code="""
    return '' + special_vars.data_y
""")

p.add_tools(
    HoverTool(
        show_arrow=False, 
        line_policy='next',
        tooltips=[
            ('X_value', '@X_value{custom}'),  # or just ('X_value', '$data_x')
            ('Y_value', '@Y_value{custom}')
        ],
        formatters=dict(
            X_value=x_custom,
            Y_value=y_custom
        )
    )
)

show(p)
Run Code Online (Sandbox Code Playgroud)

  • 顺便提一句!我检查过 =) 它没有记录在文档中,但 $data_x 也确实可用。所以你可以使用没有 js 的默认 HoverTool,并写入 ('value', '$data_x') (3认同)