pipe_with_imageecharts rect配置项内容和展示

配置项如下
      var meterIconSrc = "";

var originalPipeData = [{
        "name": "线路1",
        "points": [{
                "centerX": 0,
                "centerY": 8,
                "id": 1342,
                "type": "连接点"
            },
            {
                "centerX": 9.15,
                "centerY": 8,
                "id": 1352,
                "type": "连接点"
            },
            {
                "centerX": 9.15,
                "centerY": 14,
                "id": 1361,
                "type": "连接点"
            },
            {
                "centerX": 19,
                "centerY": 14,
                "id": 1369,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路2",
        "points": [{
                "centerX": 0,
                "centerY": 6.5,
                "id": 1345,
                "type": "连接点"
            },
            {
                "centerX": 9.26,
                "centerY": 6.5,
                "id": 1355,
                "type": "连接点"
            },
            {
                "centerX": 19.09,
                "centerY": 6.5,
                "id": 1363,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路3",
        "points": [{
                "centerX": 0,
                "centerY": 8,
                "id": 1347,
                "type": "连接点"
            },
            {
                "centerX": 9.33,
                "centerY": 8,
                "id": 3841,
                "type": "连接点"
            },
            {
                "centerX": 19.14,
                "centerY": 8,
                "id": 1365,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路4",
        "points": [{
                "centerX": 0,
                "centerY": 6.5,
                "id": 1343,
                "type": "连接点"
            },
            {
                "centerX": 9.18,
                "centerY": 6.5,
                "id": 1353,
                "type": "连接点"
            },
            {
                "centerX": 19.03,
                "centerY": 6.5,
                "id": 1362,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路5",
        "points": [{
                "centerX": 0,
                "centerY": 6.5,
                "id": 1340,
                "type": "连接点"
            },
            {
                "centerX": 9.09,
                "centerY": 6.5,
                "id": 1350,
                "type": "连接点"
            },
            {
                "centerX": 18.95,
                "centerY": 6.5,
                "id": 1359,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路6",
        "points": [{
                "centerX": 0,
                "centerY": 8,
                "id": 1339,
                "type": "连接点"
            },
            {
                "centerX": 8.93,
                "centerY": 8,
                "id": 1349,
                "type": "连接点"
            },
            {
                "centerX": 18.83,
                "centerY": 8,
                "id": 1358,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路7",
        "points": [{
                "centerX": 0,
                "centerY": 6.5,
                "id": 1341,
                "type": "连接点"
            },
            {
                "centerX": 9.13,
                "centerY": 6.5,
                "id": 1351,
                "type": "连接点"
            },
            {
                "centerX": 18.99,
                "centerY": 6.5,
                "id": 1360,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路8",
        "points": [{
                "centerX": 0,
                "centerY": 8,
                "id": 1344,
                "type": "连接点"
            },
            {
                "centerX": 9.2,
                "centerY": 8,
                "id": 1354,
                "type": "连接点"
            },
            {
                "centerX": 19.04,
                "centerY": 8,
                "id": 3028,
                "type": "连接点"
            }
        ]
    },
    {
        "name": "线路9",
        "points": [{
                "centerX": 0,
                "centerY": 8,
                "id": 1346,
                "type": "连接点"
            },
            {
                "centerX": 9.29,
                "centerY": 8,
                "id": 1356,
                "type": "连接点"
            },
            {
                "centerX": 19.11,
                "centerY": 8,
                "id": 1364,
                "type": "连接点"
            },
            {
                "centerX": 19.11,
                "centerY": 16,
                "id": 1366,
                "type": "连接点"
            }
        ]
    }
]

/*管线*/
var seriesPipesAll = []

_.forEach(originalPipeData, function(value, key) {
    var seriesPipes = []
    _.forEach(value.points, function(point, index) {

        if (index > 0) {
            var seriesPipe = []
            seriesPipe.push(value.points[index - 1]["centerX"])
            seriesPipe.push(value.points[index - 1]["centerY"])
            seriesPipe.push(point.centerX)
            seriesPipe.push(point.centerY)

            seriesPipes.push(seriesPipe)

        }
    });
    seriesPipesAll.push(seriesPipes)
});

console.log(JSON.stringify(seriesPipesAll))

function renderPipe(params, api) {

    var start = api.coord([api.value(0), api.value(1)]);
    var end = api.coord([api.value(2), api.value(3)]);
    var size = api.size([0, 1])
    var width = size[0] * 0.6;
    var height = size[1] * 0.6;

    // return {
    //     type: 'rect',
    //     shape: {
    //         x: start[0],
    //         y: start[1],
    //         width: end[0] - start[0],
    //         height: 8
    //     },
    //     style: api.style()
    // };

    return {
        type: 'group',
        children: [{
            type: 'rect',
            shape: {
                x: start[0],
                y: start[1],
                width: end[0] - start[0],
                height: 8
            },
            style: api.style()
        }, {
            type: 'rect',
            shape: {
                x: start[0] + Math.abs(end[0] - start[0]),
                y: start[1] - Math.abs(end[1] - start[1]),
                width: 8,
                height: Math.abs(end[1] - start[1]) + 8
            },
            style: api.style()
        }]
    };
}

/*管架*/
var seriesRacks = [
    [5, 8, 6, 7],
    [14, 14, 15, 13]
]


function renderRack(params, api) {

    var start = api.coord([api.value(0), api.value(1)]);
    var end = api.coord([api.value(2), api.value(3)]);

    return {
        type: 'rect',
        shape: {
            x: start[0],
            y: start[1],
            width: Math.abs(end[0] - start[0]),
            height: Math.abs(end[1] - start[1])
        },
        style: api.style()
    };
}

/*闸阀*/
var seriesValves = [
    [7, 8.3, 10],
    [12, 14.5, 15]
]

function renderValve(params, api) {
    var radius = api.value(2);
    var start = api.coord([api.value(0), api.value(1)]);

    return {
        type: 'circle',
        shape: {
            cx: start[0],
            cy: start[1],
            r: radius
        },
        style: api.style()
    };
}

/*计量表*/
var seriesMeters = [
    [3, 9, 1],
    [18, 14.5, 1]
]

function renderMeter(params, api) {
    //debugger
    var radius = api.value(2);
    var start = api.coord([api.value(0), api.value(1)]);
    var size = api.size([api.value(2), api.value(2)]);
    var width = size[0];
    var height = size[1];

    return {
        type: 'image',
        style: {
            image: meterIconSrc,
            x: start[0],
            y: start[1],
            width: width,
            height: height
        }
    };
}

option = {
    tooltip: {
        trigger: 'axis',
        // axisPointer: {
        //     type: 'shadow'
        // }
    },
    legend: {
        data: ['管架', '闸阀', '计量表']
    },
    grid: {
        height: 300
    },
    xAxis: {
        type: 'value',
        splitLine: {
            show: false
        }
    },
    yAxis: {
        type: 'value',
        splitLine: {
            show: false
        },
        // boundaryGap: ['20%', '20%'],
        min: function(value) {
            return (value.min - 2) > 0 ? value.min - 2 : value.min ;
        },
        max: function(value) {
            return value.max + 2 ;
        }
    },
    series: [{
        type: 'custom',
        name: '管线主体',
        tooltip: {
            show: false
        },
        renderItem: renderPipe,
        itemStyle: {
            normal: {
                opacity: 0.9
            }
        },
        encode: {
            x: [0, 2],
            y: [1, 3]
        },
        data: seriesPipesAll[0]
    }, {
        type: 'custom',
        name: '管架',
        renderItem: renderRack,
        itemStyle: {
            normal: {
                opacity: 0.8
            }
        },
        encode: {

            x: [0, 2],
            y: [1, 3],
            tooltip: [0, 1, 2, 3]
        },
        data: seriesRacks
    }, {
        type: 'custom',
        name: '闸阀',
        renderItem: renderValve,
        itemStyle: {
            normal: {
                opacity: 0.8
            }
        },
        encode: {
            x: 0,
            y: 1
        },
        data: seriesValves
    }, {
        type: 'custom',
        name: '计量表',
        renderItem: renderMeter,
        itemStyle: {
            normal: {
                opacity: 0.8
            }
        },
        encode: {
            x: [0],
            y: [1]
        },
        data: seriesMeters
    }]

};

myChart.on('click', function(params) {
    if (params.componentType === 'series') {
        console.log(params)
        if (params.seriesType === 'custom') {
            if (params.dataType === 'edge') {
                // 点击到了 graph 的 edge(边)上。
            } else {
                // 点击到了 graph 的 node(节点)上。
                var tips = "您点击了【";
                tips += params.seriesName;
                tips += " ";
                tips += params.dataIndex;
                tips += "】";
                alert(tips)
            }
        }
    }

});









/******** unused **************************/

function renderPipe1(params, api) {

    var start = api.coord([api.value(0), api.value(1)]);
    var end = api.coord([api.value(2), api.value(3)]);
    var size = api.size([0, 1])
    var width = size[0] * 0.6;
    var height = size[1] * 0.6;

    return {
        type: 'rect',
        shape: {
            x: start[0] + Math.abs(end[0] - start[0]),
            y: start[1] - Math.abs(end[1] - start[1]),
            width: 8,
            height: Math.abs(end[1] - start[1]) + 8
        },
        style: api.style()
    };
}
    
截图如下