gpt4 book ai didi

javascript - 在图表图像中显示鼠标悬停事件的轴值

转载 作者:行者123 更新时间:2023-11-30 10:55:21 25 4
gpt4 key购买 nike

我将图表图像(带有 x 轴和 y 轴)返回到创建我的 matplotlit 的浏览器。现在我想在有鼠标悬停事件时显示轴值。

最佳答案

当我最近做这样的事情时,我从 matplotlib 向浏览器返回了一个 PNG。然后,我使用与绘制的点相对应的像素值将图像映射应用于 PNG。我使用 onmouseover 事件弹出一个“工具提示”(实际上只是一个绝对定位的 div),其中包含关于该点的元数据。

article为我的努力提供了基础,但我记得他的实现中有一些小问题(主要是由于 matplotlib api 的变化)。如果这个问题在星期一仍然存在,我将使用我的实现中的特定代码更新这个答案(我目前无法访问我的工作机器)。

编辑:作为 promise 的示例代码

import matplotlib.pyplot as plt

dpi = 96
fig = plt.figure(figsize=(8,8),dpi=dpi)
imgWidth = fig.get_figwidth() * dpi ## this is the actual pixel size of the plot
imgHeight = fig.get_figheight() * dpi ## this is the actual pixel size

my_lines = []
my_lines.append(plt.plot(Xs,Ys,marker='o')[0]) # add a line object to plot

mapHTML = '<MAP name="curveMap">'
for lineObj in my_lines:
## convert the points to pixel locations, for pop-ups
lineObj._transform_path()
path, affine = lineObj._transformed_path.get_transformed_points_and_affine()
path = affine.transform_path(path)
for real,pixel in zip(lineObj.get_xydata(),path.vertices):
mapHTML+='''<AREA shape=\"circle\" coords=\"%i,%i,5\" href=\"javascript: void(0);\" onmouseout=\"outFly();\" onmouseover=\"javascript: popFly\(event,\\'%s\\',%i,%i\)\" />''' % (pixel[0],imgHeight-pixel[1],lineName,real[0],real[1])
mapHTML += '</MAP>'
fig.savefig(file(plot_file,"w"),format='png',dpi=dpi)
plt.close(fig)
plotHTML = '''<img src="/getPlot?uniq=%f" width="%i" height="%i" ismap usemap="#curveMap" onload="imageLoadCallback();" id="curPlot" />''' % (time.time(),imgWidth,imgHeight)
return "({'plotHTML':'%s','mapHTML':'%s'})" % (plotHTML,mapHTML)

您会看到我正在将图像写入 png 文件,然后返回 JSON。我使用 javascript 使用新的 img 和图像映射更新 DIV。

关于javascript - 在图表图像中显示鼠标悬停事件的轴值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2075402/

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