要在amCharts 4中访问当前悬停的系列数据和颜色,可以使用amCharts的事件处理器。以下是一种解决方法的代码示例:
// 创建图表
var chart = am4core.create("chartdiv", am4charts.XYChart);
// 添加数据
chart.data = [{
category: "一月",
value1: 50,
value2: 100,
color: chart.colors.next()
}, {
category: "二月",
value1: 200,
value2: 150,
color: chart.colors.next()
}, {
category: "三月",
value1: 100,
value2: 80,
color: chart.colors.next()
}];
// 创建坐标轴和系列
var categoryAxis = chart.xAxes.push(new am4charts.CategoryAxis());
categoryAxis.dataFields.category = "category";
var valueAxis = chart.yAxes.push(new am4charts.ValueAxis());
var series1 = chart.series.push(new am4charts.ColumnSeries());
series1.dataFields.valueY = "value1";
series1.dataFields.categoryX = "category";
series1.columns.template.tooltipText = "{categoryX}: [bold]{valueY}[/]";
series1.columns.template.fill = am4core.color("#888"); // 默认颜色
var series2 = chart.series.push(new am4charts.ColumnSeries());
series2.dataFields.valueY = "value2";
series2.dataFields.categoryX = "category";
series2.columns.template.tooltipText = "{categoryX}: [bold]{valueY}[/]";
series2.columns.template.fill = am4core.color("#444"); // 默认颜色
// 添加事件处理器
series1.columns.template.events.on("over", function(ev) {
var series = ev.target;
series.columns.each(function(column) {
column.fill = am4core.color("#f00"); // 悬停时的颜色
});
});
series1.columns.template.events.on("out", function(ev) {
var series = ev.target;
series.columns.each(function(column) {
column.fill = am4core.color("#888"); // 恢复默认颜色
});
});
series2.columns.template.events.on("over", function(ev) {
var series = ev.target;
series.columns.each(function(column) {
column.fill = am4core.color("#0f0"); // 悬停时的颜色
});
});
series2.columns.template.events.on("out", function(ev) {
var series = ev.target;
series.columns.each(function(column) {
column.fill = am4core.color("#444"); // 恢复默认颜色
});
});
在上面的示例中,我们创建了一个包含两个系列的柱状图。当悬停在系列上时,我们改变了柱状图的颜色。当鼠标离开系列时,颜色将恢复为默认颜色。
可以根据需要自定义悬停时的颜色,并在事件处理器中进行更多的操作。