实例模板
下载模板:地铁矢量图.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