实例模板
下载模板:地铁矢量图.7z
应用:大屏项目二次开发
模板路径:应用空间-地铁矢量图(hte_2021_06_29153439180)
1、预览效果
2、实现原理
基于乐创者报表(lczReport)中单元格的自定义控件功能+echarts实现。
3、配置步骤
3.1、引入echartsjs
3.2、报表模板中设置自定义控件
3.3、配置脚本
具体可参考 地铁图.html
由于该方法需要的数据过多,因此案例中只使用和展现了一条线路的数据
背景图片:(因为背景图片需要用http的方式去获取图片,所以例子中放进了我本地nginx服务中)background.png
ER.widget.extend(this, {
type: 'echarts',
init: function (datas, element, echarts) {
myChart = echarts.init(element);
var pic = "image://"
var data = [{
id: 0,
name: '浦沿',
x: 530,
y: 530,
value: [],
// label:{offset : [-30, 0]},
category: 0
}, {
id: 1,
name: '杨家墩',
x: 510,
y: 510,
value: [],
// label:{offset : [-30, 0]},
category: 0
}, {
id: 2,
name: '中医药大学',
x: 500,
y: 500,
value: [],
// label:{offset : [-30, 0]},
category: 0
}, {
id: 3,
name: '联庄',
x: 490,
y: 490,
value: [],
// label:{offset : [-30, 0]},
category: 0
}, {
id: 4,
name: '联庄-水澄桥1',
x: 470,
y: 470,
value: [],
symbolSize: 0,
label: {
show: false
},
category: 0
}, {
id: 5,
name: '联庄-水澄桥2',
x: 470,
y: 460,
value: [],
symbolSize: 0,
label: {
show: false
},
category: 0
}, {
id: 6,
name: '水澄桥',
x: 480,
y: 450,
value: [],
// label:{show : false},
category: 0
}, {
id: 7,
name: '复兴路',
x: 490,
y: 440,
value: [],
// label:{show : false},
category: 0
}, {
id: 8,
name: '南星桥',
x: 500,
y: 430,
symbol: pic,
symbolSize: 12,
value: [],
// label:{show : false},
category: 0
}, {
id: 9,
name: '甬江路',
x: 510,
y: 420,
value: [],
// label:{show : false},
category: 0
}, {
id: 10,
name: '近江',
x: 520,
y: 410,
symbol: pic,
symbolSize: 12,
value: [],
// label:{show : false},
category: 0
}, {
id: 11,
name: '城星路',
x: 540,
y: 390,
value: [],
// label:{show : false},
category: 0
}, {
id: 12,
name: '市民中心',
x: 550,
y: 380,
value: [],
// label:{show : false},
category: 0
}, {
id: 13,
name: '江锦路',
x: 570,
y: 360,
value: [],
// label:{show : false},
category: 0
}, {
id: 14,
name: '钱江路',
x: 570,
y: 350,
value: [],
symbol: pic,
symbolSize: 12,
// label:{show : false},
category: 0
}, {
id: 15,
name: '钱江路-景芳1',
x: 558,
y: 339,
value: [],
symbolSize: 0,
label: {
show: false
},
category: 0
}, {
id: 16,
name: '钱江路-景芳2',
x: 550.5,
y: 330.5,
value: [],
symbolSize: 0,
label: {
show: false
},
category: 0
}, {
id: 17,
name: '景芳',
x: 550,
y: 320,
value: [],
// label:{show : false},
category: 0
}, {
id: 18,
name: '新塘',
x: 550,
y: 290,
value: [],
// label:{show : false},
category: 0
}, {
id: 19,
name: '新风',
x: 550,
y: 244,
value: [],
// label:{show : false},
category: 0
}, {
id: 20,
name: '火车东站',
x: 570,
y: 232,
symbol: pic,
symbolSize: 12,
value: [],
// label:{show : false},
category: 0
}, {
id: 21,
name: '彭埠',
x: 590,
y: 220,
value: [],
// label:{show : false},
category: 0
}]
var links = [{
source: 0,
target: 1
}, {
source: 1,
target: 2
}, {
source: 2,
target: 3
}, {
source: 3,
target: 4
}, {
source: 4,
target: 5,
lineStyle: {
curveness: 0.4
}
}, {
source: 5,
target: 6
}, {
source: 6,
target: 7,
}, {
source: 7,
target: 8
}, {
source: 8,
target: 9
}, {
source: 9,
target: 10
}, {
source: 10,
target: 11
}, {
source: 11,
target: 12
}, {
source: 12,
target: 13
}, {
source: 13,
target: 14
}, {
source: 14,
target: 15
}, {
source: 15,
target: 16,
}, {
source: 16,
target: 17
}, {
source: 17,
target: 18
}, {
source: 18,
target: 19
}, {
source: 19,
target: 20
}, {
source: 20,
target: 21
}]
var categories = [{
"name": "4号线"
},
{
"name": "2号线"
},
{
"name": "1号线"
},
{
"name": "5号线"
},
{
"name": "16号线"
},
];
for (let i = 0; i < data.length; i++) {
const element = data[i];
element.value[0] = element.x
element.value[1] = -element.y
}
// 指定图表的配置项和数据
// var img = new Image();
// img.src = 'https://ss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=2447258259,3926215804&fm=26&gp=0.jpg'
var option = {
color: ['rgb(108,197,90)', 'rgb(243,110,33)', 'rgb(238,61,86)', 'rgb(0,175,200)', 'rgb(255,170,82)'],
// grid:{
// backgroundColor: {
// type: 'pattern',
// repeat: 'repeat',
// image: img // 赋值
// // color:'red'
// },
// show:true
// },
graphic: [{
type: 'image', // 图形元素类型
id: 'logo', // 更新或删除图形元素时指定更新哪个图形元素,如果不需要用可以忽略。
left: '0', // 根据父元素进行定位 (居中)
top: '0', // 根据父元素进行定位 (0%), 如果bottom的值是 0,也可以删除该bottom属性值。
// z: 0, // 层叠
bounding: 'raw', // 决定此图形元素在定位时,对自身的包围盒计算方式
style: {
image: 'http://localhost:8090/static/background.png', // 这里一定要注意、注意,必须是https开头的图片路径地址
width: 900,
height: 600
},
draggable: false
}],
legend: {
show: true,
icon: "line",
data: categories
},
xAxis: {
show: false,
min: 0,
max: 900,
// type: "value",
//开启x轴坐标
axisPointer: {
show: false
},
},
yAxis: {
show: false,
min: -600,
max: 0,
// type: "value",
//开启y轴坐标
axisPointer: {
show: false
},
},
dataZoom: [{
type: 'inside',
xAxisIndex: [0],
start: 0,
end: 100
}, {
type: 'inside',
yAxisIndex: [0],
start: 0,
end: 100
}],
series: [{
name: '地铁',
type: 'graph',
layout: 'none',
roam: true,
draggable: false,
zlevel: 5,
coordinateSystem: "cartesian2d",
//focusNodeAdjacency: true,
symbol: "emptyCircle",
symbolSize: 4,
lineStyle: {
width: 3,
color: 'source',
opacity: 1
},
label: {
show: false,
position: "top",
color: "#333"
},
data: data,
links: links,
categories: categories
},
{
type: 'effectScatter',
coordinateSystem: "cartesian2d",
// symbol: "image://",
symbolSize: 4,
rippleEffect: {
brushType: 'stroke',
scale: 20
},
zlevel: 4,
itemStyle: {
color: 'red',
shadowColor: "IndianRed",
shadowBlur: 20
},
data: [{
name: "火车东站",
value: [570, -232, 47.36]
},
{
name: "湘湖",
value: [600, -500, 36.56]
},
{
name: "湘湖",
value: [460, -300, 30.89]
},
],
effectType: "ripple",
hoverAnimation: true
}
],
textStyle: {
fontFamily: "宋体"
}
};
// 使用刚指定的配置项和数据显示图表。
myChart.setOption(option);
// myChart.on('graphroam',function(params){
// var option = myChart.getOption();//获得option对象
// console.log("graphroam_zoom:"+option.series[0].zoom);
// console.log("graphroam_center:"+option.series[0].center);
// //chart.setOption(option);//设置option
// });
myChart.on('datazoom', function (params) {
console.log(params); //里面存有代表滑动条的起始的数字
var element = myChart.getOption()
console.log(myChart.getOption())
var setoption = {
graphic: [{
id: 'logo'
}]
};
var wid = element.graphic[0].elements[0].style.width;
var hei = element.graphic[0].elements[0].style.height;
for (var i = 0; i < params.batch.length; i++) {
var dataZoomId = params.batch[i].dataZoomId;
var arrrr = dataZoomId.split(dataZoomId.substr(0, 1));
console.log(arrrr);
var zoomx = 1 / ((params.batch[i].end - params.batch[i].start) / 100);
if (arrrr[2] == '0') {
setoption.graphic[0].scaleX = zoomx;
setoption.graphic[0].left = 0 - (wid * zoomx * params.batch[i].start / 100);
} else if (arrrr[2] == '1') {
setoption.graphic[0].scaleY = zoomx;
setoption.graphic[0].top = 0 - (hei * zoomx * (100 - params.batch[i].end) / 100);
}
}
console.log(setoption);
myChart.setOption(setoption);
})
}
})
作者:倪 创建时间:2024-07-30 15:08
最后编辑:倪 更新时间:2025-04-22 15:31
最后编辑:倪 更新时间:2025-04-22 15:31
