Подсказка включена при предоставлении непустой строки / значения для tooltipText
в нужном месте. В этом случае установка его на метках оси вызовет всплывающую подсказку оси (которая немного отличается от других подсказок, например, в том, что по умолчанию она черная и цепляется за периметр или в этом случае окружность диаграммы) при наведении курсора:
categoryAxis.renderer.labels.template.tooltipText = "{category}";
Чтобы обрезать текст меток вашей оси, вы можете использовать адаптер на его textOutput
(при этом text
даст вам "{category}"
для фактических сгенерированных меток, что не очень полезно в этом случае):
var categoryCharacterLimit = 10;
categoryAxis.renderer.labels.template.adapter.add("textOutput", function(text) {
if (text && text.length > categoryCharacterLimit) {
return text.substr(0, categoryCharacterLimit) + "\u2026"; // unicode for ellipsis
}
return text;
});
Учитывая, что всплывающая подсказка по умолчанию будет такой же ширины, как и ее текст, вот быстрое исправление, чтобы ограничить ее ширину, обернуть и центрировать текст:
categoryAxis.tooltip.maxWidth = 200;
categoryAxis.tooltip.label.wrap = true;
categoryAxis.tooltip.label.textAlign = "middle";
Если вы не хотите, чтобы всплывающая подсказка отображалась для уже достаточно коротких меток осей (см. «Один» в моей демонстрации ниже), вы также можете установить там адаптер, чтобы он возвращал пустую строку (""
) (всплывающая подсказка, если текст есть, при возврате в пустую строку условие запуска больше не выполняется):
categoryAxis.tooltip.label.adapter.add("textOutput", function(text) {
if (text && text.length <= categoryCharacterLimit) {
return "";
}
return text;
});
Вот демонстрация со всем, что собрано вместе:
https://codepen.io/team/amcharts/pen/64e5da963cc3822fc95bac15a8f56b09
Если вам нужно настроить внешний вид всплывающей подсказки оси, вот дополнительная информация об этом:
https://www.amcharts.com/docs/v4/concepts/axes/axis-tooltips/#Modifying_tooltip_appearance
https://www.amcharts.com/docs/v4/concepts/series/#Tooltip_colors