admin管理员组文章数量:1352186
Can't find a way to position tooltip in center of bar like this (yeah, I know it is not exactly in center on this screenshot, but still):
If I use custom
tooltip option, I can get only x
and y
positions of a caret on top of a bar. But can't get height/width of a bar.
Here is a part of an options object that I pass to Chart constructor:
const options = {
tooltips: {
enabled: false,
custom: (tooltip) => {
// Retrieving valuable props from tooltip (caretX, caretY)
// and creating custom tooltip that is positioned
// on top of a bar
}
}
// other options
}
const chart = new Chart(ctx, {
type: 'bar',
data,
options
})
Can't find a way to position tooltip in center of bar like this (yeah, I know it is not exactly in center on this screenshot, but still):
If I use custom
tooltip option, I can get only x
and y
positions of a caret on top of a bar. But can't get height/width of a bar.
Here is a part of an options object that I pass to Chart constructor:
const options = {
tooltips: {
enabled: false,
custom: (tooltip) => {
// Retrieving valuable props from tooltip (caretX, caretY)
// and creating custom tooltip that is positioned
// on top of a bar
}
}
// other options
}
const chart = new Chart(ctx, {
type: 'bar',
data,
options
})
Share
Improve this question
edited Aug 7, 2017 at 8:24
K Scandrett
16.5k4 gold badges42 silver badges68 bronze badges
asked Jul 31, 2017 at 12:26
GProstGProst
10.2k3 gold badges27 silver badges50 bronze badges
4
- @ℊααnd Yes, height/width of a bar on hover + top left coordinates of this bar – GProst Commented Jul 31, 2017 at 13:50
- 1 Do you have a sample/some code that we can look at? – Trevor Nestman Commented Aug 2, 2017 at 17:27
- @Trevor Updated my question – GProst Commented Aug 2, 2017 at 21:04
-
You have
xAlign
andyAlign
properties for custom tooltip, but still- please preape some dome so we'll be able to help. – Maciej Kwas Commented Aug 2, 2017 at 21:12
3 Answers
Reset to default 4 +50As you may already know, to position a custom tooltip at the center of a bar, you might need some of it's (bar) properties, such as - width, height, top and left position. But unfortunately, there is no straight-forward way of getting these properties, rather you need to calculate them yourself.
To obtain / calculate those properties, you can use the following function (can be named anything), which will return an object containing all these (width, height, top, left) properties of a particular bar, when hovered over.
function getBAR(chart) {
const dataPoints = tooltipModel.dataPoints,
datasetIndex = chart.data.datasets.length - 1,
datasetMeta = chart.getDatasetMeta(datasetIndex),
scaleBottom = chart.scales['y-axis-0'].bottom,
bar = datasetMeta.data[dataPoints[0].index]._model,
canvasPosition = chart.canvas.getBoundingClientRect(),
paddingLeft = parseFloat(getComputedStyle(chart.canvas).paddingLeft),
paddingTop = parseFloat(getComputedStyle(chart.canvas).paddingTop),
scrollLeft = document.body.scrollLeft,
scrollTop = document.body.scrollTop;
return {
top: bar.y + canvasPosition.top + paddingTop + scrollTop,
left: bar.x - (bar.width / 2) + canvasPosition.left + paddingLeft + scrollLeft,
width: bar.width,
height: scaleBottom - bar.y
}
}
Calculate Center Position
After retrieving the required properties, you can calculate center position of a bar as such :
本文标签: javascriptPosition tooltip in center of barStack Overflow
版权声明:本文标题:javascript - Position tooltip in center of bar - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743910122a2560239.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论