Кажется, в API нет ничего, что могло бы сделать это напрямую. Используя bokeh.models VeeHead
, вы можете нарисовать стрелку VeeHead
import numpy as np
from bokeh.plotting import figure, show, output_file
from bokeh.models import ColumnDataSource
from bokeh.models import Arrow, VeeHead
# Create a sin wave of x/y coordinates
N = 300
x = np.linspace(0, 4*np.pi, N)
y = np.sin(x)
source = ColumnDataSource(data=dict(x=x, y=y))
TOOLS = "pan,wheel_zoom,box_zoom,reset,save"
# create a new plot and add a renderer
p = figure(tools=TOOLS, width=700, height=700, title=None)
p.line('x', 'y', source=source)
for i in range(N-1):
p.add_layout(Arrow(end=VeeHead(size=25,fill_alpha=0.5), x_start=x[i], y_start=y[i], x_end=x[i+1], y_end=y[i+1]))
show(p)
Вместо того, чтобы фактически не иметь хвоста, как в первом примере, вы добавляете один, как в этом примере. Обратите внимание, что у хвоста есть собственный стиль, который я не использовал в этом примере.
import numpy as np
from bokeh.plotting import figure, show, output_file
from bokeh.models import ColumnDataSource
from bokeh.models import Arrow, VeeHead
# prepare some date
N = 300
x = np.linspace(0, 4*np.pi, N)
y = np.sin(x)
source = ColumnDataSource(data=dict(x=x, y=y))
TOOLS = "pan,wheel_zoom,box_zoom,reset,save"
# create a new plot and add a renderer
p = figure(tools=TOOLS, width=700, height=700, title=None)
p.line('x', 'y', source=source)
for i in range(11, N-1):
m = (y[i]-y[i-1])/(x[i]-x[i-1])
Y = m*(x[i]-x[i-10]) # not point slope
p.add_layout(Arrow(end=VeeHead(size=25,fill_alpha=0.5), x_start=x[i-10], y_start=Y, x_end=x[i], y_end=y[i]))
show(p)