配置项如下
var uploadedDataURL = "/asset/get/s/data-1551157482870-q6hT30rbC.png";
var bgImg = '';
var fillImg = '';
var chartData = [{
name: '镇江',
value: 800,
grade: 1
},
{
name: '九江',
value: 720,
grade: 2
},
{
name: '黄石',
value: 680,
grade: 3
},
{
name: '大理',
value: 520,
grade: 4
},
{
name: '贵阳',
value: 460,
grade: 5
},
{
name: '深圳',
value: 380,
grade: 6
},
{
name: '广东',
value: 320,
grade: 7
},
{
name: '南通',
value: 300,
grade: 8
},
{
name: '青海',
value: 298,
grade: 9
},
];
var bgData = [];
var itemData = [];
// 取出每一条数据value,作为显示数据
chartData.forEach(function(items, index) {
itemData.push(items.value);
})
// 取出所有数据最大值,作为背景象形柱图数据
chartData.forEach(function(items, index) {
bgData.push({
name: items.name,
value: Math.max.apply(null, itemData)
});
})
// 所有数据最大值
var maxValue = Math.max.apply(null, itemData);
// 字体 distance放大参数
var scale = 1;
//富文本配置
var rich = {
white: {
color: "#fff",
align: 'left',
fontSize: 10 * scale,
padding: [0, 0]
},
};
var option = {
backgroundColor: '#FFF',
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
},
formatter: function(param) {
//alert(param.data.grade);
//alert(JSON.stringify(param));
var str = "";
str = param[0].data.name + ":" + param[1].data.value +
"</br>排名:" + chartData[param[0].dataIndex].grade;
return str;
},
},
grid: {
left: '3%',
right: '6%',
bottom: '3%',
containLabel: true
},
yAxis: [{
type: 'category',
data: (function(data) {
var arr = [];
data.forEach(function(items) {
arr.push(items.name);
});
return arr;
})(chartData),
boundaryGap: ['20%', '20%'],
splitLine: {
show: false
},
axisLine: {
show: false
},
axisTick: {
show: false
},
axisLabel: {
textStyle: {
fontSize: 10 * scale,
color: '#3fdaff'
},
formatter: function(value) {
if (value != null && value != undefined) {
var valueLength = value.length;
if (valueLength > 5) {
value = value.substring(0, 5) + "...";
}
}
return value;
}
}
}],
xAxis: [{
type: 'value',
splitLine: {
show: false
},
axisLine: {
show: false
},
axisTick: {
show: true,
inside: true,
length: 10 * scale,
lineStyle: {
color: '#0b5263'
}
},
axisLabel: {
textStyle: {
color: '#0b5263',
fontSize: 10 * scale
},
formatter: function(value) {
if (value != null && value != undefined) {
var valueLength = value.length;
if (valueLength > 5) {
value = value.substring(0, 5) + "...";
}
}
return value;
}
},
}],
dataZoom: [ //给x轴设置滚动条
{
start: 0, //默认为0
end: 8, //默认为100
type: 'slider',
show: true,
orient: "vertical",
//xAxisIndex: [0],
handleSize: 0, //滑动条的 左右2个滑动条的大小
width: 15,
left: 10, //左边的距离
top: 10, //上边的距离
bottom: 30, //下边的距离
handleColor: '#99ADC7', //h滑动图标的颜色
handleStyle: {
borderColor: "#99ADC7",
borderWidth: "0",
shadowBlur: 0,
background: "#FFF",
shadowColor: "#ddd",
},
fillerColor: '#99ADC7', //选中范围的填充颜色
borderColor: "#DBDBDB", //边框颜色
backgroundColor: '#FFF', //两边未选中的滑动条区域的颜色
showDataShadow: false, //是否显示数据阴影 默认auto
showDetail: false, //即拖拽时候是否显示详细数值信息 默认true
handleIcon: 'M-292,322.2c-3.2,0-6.4-0.6-9.3-1.9c-2.9-1.2-5.4-2.9-7.6-5.1s-3.9-4.8-5.1-7.6c-1.3-3-1.9-6.1-1.9-9.3c0-3.2,0.6-6.4,1.9-9.3c1.2-2.9,2.9-5.4,5.1-7.6s4.8-3.9,7.6-5.1c3-1.3,6.1-1.9,9.3-1.9c3.2,0,6.4,0.6,9.3,1.9c2.9,1.2,5.4,2.9,7.6,5.1s3.9,4.8,5.1,7.6c1.3,3,1.9,6.1,1.9,9.3c0,3.2-0.6,6.4-1.9,9.3c-1.2,2.9-2.9,5.4-5.1,7.6s-4.8,3.9-7.6,5.1C-285.6,321.5-288.8,322.2-292,322.2z',
filterMode: 'filter',
},
//下面这个属性是里面拖到
{
type: 'inside',
show: true,
//xAxisIndex: [0],
orient: "vertical",
start: 0, //默认为1
end: 8, //默认为100
},
],
series: [
//背景
{
name: 'bg',
type: 'pictorialBar',
barWidth: '45%',
// barGap: '0%',
silent: true,
label: {
normal: {
show: false,
position: "top",
distance: 20 * scale,
formatter: function(params) {
var stuNum = 0;
chartData.forEach(function(value, index, array) {
if (params.name == value.name) {
stuNum = value.value;
}
})
return stuNum + '{white| 人}';
},
textStyle: {
color: "#ffc72b",
fontSize: 10 * scale
},
rich: rich
}
},
symbol: 'image://' + bgImg,
symbolClip: false,
symbolBoundingData: maxValue,
symbolSize: ['100%', 20],
data: bgData,
"symbolRepeat": "fixed",
},
{
name: '数据',
type: 'pictorialBar',
barWidth: '45%',
barGap: '-100%',
data: chartData,
z: 3,
symbol: 'image://' + fillImg,
symbolClip: true,
symbolBoundingData: maxValue,
symbolSize: ['100%', 20],
"symbolRepeat": "fixed",
},
]
};