gpt4 book ai didi

python - 交互式 Altair 绘图轴上方的文本

转载 作者:行者123 更新时间:2023-12-03 18:50:46 28 4
gpt4 key购买 nike

我一直在关注问题 here 的建议暂时将各种提示/信息放在我在 Altair 中的地 block 上。但是,如果 Altair 绘图设置为 interactive(),则此建议不起作用 - 在我看来,启用比例绑定(bind)可防止任何绘图对象出现在矩形轴之外。
这是一个基于该链接的复制示例:比较生成的图有/没有最后注释的 interactive() 行。

    import altair as alt
import pandas as pd
import numpy as np

df = pd.DataFrame({'x': np.linspace(0, 4, 1000)})
df['y'] = np.sin(2 * np.pi * df['x'])

select_point = alt.selection_single(fields=('x',), nearest=True, on='mouseover', empty='none')
line = alt.Chart(df).mark_line().encode(
x='x:Q',
y='y:Q',
)
points = line.mark_point(filled=True, size=100).encode(
opacity=alt.condition(select_point, alt.value(1.0), alt.value(0.0)),
).add_selection(select_point)
text1 = alt.Chart(df, width=600, height=400).mark_text(
align='left', baseline='bottom', dx=+5, fontSize=12,
).encode(
x=alt.value(0.0),
y=alt.value(-1),
text='_label:N',
opacity=alt.condition(select_point, alt.value(1.0), alt.value(0.0)),
).transform_calculate(
_label='"ABOVE AXES x = " + format(datum.x, ".2f") + ", y = " + format(datum.y, ".2f")',
)
text2 = alt.Chart(df, width=600, height=400).mark_text(
align='left', baseline='bottom', dx=+5, fontSize=12,
).encode(
x=alt.value(0.0),
y=alt.value(12),
text='_label:N',
opacity=alt.condition(select_point, alt.value(1.0), alt.value(0.0)),
).transform_calculate(
_label='"INSIDE AXES x = " + format(datum.x, ".2f") + ", y = " + format(datum.y, ".2f")',
)
chart = alt.layer(line, points, text1, text2)
# chart = chart.interactive()
Interactive OFF
Interactive ON
附加信息,以防有帮助/相关:
  • 我使用interactive() 和手动选择比例绑定(bind)对此进行了测试,效果相同
  • 将图表保存为 HTML
  • 后,我在 PyQT WebEngineView 容器中进行渲染
  • 肯定会在轴边界之外对对象进行某种跟踪,即使它们未在交互式 ON 的情况下显示也是如此。我还用点标记进行了测试:悬卡在轴边界边缘的大标记在交互式关闭时完全可见,但在交互式打开时会被切断。但是,如果您启用了交互式并缓慢拖动轴边界,您可以看到绘图标题向上移动以避免大标记从绘图的顶部边缘滑落,直到标记的中心离开边界和标题弹回来。

  • 底线问题:当绘图设置为交互式时,如何让文本出现在 Altair 的轴边界之外?

    最佳答案

    clip=Falsemark_text() ,并且文本将在轴外可见。clip参数默认为 False对于非绑定(bind)比例,True用于绑定(bind)秤。

    关于python - 交互式 Altair 绘图轴上方的文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66959478/

    28 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com