多系列 bar 和 line 的组合 怎么做
例如上图,单个系列,有百分比, 有区分, 尝试解决 发现 line位置一直不准?
const base64Rect = ''
const imgDom = new Image();
imgDom.src = base64Rect;
var xAxisData = [
'category0','category1',
];
var customData = [
[0, 10, 20, 30, 40,
// 30, 20, 11, 11, 10, 20, 30, 20, 11, 11
],
[1, 10, 20, 30, 40,
// 30, 20, 11, 11, 10, 20, 30, 20, 11, 11
],
[2, 10, 20, 30, 40,
// 30, 20, 11, 11, 10, 20, 30, 20, 11, 11
],
];
var legendData = [
'2010',
'2011',
'2012',
'2013',
'2014',
// '2015',
// '2016',
// '2017',
// '2018',
// '2019',
// '2020',
// '2021',
// '2022',
// '2023',
// '2024',
];
var dataList = [
[10, 10, 10],
[20, 20, 10],
[30, 30, 10],
[40, 40, 10],
[50, 50, 10],
// [11, 11],
// [11, 11],
// [10, 10],
// [20, 20],
// [30, 30],
// [20, 20],
// [11, 11],
// [11, 11],
// [20, 20],
// [30, 30],
// [20, 20],
// [20, 20],
// [30, 30],
];
var encodeY = [1, 2, 3, 4, 5, 6, 7, 8, 9];
function renderItem(params, api) {
// console.log('customData', customData)
var xValue = api.value(0);
var currentSeriesIndices = api.currentSeriesIndices();
console.log('currentSeriesIndices', currentSeriesIndices)
var barLayout = api.barLayout({
barGap: '30%',
barWidth: 16,
barCategoryGap: '20%',
count: dataList.length * 2
});
// console.log('barLayout', barLayout)
var points = [];
for (var i = 0; i < currentSeriesIndices.length; i++) {
var seriesIndex = currentSeriesIndices[i];
if (seriesIndex !== params.seriesIndex) {
// console.log('seriesIndex', seriesIndex)
var point = api.coord([api.value(seriesIndex), xValue]);
point[1] += barLayout[i - 1].offsetCenter + (dataList.length / 2.3) * (8 + 16);
// point[0] += 10;
points.push(point);
}
}
// console.log('points', points)
var style = api.style({
stroke: api.visual('color'),
fill: null
});
return {
type: 'group',
children:[
{
type: 'polyline',
shape: {
points: points
},
itemStyle: {
borderCap: 'square'
},
style
},
].concat(points.map((item, index) => {
return {
type: 'text',
style: {
fill: '#553200',
font: '14px',
text: `${api.value(index+1)}%`,
textAlign: 'right',
textVerticalAlign: 'center',
x: item[0],
y: item[1],
}
}
})),
};
}
option = {
tooltip: {
trigger: 'axis'
},
legend: {
data: legendData
},
yAxis: {
data: xAxisData
},
xAxis: {},
series: [
{
type: 'custom',
name: 'trend',
renderItem: renderItem,
itemStyle: {
borderWidth: 2,
},
encode: {
x: 0,
y: encodeY
},
barWidth: 16,
barGap: '30%',
barCategoryGap: '20%',
data: customData,
z: 100
}
].concat(dataList.map(function (data, index) {
const itemStyle = index === 3 ? {
color: {
image: imgDom,
repeat: 'repeat' // 是否平铺,可以是 'repeat-x', 'repeat-y', 'no-repeat'
},
borderColor: '#C29645'
} : {
color: '#C29645',
borderColor: '#C29645'
}
return {
type: 'bar',
animation: false,
name: legendData[index],
stack: legendData[index],
itemStyle,
barWidth: 16,
barGap: '30%',
barCategoryGap: '20%',
data: index === 4 ? ['-', '-'] : data
};
})).concat(
dataList.map(function (data, index) {
return {
type: 'bar',
name: legendData[index],
stack: legendData[index],
itemStyle : {
color: '#fff',
borderColor: '#C29645'
},
label: {
show: true,
color: '#C29645',
fontWeight: 400,
fontSize: 14,
formatter: '7%',
position: 'right'
},
barGap: '30%',
barWidth: 16,
animation: false,
data: data
};
})
)
};
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
你可以用下 Charts4 的数据集看下
https://echarts.apache.org/ha...