繁体   English   中英

散景中带有 CategoricalAxis 的多线轴 label?

[英]Multiline axis label with CategoricalAxis in Bokeh?

我正在研究 Bokeh plot,并且几乎按照我想要的方式得到了它。 但是,我正在努力添加多线轴标签。

这是我到目前为止所拥有的:

import bokeh.io
from bokeh.plotting import gridplot, figure, output_file, show, output_notebook
from bokeh.models import ColumnDataSource, BoxAnnotation, CategoricalAxis, FactorRange
from bokeh.embed import components

x = ['label1','label2','label3','label4','label5','label6','label7', 'Trying for a multiline label']
y = [1.0, 2.7, 1.2, 4.5, 1.5, 2.2, 1.8, 4.6]
p = figure(x_range=[*x], y_range=(0, 5), plot_height=400, plot_width=550)
dots = p.circle(x=x, y=y, color='black',size=10)
line = p.line(x=x, y=y, color='black')

numbers = [str(x) for x in y]
p.extra_x_ranges = {"extra_numbers": FactorRange(factors=numbers)}
p.add_layout(CategoricalAxis(x_range_name="extra_numbers"), 'below')
p.title.text = 'Plot'
p.title.text_font_size = "25px"
p.title.text_color = "black"
p.title.align = "center"

low_box = BoxAnnotation(top=2, fill_alpha=0.1, fill_color='green')
mid_box = BoxAnnotation(bottom=2, top=3, fill_alpha=0.1, fill_color='orange')
high_box = BoxAnnotation(bottom=3, fill_alpha=0.1, fill_color='red')

p.add_layout(low_box)
p.add_layout(mid_box)
p.add_layout(high_box)

show(p)

上面的代码产生以下 plot: 在此处输入图像描述

您可以清楚地看到最后一个 label 没有正确包裹,我还没有设法弄清楚我们如何让它包裹并创建一个多线轴 label。 是否有捷径可寻? 我想出的最佳替代解决方案是尝试使用垂直标签,但正如您所见,它们看起来不太好,并且弄乱了文本下方的第二个轴:

from bokeh.models import CategoricalAxis, FactorRange
from bokeh.plotting import figure, show
from math import pi

x = ['label1','label2','label3','label4','label5','label6','label7', 'Trying for a multiline label']
y = [1.0, 2.7, 1.2, 4.5, 1.5, 2.2, 1.8, 4.6]
p = figure(x_range=[*x], y_range=(0, 5), plot_height=900)
dots = p.circle(x=x, y=y, color='black',size=10)
line = p.line(x=x, y=y, color='black')
p.xaxis.major_label_orientation = pi/2
p.xaxis.major_label_text_font_size = "1.4em"

p.xaxis.axis_line_width = 2
p.yaxis.axis_line_width = 2
numbers = [str(x) for x in y]
p.extra_x_ranges = {"extra_numbers": FactorRange(factors=numbers)}
p.add_layout(CategoricalAxis(x_range_name="extra_numbers"), 'below')
show(p)

现在图表如下所示: 在此处输入图像描述

当然,一个简单的解决方法是切换轴的顺序,使数字在上面,标签在下面; 然而,这仍然是一个随意的解决方案,并不是我真正想要的。 我真的很想在 label 中换行。 例如,下面的 plot 与我想要完成的类似(可以在此处找到此非散景图的代码)。 在此处输入图像描述

任何帮助或建议将不胜感激!

库存 Bokeh 轴模型无法使用多线标签。 为了实现这一点,您必须创建一个自定义Axis子类并自己管理所有包装,因为canvas上下文不以任何方式支持它。

作为替代方案,您可以尝试有角度的标签。 这种方法的缺点是必须找出 plot 的正确偏移量,以确保标签不会被切断。

自过去几个版本以来,多行标签一直在散景中工作(我相信自 3.3 以来)。 您需要自己在 label 字符串的适当位置添加换行符“\n”。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM