let app = new Vue({
el: "#app",
data() {
return {
config5: {
waitTime: 2000,
rowNum: 4,
header: ["单位名称", "平均工资涨幅", ''],
data: [
["山焦财务", '-12%'],
["山焦担保", '4%'],
["山焦股份", '6%'],
["山焦国华", '20%'],
["山焦国华", '9%'],
["山焦财务", '-1%'],
["山焦担保", '4%'],
["山焦股份", '6%'],
["山焦国华", '20%'],
["山焦国华", '9%']
],
align: ["center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
config1: {
waitTime: 2000,
rowNum: 1,
data: [
["山焦财务", '-12%'],
["山焦担保", '4%'],
["山焦股份", '6%'],
["山焦国华", '20%'],
["山焦国华", '9%'],
["山焦财务", '-1%'],
["山焦担保", '4%'],
["山焦股份", '6%'],
["山焦国华", '20%'],
["山焦国华", '9%']
],
align: ["center", "center"],
oddRowBGC: "#3B9DEE",
evenRowBGC: "#1E5389",
},
configLast1: {
waitTime: 2000,
header: ["项目名称"],
rowNum: 2,
data: [
["大型矿井综合掘进机器人",],
["废弃矿山遗留资源及地下空间开发利用关键技术研究",],
["遗留难采煤炭资源安全绿色高回收率开采关键技术研究与示范",],
["山西煤炭资源高效保水开采技术与示范",],
["炼焦煤采洗配销一体化关键技术研究",],
["高瓦斯矿井110工法回采工作面瓦斯与自然发火共治关键技术示范研究",],
],
align: ["center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
configLast2: {
waitTime: 2000,
header: ["合作高校"],
rowNum: 2,
data: [
["太原理工大学",],
["北京大学",],
["安徽理工大学",],
["太原理工大学",],
["中国科学技术大学",],
["太原理工大学",],
["中国矿业大学",],
],
align: ["center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
configLast3: {
waitTime: 2000,
header: ["合作类型"],
rowNum: 2,
data: [
["国家重点研发计划项目",],
["山西省揭榜招标项目",],
["山西省科技重大专项",],
["山西省揭榜招标项目",],
["山西省重点研发项目",],
["山西省重点研发项目",],
],
align: ["center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
configLast4: {
waitTime: 2000,
header: ["主要成效"],
rowNum: 2,
data: [
["综合掘进机器人系统",],
["建立废弃矿山煤层气地面抽采和废弃矿山地下空间利用先导工程",],
["遗留难采煤炭资源赋存状况的全方位勘探新技术,超前注浆封堵新材料、新装置与新工艺。",],
["底板阻水性能评价方法体系,研发承压水突水机理与岩层改性再造技术,形成了一套高效承压水上采煤保水开采方案",],
["开展煤质检测和配煤技术研究,开发配煤模型及智能配煤算法",],
["解决了瓦斯超限问题",],
],
align: ["center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
configOrg: {
waitTime: 2000,
rowNum: 2,
data: [
["金融资本公司", '山焦担保', '上级调整', '2023-06-01'],
["山焦统配", '山焦统配', '组织新设', '2023-05-01'],
["汾西矿业集团", '灵石县富威橡胶', '组织更名', '2023-05-01'],
["焦煤置业", '海南科思实业有限公司', '组织停用', '2023-04-04'],
["西山煤电", '房城建安有限公司', '组织停用', '2023-04-01'],
["霍州煤电", '建筑建材公司', '组织停用', '2023-03-25'],
["霍州煤电", '设备租赁分公司', '组织停用', '2023-02-15'],
],
align: ["center", "center", "center", "center", "center"],
oddRowBGC: "#3B9DEE",
evenRowBGC: "#1E5389",
},
configChange: {
waitTime: 2000,
header: ["姓名", "调出单位", "调入单位", "调动时间", '变动状态', ""],
rowNum: 4,
data: [
["段树成", '山煤国际', '招标公司', '2023-07-04', '调动完成'],
["蒲立志", '焦煤置业', '山煤国际', '2023-07-01', '调动中'],
["侯利强", '霍州煤电', '西山煤电', '2023-07-01', '调动中'],
["王国明", '西山煤电', '华晋焦煤', '2023-06-19', '调动完成'],
["梁婧", '西山煤电', '物资装备公司', '2023-06-01', '调动完成'],
["赵越", '山煤国际', '招标公司', '2023-06-01', '调动完成'],
["董然", '西山煤电', '人力资源公司', '2023-06-01', '调动完成'],
["解红梅", '西山煤电', '投资公司', '2023-06-01', '调动完成'],
],
align: ["center", "center", "center", "center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
configMark: {
waitTime: 2000,
header: ["单位名称", "人员数量", "月份", "预警项", ""],
rowNum: 4,
data: [
["西山煤电", "71", "3月", "薪资低于4000元"],
["汾西矿业", "1896", "3月", "薪资低于4000元"],
["霍州煤电", "847", "3月", "薪资低于4000元"],
["山煤国际", "514", "3月", "薪资低于4000元"],
["华晋焦煤", "13", "3月", "薪资低于4000元"],
],
align: ["center", "center", "center", "center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
config2: {
waitTime: 2000,
header: ["单位名称", "已算薪组织", "未算薪组织", "算薪进度百分比", ""],
rowNum: 4,
data: [
["西山煤电", '290', '46', '86%'],
["汾西矿业", '10', '38', '21%'],
["霍州煤电", '314', '3', '99%'],
["山煤国际", '16', '35', '31%'],
["华晋焦煤", '7', '1', '87%'],
],
align: ["center", "center", "center", "center", "center"],
headerBGC: "#153A62",
oddRowBGC: "#061F42",
evenRowBGC: "#0C284A",
},
fIndex: 0,
fList: [
{
project: "大型矿井综合掘进机器人",
school: "太原理工大学, 北京大学",
type: "国家重点研发计划项目",
merits: "综合掘进机器人系统"
},
{
project: "废弃矿山遗留资源及地下空间开发利用关键技术研究",
school: "安徽理工大学,太原理工大学,中国科学技术大学",
type: "山西省揭榜招标项目",
merits: "建立废弃矿山煤层气地面抽采和废弃矿山地下空间利用先导工程"
},
{
project: "遗留难采煤炭资源安全绿色高回收率开采关键技术研究与示范",
school: "太原理工大学",
type: "山西省科技重大专项",
merits: "遗留难采煤炭资源赋存状况的全方位勘探新技术,超前注浆封堵新材料、新装置与新工艺。"
},
{
project: "山西煤炭资源高效保水开采技术与示范",
school: "中国矿业大学",
type: "山西省揭榜招标项目",
merits: "底板阻水性能评价方法体系,研发承压水突水机理与岩层改性再造技术,形成了一套高效承压水上采煤保水开采方案"
},
{
project: "炼焦煤采洗配销一体化关键技术研究",
school: "太原理工大学",
type: "山西省重点研发项目",
merits: "开展煤质检测和配煤技术研究,开发配煤模型及智能配煤算法"
},
{
project: "高瓦斯矿井110工法回采工作面瓦斯与自然发火共治关键技术示范研究",
school: "太原理工大学",
type: "山西省重点研发项目",
merits: "解决了瓦斯超限问题"
},
],
salaryFlag: false,
pdfFlag: true,
eChartsBig: undefined,
LineChart: undefined,
LineElse: undefined,
time2: undefined,
leftEcharts5: undefined,
mobilizeFL: undefined,
industry: {
x: ["矿井", "选煤厂", "火电厂", "清洁能源厂", "焦化厂"],
y: [151, 50, 6, 32, 4]
},
twoBar: undefined,
echartTwoList: {
x: ["回采", "掘进", "开拓工人", "运输", "机电", "通风安全", "安拆", "露天", "其他"],
y: [11556, 15008, 6073, 10562, 8492, 10776, 1553, 119, 3668]
},
echartTwoList2: {
x: ["煤炭洗选人员", "焦炭化工人员", "民爆人员", "金融人员", "煤炭销售人员"],
y: [10115, 6327, 2301, 104, 2604]
},
echartsTwoBar2: {
y: ["4940", "18170", "51812", "38430", '18329', '17745', '31827'],
x: ["5年以下", "6-10年", "11-15年", "16-20年", '21-25年', '26-30年', '30年以上']
},
echartsTwoBar1: {
y: ["15990", "38872", "35952", "27063", '31424', '26099', '11401'],
x: ["30岁以下", "31-35岁", "36-40岁", "41-45岁", '46-50岁', '51-55岁', '55岁以上']
},
// organizationList: {
// x: ["集团机构数", "共享中心数", "事业部数", "二级组织数", "三级组织数", "四级组织数"],
// y: [18, 12, 5, 22, 316, 496]
// },
orgIndex: 0,
organizationList: [
{
name: "集团机构数",
flag: true,
value: 18
}, {
name: "共享中心数",
flag: false,
value: 12
}, {
name: "事业部数",
flag: false,
value: 5
}, {
name: "二级组织数",
flag: false,
value: 22
}, {
name: "三级组织数",
flag: false,
value: 316
}, {
name: "四级组织数",
flag: false,
value: 496
},
],
twoIndex: 1,
time2: 1,
time3: 1,
time4: 1,
isShowMark: false,
changeFlag: false,
userFlag: true,
salaryIndex: 1,
sx: [],
xy: [],
fx: [],
fy1: [],
fy2: [],
fy3: [],
fy4: [],
fy5: [],
}
},
mounted() {
this.$nextTick(() => {
this.sx = spArr(salaryList.x, 8)
this.sy = spArr(salaryList.y, 8)
this.fx = spArr(mobilizeList.x, 8)
this.fy1 = spArr(mobilizeList.y1, 8)
this.fy2 = spArr(mobilizeList.y2, 8)
this.fy3 = spArr(mobilizeList.y3, 8)
this.fy4 = spArr(mobilizeList.y4, 8)
this.fy5 = spArr(mobilizeList.y5, 8)
// let organization = this.$refs.organization
// this.initOrganization(organization, "", this.organizationList)
let mobilize = this.$refs.mobilize
this.initEchartStack(mobilize, { x: this.fx[0], y1: this.fy1[0], y2: this.fy2[0], y3: this.fy3[0], y4: this.fy4[0], y5: this.fy5[0] })
let industry = this.$refs.industry
this.initOrganizationElse(industry, "", this.industry, "")
let sequence = this.$refs.sequence
this.initBarEcharts(sequence, { x: ["管理序列", "技术序列", "操作序列"], y1: [34242, 18547, 134012], y2: [28993, 19411, 126807] }, ["当前数", "同期数"])
let serviceAge = this.$refs.serviceAge
this.initLineEcharts(serviceAge, this.echartsTwoBar1)
let level = this.$refs.level
this.initLineElseEcharts(level, levelList)
let initChartR1 = this.$refs.initChartR1
this.initChartR1(initChartR1)
let initChartsBig = this.$refs.initChartsBig
this.initChartsBig(initChartsBig)
let leftEnd = this.$refs.leftEnd
this.initBarEchartsElse(leftEnd, leftEndList, ["累计平均工资", "同期累计平均工资"])
let echarts90 = this.$refs.echarts90
this.initLineElseEchartsR(echarts90, { x: this.sx[0], y: this.sy[0] })
let student = this.$refs.student
this.initEchartsBar(student, schoolList,)
let works = this.$refs.works
this.initBarCharts(works, worksList)
let efficiency = this.$refs.efficiency
this.initBarChartsElse(efficiency, efficiencyList, "吨/工", { name: "行业线", value: 8.2 })
let whole = this.$refs.whole
this.initBarChartsElse(whole, wholeList, "吨/人", { name: "标杆矿井线", value: 1800 })
let buffer = this.$refs.buffer
this.initStereoscopic(buffer,userList)
// let share = this.$refs.share
// this.initHorizontalBar(share)
let el = this.$refs.container
this.initProvinceChart(el)
let echartTwo = this.$refs.echartTwo
this.initTwoBarEcharts(echartTwo, this.echartTwoList)
this.timeNs()
this.timePractice()
this.timeSy()
setInterval(_ => {
if (this.fIndex == this.fList.length - 1) {
this.fIndex = 0
} else {
this.fIndex = this.fIndex + 1
}
this.organizationList.forEach(item => {
item.flag = false
})
if (this.orgIndex == this.organizationList.length - 1) {
this.orgIndex = 0
} else {
this.orgIndex = this.orgIndex + 1
}
this.organizationList[this.orgIndex].flag = true
}, 2000)
})
},
methods: {
// 针对学历结构的定时器
timeNs() {
let that = this;
this.time2 = setInterval(() => {
this.time2 && clearInterval(this.time2);
this.timeNs();
that.leftEcharts5.dispose();
let initChartsBig = that.$refs.initChartsBig
that.initChartsBig(initChartsBig)
}, 15000);
},
timeSy() {
let that = this;
this.time4 = setInterval(() => {
this.time4 && clearInterval(this.time4);
this.timeSy();
that.LineElse.dispose();
that.mobilizeFL.dispose();
let echarts90 = this.$refs.echarts90
let mobilize = this.$refs.mobilize
if (that.salaryIndex == that.sx.length) {
that.salaryIndex = 0
}
this.initEchartStack(mobilize, { x: this.fx[that.salaryIndex], y1: this.fy1[that.salaryIndex], y2: this.fy2[that.salaryIndex], y3: this.fy3[that.salaryIndex], y4: this.fy4[that.salaryIndex] })
this.initLineElseEchartsR(echarts90, { x: that.sx[that.salaryIndex], y: that.sy[that.salaryIndex] })
that.salaryIndex += 1
}, 10000);
},
// 针对从业人员类别的定时器
timePractice() {
let that = this;
this.time3 = setInterval(() => {
this.time3 && clearInterval(this.time3);
this.timePractice();
that.twoBar.dispose();
that.LineChart.dispose();
let echartTwo = that.$refs.echartTwo
let serviceAge = that.$refs.serviceAge
if (that.twoIndex == 1) {
that.initTwoBarEcharts(echartTwo, that.echartTwoList)
that.initLineEcharts(serviceAge, that.echartsTwoBar1)
that.twoIndex = 2
} else {
that.initTwoBarEcharts(echartTwo, that.echartTwoList2)
that.initLineEcharts(serviceAge, that.echartsTwoBar2)
that.twoIndex = 1
}
this.userFlag = !this.userFlag
}, 15000);
},
initOrganization(el, title = "", data = { x: ["集团本部", "山焦财务", "山焦担保", "山焦股份", "山焦国华", "山焦机电", "山焦人力", "山焦民爆", "山焦事业", "山焦投资"], y: [0, 680, 562, 268, 717, 843, 987, 126, 723, 569] }, unit = "") {
let chart = echarts.init(el);
let option = {
grid: {
top: 25,
right: 15,
left: "15%",
bottom: "27%",
},
grid: {
top: 30,
right: 20,
left: 105,
bottom: 40,
},
tooltip: {
show: true,
trigger: "axis",
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
// 坐标轴指示器,坐标轴触发有效
type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
},
},
xAxis: {
data: data.x,
axisTick: {
show: false,
},
// x轴的字体颜色
axisLabel: {
interval: 0,
// rotate: 40,
textStyle: {
color: "white",
fontSize: 26,
},
},
//y轴线的颜色以及宽度
axisLine: {
show: true,
lineStyle: {
color: "#1E5389",
width: 1,
type: "solid",
},
},
},
yAxis: {
name: unit,
type: "log",
axisTick: {
lineStyle: {
color: "#18416F",
},
},
// y轴的字体颜色
axisLabel: {
textStyle: {
color: "white",
fontSize: 20,
},
},
nameTextStyle: {
fontSize: 20,
},
splitLine: {
show: true,
lineStyle: {
color: "#204561",
width: 1,
type: "dotted",
},
},
//y轴线的颜色以及宽度
axisLine: {
show: true,
lineStyle: {
color: "#1E5389",
width: 1,
type: "solid",
},
},
},
series: [
{
name: "",
type: "line",
smooth: true,
showSymbol: true, // 节点长显
symbol: 'image://' + '',
symbolSize: 30,
data: data.y,
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: "#40A9FF",
},
{
offset: 1,
color: "#051F41",
},
],
false
),
},
},
itemStyle: {
normal: {
color: "#40A9FF",
},
},
lineStyle: {
normal: {
width: 2,
},
},
}
],
};
let that = this;
chart.setOption(option);
chart.on('click', function (param) {
that.isShowMark = true
that.salaryFlag = false
that.pdfFlag = true
})
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initOrganizationElse(el, title = "", data = { x: ["集团本部", "山焦财务", "山焦担保", "山焦股份", "山焦国华", "山焦机电", "山焦人力", "山焦民爆", "山焦事业", "山焦投资"], y: [0, 680, 562, 268, 717, 843, 987, 126, 723, 569] }, unit = "") {
let chart = echarts.init(el);
let option = {
title: {
show: false,
top: 5,
left: "center",
text: title,
textStyle: {
color: "#5EB7FF",
fontWeight: "normal",
fontSize: 32
}
},
grid: {
top: 50,
right: 40,
left: 105,
bottom: 40,
},
tooltip: {
show: true,
trigger: "axis",
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
// 坐标轴指示器,坐标轴触发有效
type: "shadow", // 默认为直线,可选为:'line' | 'shadow'
},
},
xAxis: {
data: data.x,
axisTick: {
show: false,
},
// x轴的字体颜色
axisLabel: {
interval: 0,
// rotate: 40,
textStyle: {
color: "white",
fontSize: 26,
},
},
//y轴线的颜色以及宽度
axisLine: {
show: true,
lineStyle: {
color: "#1E5389",
width: 1,
type: "solid",
},
},
},
yAxis: {
name: unit,
axisTick: {
lineStyle: {
color: "#18416F",
},
},
// y轴的字体颜色
axisLabel: {
textStyle: {
color: "white",
fontSize: 20,
},
},
nameTextStyle: {
fontSize: 20,
color: "white",
},
splitLine: {
show: true,
lineStyle: {
color: "#204561",
width: 1,
type: "dotted",
},
},
//y轴线的颜色以及宽度
axisLine: {
show: true,
lineStyle: {
color: "#1E5389",
width: 1,
type: "solid",
},
},
},
series: [
{
name: "",
type: "bar",
data: data.y,
showBackground: true,
backgroundStyle: {
color: "#18416F",
},
barWidth: "20%",
itemStyle: {
color: new echarts.graphic.LinearGradient(0, 1, 0, 0, [
{
offset: 0,
color: "#02355C",
}, //柱图渐变色
{
offset: 1,
color: "#40A9FF",
},
]),
},
}
],
legend: {
data: ["入池人数", "出池人数"],
textStyle: {
// 图列内容样式
color: "#fff", // 字体颜色
// fontSize: "10",
},
right: 30,
icon: "roundRect",
// 小图标的宽高
itemHeight: 5,
},
};
let that = this;
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initLineEcharts(el, data) {
this.LineChart = echarts.init(el);
let option = {
grid: {
top: 25,
right: 15,
left: "15%",
bottom: "27%",
},
tooltip: {
show: true,
trigger: "axis",
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
lineStyle: {
color: "#ddd",
},
},
},
legend: {
textStyle: {
// 图列内容样式
color: "#fff", // 字体颜色
// fontSize: "10",
},
right: 30,
icon: "roundRect",
// 小图标的宽高
itemHeight: 5
},
xAxis: {
type: "category",
data: data.x,
boundaryGap: false,
splitLine: {
show: false,
interval: "auto",
},
axisTick: {
show: false,
},
axisLine: {
lineStyle: {
color: "#7ECEF4",
},
},
axisLabel: {
interval: 0,
rotate: 25,
textStyle: {
fontSize: 26,
color: "#fff",
},
},
},
yAxis: {
type: "value",
splitLine: {
show: true,
lineStyle: {
color: "#204561",
width: 1,
type: "dotted",
},
},
axisTick: {
show: false,
},
axisLine: {
lineStyle: {
color: "#7ECEF4",
},
},
axisLabel: {
margin: 10,
textStyle: {
fontSize: 20,
color: "#fff",
},
},
},
series: [
{
name: "",
type: "line",
smooth: false,
showSymbol: true, // 节点长显
symbol: 'image://' + '',
symbolSize: 30,
data: data.y,
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: "#45DAD1",
},
{
offset: 1,
color: "#051F41",
},
],
false
),
},
},
itemStyle: {
normal: {
color: "#45DAD1",
},
},
lineStyle: {
normal: {
width: 2,
},
},
}
],
};
this.LineChart.setOption(option);
tools.loopShowTooltip(this.LineChart, option, {
nterval: 2000,
loopSeries: true,
});
},
initLineElseEcharts(el, data) {
let chart = echarts.init(el);
let option = {
grid: {
top: 25,
right: 15,
left: "15%",
bottom: "27%",
},
tooltip: {
show: true,
trigger: "axis",
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
lineStyle: {
color: "#ddd",
},
},
},
legend: {
textStyle: {
// 图列内容样式
color: "#fff", // 字体颜色
// fontSize: "10",
},
right: 30,
icon: "roundRect",
// 小图标的宽高
itemHeight: 5
},
xAxis: {
type: "category",
data: data.x,
boundaryGap: false,
splitLine: {
show: false,
interval: "auto",
},
axisTick: {
show: false,
},
axisLine: {
lineStyle: {
color: "#7ECEF4",
},
},
axisLabel: {
interval: 0,
rotate: 40,
margin: 10,
textStyle: {
fontSize: 26,
color: "#fff",
},
},
},
yAxis: {
type: "value",
splitLine: {
show: true,
lineStyle: {
color: "#204561",
width: 1,
type: "dotted",
},
},
axisTick: {
show: false,
},
axisLine: {
lineStyle: {
color: "#7ECEF4",
},
},
axisLabel: {
margin: 10,
textStyle: {
fontSize: 20,
color: "#fff",
},
},
},
series: [
{
name: "",
type: "line",
smooth: false,
showSymbol: true, // 节点长显
symbol: 'image://' + '',
symbolSize: 30,
data: data.y,
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: "#40A9FF",
},
{
offset: 1,
color: "#051F41",
},
],
false
),
},
},
itemStyle: {
normal: {
color: "#40A9FF",
},
},
lineStyle: {
normal: {
width: 2,
},
},
}
],
};
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initLineElseEchartsR(el, data) {
this.LineElse = echarts.init(el);
let option = {
grid: {
top: 15,
right: "5%",
left: "5%",
bottom: "22%",
},
tooltip: {
show: true,
trigger: "axis",
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
lineStyle: {
color: "#ddd",
},
},
formatter: "{b} : {c} %"
},
legend: {
textStyle: {
// 图列内容样式
color: "#fff", // 字体颜色
// fontSize: "10",
},
right: 30,
icon: "roundRect",
// 小图标的宽高
itemHeight: 5
},
xAxis: {
type: "category",
data: data.x,
boundaryGap: false,
splitLine: {
show: false,
interval: "auto",
},
axisTick: {
show: false,
},
axisLine: {
lineStyle: {
color: "#7ECEF4",
},
},
axisLabel: {
interval: 0,
textStyle: {
fontSize: 26,
color: "#fff",
},
},
},
yAxis: {
type: "value",
min: 80,
max: 100,
splitNumber: 3,
interval: 10,
splitLine: {
show: true,
lineStyle: {
color: "#204561",
width: 1,
type: "dotted",
},
},
axisTick: {
show: false,
},
axisLine: {
lineStyle: {
color: "#7ECEF4",
},
},
axisLabel: {
margin: 10,
textStyle: {
fontSize: 20,
color: "#fff",
},
},
},
series: [
{
name: "",
type: "line",
smooth: false,
showSymbol: true, // 节点长显
symbol: 'image://' + '',
symbolSize: 30,
data: data.y,
areaStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: "#40A9FF",
},
{
offset: 1,
color: "#051F41",
},
],
false
),
},
},
itemStyle: {
normal: {
color: "#40A9FF",
},
},
lineStyle: {
normal: {
width: 2,
},
},
}
],
};
this.LineElse.setOption(option);
tools.loopShowTooltip(this.LineElse, option, {
nterval: 2000,
loopSeries: true,
});
},
initChartR1(el) {
let myChart = echarts.init(el)
let objData = {}
echarts2.forEach(item=>{
objData[item.name] = item.value
})
let option = {
tooltip: {
show: true,
trigger: "item",
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
lineStyle: {
color: "#ddd",
},
},
formatter: "{b} : {c}({d}%)"
},
legend: {
top: 'center',
orient: 'vertical',
left: '60%',
textStyle: {
fontSize: 30,
color: '#9DB9EB',
},
formatter: function (name) {
console.log(name);
return (
"{title|" + name + "} {value|" + objData[name] + "} {title|人}"
);
},
textStyle: {
rich: {
title: {
fontSize: 26,
lineHeight: 50,
color: "#fff",
},
value: {
fontSize: 26,
fontWeight: "bolder",
lineHeight: 50,
color: "#FFAD05",
},
},
},
},
graphic: {
elements: [{
type: 'image',//需要填充图片,配置image,如果不需要图片可以配置其他的, text, circle, sector, ring, polygon, polyline, rect, line, bezierCurve, arc, group,
style: {
image: './images/pie-back.png', //这里添加图片地址
width: 120,
height: 120
},
left: '30%',//
top: 'middle' //配置图片居中
}]
},
series: [
{
name: '',
type: 'pie',
radius: ['40%', '50%'],
center: ["37%", "50%"],
labelLine: {
normal: {
show: false,
length: 20,
length2: 55
},
emphasis: {
show: false
}
},
label: {
normal: {
show: false,
formatter: "{b}",
textStyle: {
fontSize: 28,
},
position: 'outside'
},
emphasis: {
show: false
}
},
data: echarts2,
itemStyle: {
normal: {
color: function (colors) {
var colorList = [
"#eeee36", "#6336df", "#2edb8e", "#44cdf3", "#fcbf45"
];
return colorList[colors.dataIndex];
}
},
}
},
],
}
myChart.setOption(option)
tools.loopShowTooltip(myChart, option, {
nterval: 2000,
loopSeries: true,
});
},
initChartsBig(el) {
this.leftEcharts5 = echarts.init(el);
let option = {
color: ["#eeee36", "#6336df", "#2edb8e", "#44cdf3", "#fcbf45"],
grid: {
left: -100,
top: 50,
bottom: 10,
right: 10,
containLabel: true
},
tooltip: {
trigger: 'item',
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
formatter: "{b} : {c} ({d}%)"
},
legend: {
show: false,
type: "scroll",
orient: "vartical",
// x: "right",
top: "center",
right: "10",
// bottom: "0%",
itemWidth: 30,
itemHeight: 12,
itemGap: 16,
textStyle: {
color: '#A3E2F4',
fontSize: 30,
fontWeight: 0
},
data: ['研究生及以上', '大学', '大专', '中专、技校', '初中及以下']
},
polar: {},
angleAxis: {
interval: 1,
type: 'category',
data: [],
z: 10,
axisLine: {
show: false,
lineStyle: {
color: "#0B4A6B",
width: 1,
type: "solid"
},
},
axisLabel: {
interval: 0,
show: true,
color: "#0B4A6B",
margin: 8,
fontSize: 16
},
},
radiusAxis: {
min: 40,
max: 120,
interval: 20,
axisLine: {
show: false,
lineStyle: {
color: "#0B3E5E",
width: 1,
type: "solid"
},
},
axisLabel: {
formatter: '{value} %',
show: false,
padding: [0, 0, 20, 0],
color: "#0B3E5E",
fontSize: 26,
},
splitLine: {
lineStyle: {
color: "#0B3E5E",
width: 2,
type: "solid"
}
}
},
calculable: true,
series: [{
type: 'pie',
radius: ["5%", "10%"],
hoverAnimation: false,
labelLine: {
normal: {
show: false,
length: 30,
length2: 55
},
emphasis: {
show: false
}
},
data: [{
name: '',
value: 0,
tooltip: { show: false },
itemStyle: {
normal: {
color: "#0B4A6B"
}
}
}]
}, {
type: 'pie',
radius: ["90%", "95%"],
hoverAnimation: false,
labelLine: {
normal: {
show: false,
length: 30,
length2: 55
},
emphasis: {
show: false
}
},
name: "",
data: [{
name: '',
value: 0,
tooltip: { show: false },
itemStyle: {
normal: {
color: "#0B4A6B"
}
}
}]
}, {
stack: 'a',
type: 'pie',
radius: ['20%', '80%'],
roseType: 'area',
zlevel: 10,
label: {
normal: {
show: true,
formatter: "{b}",
textStyle: {
fontSize: 28,
},
position: 'outside'
},
emphasis: {
show: true
}
},
labelLine: {
normal: {
show: true,
length: 10,
length2: 55
},
emphasis: {
show: false
}
},
data: [{
value: 3103,
name: '研究生及以上'
},
{
value: 42543,
name: '大学'
},
{
value: 46669,
name: '大专'
},
{
value: 69437,
name: '中专、技校'
},
{
value: 25049,
name: '初中及以下'
}
]
},]
}
this.leftEcharts5.setOption(option, {
notMerge: true,
notMerge: false,
});
tools.loopShowTooltip(this.leftEcharts5, option, {
nterval: 2000,
loopSeries: true,
});
},
initBarCharts(el, data) {
let chart = echarts.init(el);
var option = {
tooltip: { //提示框组件
trigger: 'axis',
formatter: '{b}
{a0}: {c0}
{a1}: {c1}',
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
type: 'shadow',
label: {
backgroundColor: '#6a7985'
}
},
textStyle: {
color: '#fff',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
}
},
grid: {
left: '9%',
right: '15%',
bottom: '10%',
top: 50,
},
legend: {//图例组件,颜色和名字
right: 10,
top: 0,
itemGap: 16,
itemWidth: 18,
itemHeight: 10,
data: [
{
name: '目标值',
}, {
name: '实际值',
//icon:'image://../wwwroot/js/url2.png', //路径
}
],
textStyle: {
color: '#a8aab0',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
}
},
xAxis: [
{
type: 'category',
boundaryGap: true,//坐标轴两边留白
data: data.x,
axisLabel: { //坐标轴刻度标签的相关设置。
interval: 0,//设置为 1,表示『隔一个标签显示一个标签』
margin: 15,
textStyle: {
color: '#fff',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 26,
}
},
axisTick: {//坐标轴刻度相关设置。
show: false,
},
axisLine: {//坐标轴轴线相关设置
lineStyle: {
color: '#fff',
opacity: 0.2
}
},
splitLine: { //坐标轴在 grid 区域中的分隔线。
show: false,
}
}
],
yAxis: [
{
name: "万元/人",
type: 'value',
splitNumber: 5,
axisLabel: {
textStyle: {
color: '#FFF',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 20,
}
},
nameTextStyle: {
color: "#a8aab0",
fontSize: 30
},
axisLine: {
show: false
},
axisTick: {
show: false
},
splitLine: {
show: false,
lineStyle: {
color: ['#fff'],
}
}
}
],
series: [
{
name: '目标值',
type: 'bar',
data: data.y2,
barWidth: 20,
barGap: 0.2,//柱间距离
label: {//图形上的文本标签
normal: {
show: false,
position: 'top',
textStyle: {
color: '#a8aab0',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
},
},
},
itemStyle: {//图形样式
normal: {
barBorderRadius: [10, 10, 0, 0],
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#9e65ea',
},
{
offset: 1,
color: '#051F41',
}], false),
},
},
},
{
name: '实际值',
type: 'bar',
data: data.y1,
barWidth: 20,
barGap: 0,//柱间距离
label: {//图形上的文本标签
normal: {
show: false,
position: 'top',
textStyle: {
color: '#a8aab0',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
},
},
},
itemStyle: {//图形样式
normal: {
barBorderRadius: [10, 10, 0, 0],
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 1, color: '#051F41'
}, {
offset: 0, color: '#84fab0'
}], false),
},
},
markLine: {
symbol: ['none'],
silent: true,
data: [{
yAxis: 15.3,
name: "社会劳动生产率",
lineStyle: {
normal: {
type: "dashed",
width: 3,
color: '#0bff68'
}
},
label: {
show: true,
distance: 20,
fontWeight: "lighter",
formatter: "社会劳动生产率",
},
}, {
yAxis: 50.8,
lineStyle: {
normal: {
type: "dashed",
width: 3,
color: 'rgb(0, 255, 242)'
}
},
label: {
show: true,
distance: 20,
fontWeight: "lighter",
formatter: "省属企业平均劳动生产率",
},
}, {
yAxis: 69.2,
lineStyle: {
normal: {
type: "dashed",
width: 3,
color: '#f9d423'
}
},
label: {
show: true,
distance: 20,
fontWeight: "lighter",
formatter: "央企平均劳动生产率",
},
},]
},
}
]
};
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initBarChartsElse(el, data, name, lineInfo) {
let chart = echarts.init(el);
var option = {
tooltip: { //提示框组件
trigger: 'axis',
formatter: '{b}
{a0}: {c0}
{a1}: {c1}',
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: {
type: 'shadow',
label: {
backgroundColor: '#6a7985'
}
},
textStyle: {
color: '#fff',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
}
},
grid: {
left: '10%',
right: '15%',
bottom: '10%',
top: 50,
},
legend: {//图例组件,颜色和名字
right: 10,
top: 0,
itemGap: 16,
itemWidth: 18,
itemHeight: 10,
data: [
{
name: '目标值',
}, {
name: '实际值',
//icon:'image://../wwwroot/js/url2.png', //路径
}
],
textStyle: {
color: '#a8aab0',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
}
},
xAxis: [
{
type: 'category',
boundaryGap: true,//坐标轴两边留白
data: data.x,
axisLabel: { //坐标轴刻度标签的相关设置。
interval: 0,//设置为 1,表示『隔一个标签显示一个标签』
margin: 15,
textStyle: {
color: '#fff',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 26,
}
},
axisTick: {//坐标轴刻度相关设置。
show: false,
},
axisLine: {//坐标轴轴线相关设置
lineStyle: {
color: '#fff',
opacity: 0.2
}
},
splitLine: { //坐标轴在 grid 区域中的分隔线。
show: false,
}
}
],
yAxis: [
{
name,
type: 'value',
splitNumber: 5,
axisLabel: {
textStyle: {
color: '#FFF',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 20,
}
},
nameTextStyle: {
color: "#a8aab0",
fontSize: 30
},
axisLine: {
show: false
},
axisTick: {
show: false
},
splitLine: {
show: false,
lineStyle: {
color: ['#fff'],
}
}
}
],
series: [
{
name: '目标值',
type: 'bar',
data: data.y2,
barWidth: 20,
barGap: 0,//柱间距离
label: {//图形上的文本标签
normal: {
show: false,
position: 'top',
textStyle: {
color: '#a8aab0',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
},
},
},
itemStyle: {//图形样式
normal: {
barBorderRadius: [10, 10, 0, 0],
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
{
offset: 0,
color: '#9e65ea',
},
{
offset: 1,
color: '#051F41',
}], false),
},
},
},
{
name: '实际值',
type: 'bar',
data: data.y1,
barWidth: 20,
barGap: 0,//柱间距离
label: {//图形上的文本标签
normal: {
show: false,
position: 'top',
textStyle: {
color: '#a8aab0',
fontStyle: 'normal',
fontFamily: '微软雅黑',
fontSize: 30,
},
},
},
itemStyle: {//图形样式
normal: {
barBorderRadius: [10, 10, 0, 0],
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 1, color: '#051F41'
}, {
offset: 0, color: '#84fab0'
}], false),
},
},
markLine: {
symbol: ['none'],
silent: true,
data: [{
yAxis: lineInfo.value,
name: lineInfo.name,
lineStyle: {
normal: {
type: "dashed",
width: 3,
color: 'rgb(0, 255, 242)'
}
},
label: {
show: true,
distance: 20,
fontWeight: "lighter",
formatter: lineInfo.name,
},
}]
},
}
]
};
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initBarEcharts(el, data, nameList) {
let chart = echarts.init(el);
var scale = 2;
var singleData = data.y1;
var multipleData = data.y2;
var color = "#fff";
option = {
tooltip: {
show: true,
trigger: 'axis',
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: { // 坐标轴指示器,坐标轴触发有效
type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
}
},
legend: {
data: nameList,
align: 'left',
itemGap: 50,
// x: 'right',
right: '1%',
y: '1%',
icon: 'rect',
itemWidth: 15 * scale, // 图例图形宽度
itemHeight: 15 * scale, // 图例图形高度
textStyle: {
color: "#3fdaff",
fontSize: 16 * scale
}
},
grid: {
left: '3%',
right: '4%',
bottom: '3%',
containLabel: true
},
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
xAxis: [{
type: 'category',
data: data.x,
axisLabel: {
// inside: true,
padding: [15, 0, 0, 0],
textStyle: {
color: "#fff",
fontSize: 26,
}
},
axisTick: {
inside: true,
length: 8 * scale,
lineStyle: {
color: color,
}
},
axisLine: {
lineStyle: {
color: color,
}
},
splitLine: {
lineStyle: {
color: 'rgba(80,224,255,0.3)',
type: 'dashed'
}
}
}],
yAxis: [{
type: 'value',
axisLabel: {
// inside: true,
padding: [0, 15, 0, 0],
textStyle: {
color: color,
fontSize: 20,
}
},
axisTick: {
lineStyle: {
color: color,
}
},
axisLine: {
lineStyle: {
color: color,
}
},
splitLine: {
lineStyle: {
color: '#fff',
type: 'dashed'
},
show: false,
},
nameTextStyle: {
color: "#fff",
fontSize: 16 * scale,
padding: [0, 0, 10, 0]
}
}],
series: [{
name: nameList[0],
type: 'bar',
barWidth: '15%',
barGap: '40%',
itemStyle: {
normal: {
color: 'rgba(94,218,255,0.4)',
}
},
data: singleData
},
{
name: nameList[1],
type: 'bar',
barWidth: '15%',
barGap: '40%',
itemStyle: {
normal: {
color: '#ffc72b',
}
},
data: multipleData
}]
};
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initBarEchartsElse(el, data, nameList) {
let chart = echarts.init(el);
var scale = 2;
var singleData = data.y1;
var multipleData = data.y2;
var color = "#fff";
option = {
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
tooltip: {
show: true,
trigger: 'axis',
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: { // 坐标轴指示器,坐标轴触发有效
type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
}
},
legend: {
data: nameList,
align: 'left',
itemGap: 50,
// x: 'right',
right: '1%',
y: '1%',
icon: 'rect',
textStyle: {
color: "#3fdaff",
fontSize: 20
}
},
grid: {
top: "10%",
left: '5%',
right: '4%',
bottom: '20%',
},
xAxis: [{
type: 'category',
data: data.x,
axisLabel: {
// inside: true,
rotate: 30,
padding: [15, 0, 0, 0],
textStyle: {
color: "#fff",
fontSize: 26,
}
},
axisTick: {
inside: true,
length: 8 * scale,
lineStyle: {
color: color,
}
},
axisLine: {
lineStyle: {
color: color,
}
},
splitLine: {
lineStyle: {
color: 'rgba(80,224,255,0.3)',
type: 'dashed'
}
}
}],
yAxis: [{
type: 'value',
axisLabel: {
// inside: true,
padding: [0, 15, 0, 0],
textStyle: {
color: color,
fontSize: 20,
}
},
axisTick: {
lineStyle: {
color: color,
}
},
axisLine: {
lineStyle: {
color: color,
}
},
splitLine: {
lineStyle: {
color: '#fff',
type: 'dashed'
},
show: false,
},
nameTextStyle: {
color: "#fff",
fontSize: 16 * scale,
padding: [0, 0, 10, 0]
}
}],
series: [{
name: nameList[0],
type: 'bar',
barWidth: '15%',
barGap: '40%',
itemStyle: {
normal: {
color: 'rgba(94,218,255,0.4)',
}
},
label: {
show: true,
position: "top",
align: "center",
},
data: singleData
},
{
name: nameList[1],
type: 'bar',
barWidth: '15%',
barGap: '40%',
label: {
show: true,
position: "top",
align: "center",
},
itemStyle: {
normal: {
color: '#ffc72b',
}
},
data: multipleData
}]
};
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initStereoscopic(el,data) {
let chart = echarts.init(el);
option = {
tooltip: {
show: true,
trigger: 'axis',
textStyle: {
fontSize: 30,
color: '#A3E2F4'
},
axisPointer: { // 坐标轴指示器,坐标轴触发有效
type: 'shadow' // 默认为直线,可选为:'line' | 'shadow'
}
},
grid: {
top: 50,
bottom: 30,
left: 90,
right: 90,
textStyle: {
color: "#fff"
}
},
legend: {
icon: 'circle',
right: '4%',
top: '8%',
textStyle: {
color: '#fff',
fontSize: 26
},
data: ['缓冲池', '共享池']
},
calculable: true,
xAxis: [{
type: "category",
axisLine: {
lineStyle: {
color: '#fff'
}
},
splitLine: {
show: false
},
axisTick: {
show: false
},
splitArea: {
show: false
},
axisLabel: {
// inside: true,
textStyle: {
color: "#fff",
fontSize: 26,
}
},
data: data.x,
}],
yAxis: [{
type: "value",
splitLine: {
show: false
},
axisLine: {
show: false,
lineStyle: {
color: '#fff'
}
},
axisTick: {
show: false
},
axisLabel: {
textStyle: {
color: "#fff",
fontSize: 26,
}
},
splitArea: {
show: false
},
// data: ['中止合同人员', '双创人员', '考核待岗人员'],
}],
series: [{
name: "缓冲池",
type: "bar",
stack:"value",
barMaxWidth: 15,
barGap: "10%",
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#FF9915'
}, {
offset: 1,
color: 'rgba(245,221,111,0)'
}]),
borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#FF9915'
}, {
offset: 1,
color: 'rgba(245,221,111,0)'
}]),
}
},
data: data.y1,
},
{
name: "共享池",
type: "bar",
stack:"value",
barMaxWidth: 15,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: 'rgba(24,191,207,1)'
}, {
offset: 1,
color: 'rgba(24,191,207,0)'
}]),
borderColor: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: 'rgba(24,191,207,1)'
}, {
offset: 1,
color: 'rgba(24,191,207,0)'
}]),
}
},
data: data.y2
}
]
}
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initHorizontalBar(el) {
let chart = echarts.init(el);
var bg =
'image://';
var bar =
'image://';
var data = [10, 15];
var barWidth = 20;
var maxNum = 0;
for (var i = 0; i < data.length; i++) {
if (data[i] > maxNum) {
maxNum = data[i];
}
}
option = {
grid: {
top: '10%',
left: '20%',
right: '15%',
bottom: '0%',
},
xAxis: {
show: false,
},
yAxis: {
data: ["共享队伍", "共享单位"],
splitLine: {
show: false,
},
axisLabel: {
textStyle: { fontSize: 20, color: '#fff' },
},
axisLine: {
show: false,
},
axisTick: false,
},
series: [
{
type: 'pictorialBar',
barWidth: barWidth,
zlevel: 2,
data: data.map(function (item) {
return {
value: item,
symbol: bar,
};
}),
},
{
type: 'pictorialBar',
barWidth: barWidth,
data: data.map(function (item) {
return {
realValue: item,
value: maxNum,
symbol: bg,
};
}),
label: {
show: true,
position: 'right',
distance: 150,
align: "right",
formatter: function (params) {
console.log(params);
if (params.name != "共享队伍") {
return params.data.realValue + ' 个';
} else {
return params.data.realValue + ' 支';
}
},
color: '#fff',
fontSize: 35,
},
},
],
};
chart.setOption(option);
tools.loopShowTooltip(chart, option, {
nterval: 2000,
loopSeries: true,
});
},
initProvinceChart(el, mapData = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]) {
var data = [
{
name: '大同市',
value: mapData[0].value,
value2: mapData[0].value
},
{
name: '朔州市',
value: mapData[1].value,
value2: mapData[1].value
},
{
name: '忻州市',
value: mapData[2].value,
value2: mapData[2].value
},
{
name: '吕梁市',
value: mapData[3].value,
value2: mapData[3].value
},
{
name: '太原市',
value: 1,
value2: 2
},
{
name: '阳泉市',
value: mapData[5].value,
value2: mapData[5].value
},
{
name: '晋中市',
value: mapData[6].value,
value2: mapData[6].value
},
{
name: '长治市',
value: mapData[7].value,
value2: mapData[7].value
},
{
name: '临汾市',
value: mapData[8].value,
value2: mapData[8].value
},
{
name: '晋城市',
value: mapData[9].value,
value2: mapData[9].value
},
{
name: '运城市',
value: mapData[10].value,
value2: mapData[10].value
}
]
for (let i = 0; i < data.length; i++) {
const name = data[i].name;
const mapDataObj = mapData.find(obj => obj.name === name);
if (mapDataObj) {
data[i].value = mapDataObj.value;
data[i].value2 = mapDataObj.value;
}
}
let formdata = '太原' // 中心点
this.geoCoordMap = []
/*获取地图数据*/
this.mapChart = echarts.init(el)
echarts.registerMap('shanxi', jsonData)
var mapFeatures = echarts.getMap('shanxi').geoJson.features
mapFeatures.forEach(v => {
// 地区名称
var name = v.properties.name
// 地区经纬度
this.geoCoordMap[name] = v.properties.centroid
// 按照地图乱序
// data.push({ name: v.properties.name, value: v.properties.centroid[0], value2: v.properties.centroid[1] })
})
// 地图数据
var chinaGeoCoordMap = {
太原市: [111.949248, 38.057014],
大同市: [113.595259, 40.29031],
阳泉市: [113.505474, 37.964652],
长治市: [112.813556, 36.791112],
晋城市: [112.551274, 35.577553],
朔州市: [112.433387, 39.531261],
晋中市: [112.936465, 37.696495],
运城市: [111.003957, 35.59],
忻州市: [112.333538, 38.7769],
临汾市: [111.517973, 36.48415],
吕梁市: [111.134335, 37.524366],
}
// 飞线点数据
var chinaDatas = [
[{
name: '太原市',
value: 0,
},],
[{
name: '大同市',
value: 0,
},],
[{
name: '阳泉市',
value: 0,
},],
[{
name: '长治市',
value: 0,
},],
[{
name: '晋城市',
value: 0,
},],
[{
name: '朔州市',
value: 0,
},],
[{
name: '晋中市',
value: 9,
},],
[{
name: '运城市',
value: 0,
},],
[{
name: '忻州市',
value: 0,
},],
[{
name: '临汾市',
value: 0,
},],
[{
name: '吕梁市',
value: 0,
},],
]
var convertData = function (data) {
var res = []
for (var i = 0; i < data.length; i++) {
var dataItem = data[i]
var fromCoord = chinaGeoCoordMap[dataItem[0].name]
var toCoord = [112.549248, 37.857014] //中心点地理坐标
if (fromCoord && toCoord) {
res.push([{
// 飞线从哪里出发
coord: toCoord,
},
{
// 飞线去往哪里
coord: fromCoord,
value: dataItem[0].value,
},
])
}
}
return res
}
var series = [];
[
[formdata, chinaDatas]
].forEach(function (item) {
series.push({
type: 'lines',
name: "模拟数据",
coordinateSystem: 'geo',
zlevel: 2,
effect: {
show: true,
period: 5, //值越小 速度越快
trailLength: 0.3, // 0-1 值越大,越拖
symbol: 'pin', //箭头图标
symbolSize: 8, //图标大小
color: "#E6C50B"
},
lineStyle: {
normal: {
show: true,
type: 'dashed',
width: 2, //尾迹线条宽度
opacity: 0.1, //尾迹线条透明度
curveness: 0.3, //尾迹线条曲直度
color: '#E6C50B', // 飞线颜色
},
},
data: convertData(item[1]),
}, {
type: 'effectScatter',
coordinateSystem: 'geo',
zlevel: 2,
rippleEffect: {
//涟漪特效
period: 10, //动画时间,值越小速度越快
brushType: 'stroke', //波纹绘制方式 stroke, fill
scale: 10, //波纹圆环最大限制,值越大波纹越大
color: '#E6C50B',
},
itemStyle: {
normal: {
color: '#E6C50B',
shadowBlur: 10,
shadowColor: '#E6C50B',
},
},
label: {
normal: {
formatter: '{b}',
position: 'right',
offset: [15, 0],
color: '#fff',
show: true
},
},
symbol: 'circle',
symbolSize: 9,
data: item[1].map(function (dataItem) {
return {
itemStyle: {
color: '#fff' // 修改标点的颜色
},
//在这里定义你所要展示的数据
name: dataItem[0].name,
value: chinaGeoCoordMap[dataItem[0].name].concat([dataItem[0].value]),
}
}),
})
})
let effectScatterData = [
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 534, "山西焦煤机关",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 65704, "西山煤电",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 14972, "山煤国际",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 91, "物资装备公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 111, "金土地公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 835, "销售公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 117, "国发公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 582, "投资公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 117, "人力资源公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 10, "金融资本公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 843, "民爆集团",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 10, "云数据公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 218, "焦煤置业",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 47, "新能源公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 13, "油品公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 29, "低碳公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 67, "交易中心",]
},
{
itemStyle: {
color: "#fff"
},
name: "太原市",
value: [111.949248, 37.957014, 48, "招标公司",]
},
{
itemStyle: {
color: "#fff"
},
name: "晋中市",
value: [112.936465, 37.696495, 49047, "汾西矿业",]
},
{
itemStyle: {
color: "#fff"
},
name: "临汾市",
value: [111.517973, 35.88415, 53563, "霍州煤电",]
},
{
itemStyle: {
color: "#fff"
},
name: "临汾市",
value: [111.517973, 35.88415, 9508, "山西焦化",]
},
{
itemStyle: {
color: "#fff"
},
name: "吕梁市",
value: [111.134335, 37.524366, 9960, "华晋焦煤",]
},
]
let option = {
tooltip: {
trigger: "item",
padding: 15,
backgroundColor: 'rgba(0, 0, 0, 0)',
enterable: true,
transitionDuration: 1,
formatter: (params, ticket, callback) => {
// 清空所有轮播
for (var k in this.geoCoordMap) {
this.mapChart.dispatchAction({
// type: 'geoUnSelect',
type: 'downplay',
name: k,
})
}
// 如果鼠标滑动到线线上面,则返回空
this.mapChart.dispatchAction({
// type: 'geoSelect',
type: 'highlight',
name: params.name,
})
if (params.componentSubType == 'lines') {
return
}
if (params.componentSubType == 'effectScatter') {
let tipHtml = `
区域:${params.name}
二级单位:${params.value[3]}
员工总数:${params.value[2]}