患者时间轴-1

描述:当前是关于Echarts图表中的 示例。
 
            var data = [];
var dataCount = 10;
var startTime = +new Date();
var categories = [''];
var types = [{
        name: 'JS Heap',
        color: 'rgba(0,0,0,0.08)'
    },
    {
        name: 'Documents',
        color: '#bd6d6c'
    },
    {
        name: 'Nodes',
        color: '#75d874'
    },
    {
        name: 'Listeners',
        color: '#e0bc78'
    },
    {
        name: 'GPU Memory',
        color: '#dc77dc'
    },
    {
        name: 'GPU',
        color: '#72b362'
    }
];
let xdata = [
    "2011-12-28",
    "2016-12-28",
];
let data4 = [8, 6];
let dataMess = [{
        index: 8,
        mess: "XX企业氨水罐发生nh3爆炸",
    },
    {
        index: 6,
        mess: "系统报告泄漏事件升级,由\n报警上升为紧急报警",
    },
    {
        index: 4,
        mess: "系统报告XX园区应急指挥中心\n做批示",
    },
    {
        index: 2,
        mess: "XX区XX医院医疗队伍入场",
    },
    {
        index: 4,
        mess: "XX区应急指挥中心抽\n调应急专家级咨询专家入场",
    },
    {
        index: 6,
        mess: "XX园区SO2泄漏事\n件现场指挥小组成立",
    },
    {
        index: 8,
        mess: "XX园区SO2泄漏事件\n堵漏方案通过",
    },
    {
        index: 6,
        mess: "XX园区SO2泄漏\n事件空气恢复方案通过",
    },
];

let labelMess = function(param) {
    return (
        `{b|${param.name}} \n` + `{value|${dataMess[param.dataIndex].mess}}`
    );
};

function renderItem(params, api) {
    console.log(params)
    var categoryIndex = api.value(0);
    var start = api.coord([api.value(1), categoryIndex]);
    var end = api.coord([api.value(2), categoryIndex]);
    // console.log(start, end)
    var height = api.size([0, 1])[1];

    var rectShape = echarts.graphic.clipRectByRect({
        x: start[0],
        y: start[1] - height / 2,
        width: end[0] - start[0],
        height: height * 0.6
    }, {
        x: params.coordSys.x,
        y: params.coordSys.y,
        width: params.coordSys.width,
        height: params.coordSys.height
    });

    return rectShape && {
        type: 'rect',
        shape: rectShape,
        style: api.style({
            fill: types[params.dataIndex].color
        })
    };
}

option = {
    tooltip: {
        formatter: function(params) {
            return params.marker + params.name + ': ' + params.value[2] + ' ms';
        }
    },
    grid: [{
            "top": 80,
            "height": 40,
            "right": "4%",
            "z": 10
        },
        {
            "top": 80,
            "height": 65,
            "right": "4%",
            "z": 15
        },
        {
            "top": 80,
            "bottom": 0,
            // "height": 40,
            "right": "4%",
            "z": 0
        },
        {
            "top": 38,
            "height": 65,
            "right": "4%",
            "z": 12
        },
        {
            "top": 38,
            "height": 65,
            "right": "4%",
            "z": 12
        },
    ],
    "dataZoom": [{
            "type": "inside",
            "xAxisIndex": [
                0,
                1,
                2
            ],
            "start": 0,
            "end": 99.99999999999999,
            "throttle": 200
        },
        {
            "show": false,
            "height": 16,
            "xAxisIndex": [
                0,
                1,
                2
            ],
            "type": "slider",
            "top": 64,
            "start": 0,
            "end": 100,
            "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",
            "handleSize": "120%",
            "handleStyle": {
                "color": "#18A2B2",
                "shadowColor": "#B1B5B9",
                "shadowBlur": 5
            },
            "dataBackground": {
                "lineStyle": {
                    "width": 0
                },
                "areaStyle": {
                    "color": "transparent"
                }
            },
            "backgroundColor": "transparent",
            "fillerColor": "transparent",
            "borderColor": "transparent",
            "throttle": 200
        }
    ],
    "xAxis": [{
            "type": "time",
            "boundaryGap": false,
            "axisLine": {
                "show": true,
                "lineStyle": {
                    "color": "#d8d8d8"
                }
            },
            "axisTick": {
                "show": true,
                "inside": true
            },
            "axisLabel": {
                "color": "rgba(0,0,0,0.54)",
                "fontSize": 12
            },
            "splitLine": {
                "show": false
            },
            "min": "2011-11-28",
            "max": "2017-07-25"
        },
        {
            "type": "value",
            "gridIndex": 1,
            "min": 0,
            "max": 100,
            "axisLabel": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "splitLine": {
                "show": false
            }
        },
        {
            "type": "time",
            "gridIndex": 2,
            "axisLabel": {
                "show": false
            },
            "axisLine": {},
            "axisTick": {
                "show": false
            },
            "splitLine": {
                "show": false
            }
        },
        {
            "type": "time",
            "boundaryGap": false,
            "axisLabel": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "splitLine": {
                "show": false
            }
        },
        {
            "type": "time",
            "boundaryGap": false,
            "gridIndex": 3,
            "axisLabel": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "splitLine": {
                "show": false
            },
            min: '2011-11-28',
            max: '2017-07-25',
        },
        {
            "type": "time",
            "boundaryGap": false,
            "gridIndex": 4,
            "axisLabel": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "splitLine": {
                "show": false
            },
            min: '2011-11-28',
            max: '2017-07-25',
        }
    ],
    "yAxis": [{
            "data": [],
            "gridIndex": 0,
            "splitLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisLabel": {
                "show": false
            }
        },
        {
            "type": "value",
            "gridIndex": 1,
            "axisLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "axisLabel": {
                "show": false
            },
            "splitLine": {
                "show": false
            }
        },
        {
            "type": "value",
            "gridIndex": 2,
            "axisLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "axisLabel": {
                "show": false
            },
            "splitLine": {
                "show": false
            }
        },
        {
            "data": [],
            "gridIndex": 0,
            "splitLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisLabel": {
                "show": false
            }
        },
        {
            "gridIndex": 3,
            "splitLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisLabel": {
                "show": false
            },
            
        },
        {
            "gridIndex": 4,
            "splitLine": {
                "show": false
            },
            "axisTick": {
                "show": false
            },
            "axisLine": {
                "show": false
            },
            "axisLabel": {
                "show": false
            },
            
        }
    ],
    series: [{
            "type": "custom",
            "itemStyle": {
                "opacity": 0.8
            },
            "encode": {
                "x": [1, 2],
                "y": [0]
            },
            "renderItem": renderItem,
            "data": [{
                "value": [0, "2011-12-28", "2012-06-04", "Admission"]
            }, {
                "value": [0, "2012-12-28", "2013-01-04", "Outpatient"]
            }, {
                "value": [0, "2014-05-20", "2014-08-03", "Admission"]
            }, {
                "value": [0, "2016-06-22", "2016-07-25", "Emergency"]
            }]
        }, {
            "type": "line",
            "yAxisIndex": 2,
            "xAxisIndex": 2,
            "data": [
                ["2011-11-28", 0],
                ["2017-07-25", 0]
            ],
            "symbol": "none",
            "lineStyle": {
                "color": "transparent"
            },
            markArea: {
                silent: true,
                itemStyle: {
                    color: 'rgba(83,165,138,.1)',
                },
                data: [
                    [{
                            coord: ['2013-05-01'],
                        },
                        {
                            coord: ['2015-05-16'],
                        },
                    ],
                ],
            },
        }, {
            "type": "custom",
            "yAxisIndex": 3,
            "xAxisIndex": 3,
            "itemStyle": {
                "opacity": 0.8,
            },
            "renderItem": renderItem,
            "encode": {
                "x": [1, 2],
                "y": [0]
            },
            "data": [{
                "value": [0, "2011-11-28", "2017-07-25"]
            }]
        },
        // {
        //  // 个性化 data zoom slider
        //   type: 'pictorialBar',
        //   yAxisIndex: 1,
        //   xAxisIndex: 1,
        //   barWidth: 1,
        //   itemStyle: {
        //     color: '#18A2B2',
        //     borderColor: '#18A2B2',
        //   },
        //   symbol: 'rect',
        //   data: [
        //     [0, 8],
        //     [100, 8],
        //   ],
        // },
        {
            type: "pictorialBar",
            data: [
                // ['2011-11-28', 8],
                ['2013-02-29', 8]
            ],
            zlevel: 999,
            xAxisIndex: 4,
            yAxisIndex: 4,
            barWidth: 1,
            symbol: "rect",
            symbolSize: ['100%', 90],
            symbolOffset: [8,0],
            itemStyle: {
                normal: {
                    color: {
                        //图形颜色
                        type: "linear",
                        x: 0,
                        y: 0,
                        x2: 0,
                        y2: 1,
                        colorStops: [{
                                offset: 0,
                                color: "#D88000", // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: "#D88000", // 100% 处的颜色
                            },
                        ],
                        global: false, // 缺省为 false
                    },
                    // shadowColor: "#D0D6E5",
                    // shadowBlur: 1,
                },
            },
            label: {
                show: true,
                width: 90,
                height: 50,
                padding: [0, 0, 0, 10],
                backgroundColor:'rgba(239,183,19,0.40)',
                // shadowColor: "#D88000",
                // shadowBlur: 4,
                // borderRadius: 5,
                position: "top",
                offset: [57, 55],
                formatter: function(param) {
                    console.log(param)
                    return ( `{a|${'首次转移'}}\n ` + `{b|${'2011-11-28'}}`  + `{c|${3}}`);
                },
                rich: {
                    a: {
                        lineHeight: 0,
                        fontWeight: 400,
                        fontSize: 12,
                        padding: [-35, 0, 0, 3],
                    },
                    b: {
                        color: 'rgba(27,27,27,0.54)',
                        fontWeight: 400,
                        fontSize: 12,
                        lineHeight: 30,
                        padding: [-45, 0, 0, 0],
                        align: "left",
                    },
                    c: {
                        backgroundColor: {
                            width: 24,
                            height: 24,
                            image: ""
                        },
                        height: 24,
                        width: 24,
                        align: 'right',
                        padding: [2, 8, 0, 0],
                    }
                },
            },
        },
        {
            type: "pictorialBar",
            data: [
                ['2011-11-28', 8],
                // ['2012-02-29', 8]
            ],
            xAxisIndex: 4,
            yAxisIndex: 4,
            zlevel: 1000,
            barWidth: 1,
            symbol: "rect",
            symbolSize: ['100%', 90],
            itemStyle: {
                normal: {
                    color: {
                        //图形颜色
                        type: "linear",
                        x: 0,
                        y: 0,
                        x2: 0,
                        y2: 1,
                        colorStops: [{
                                offset: 0,
                                color: "#D88000", // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: "#D88000", // 100% 处的颜色
                            },
                        ],
                        global: false, // 缺省为 false
                    },
                    // shadowColor: "#D0D6E5",
                    // shadowBlur: 1,
                },
            },
            label: {
                show: true,
                width: 90,
                height: 50,
                padding: [0, 0, 0, 10],
                backgroundColor:'rgba(239,183,19,0.40)',
                // shadowColor: "#D88000",
                // shadowBlur: 4,
                // borderRadius: 5,
                position: "top",
                offset: [49, 55],
                formatter: function(param) {
                    console.log(param)
                    return ( `{a|${'首次复发'}}\n ` + `{b|${'2011-11-28'}}\n` );
                },
                rich: {
                    a: {
                        lineHeight: 0,
                        fontWeight: 400,
                        fontSize: 12,
                        padding: [-35, 0, 0, 3],
                    },
                    b: {
                        color: 'rgba(27,27,27,0.54)',
                        fontWeight: 400,
                        fontSize: 12,
                        lineHeight: 30,
                        padding: [-45, 0, 0, 0],
                        align: "left",
                    },
                },
            },
        },
        
        {
            type: "pictorialBar",
            data: [
                ['2011-11-28', 8],
                ['2012-02-29', 8]
            ],
            xAxisIndex: 5,
            yAxisIndex: 5,
            barWidth: 50,
            symbol: "rect",
            // z: 100,
            symbolSize: ['200%', 50],
            symbolOffset: [50, -40] ,
            itemStyle: {
                normal: {
                    color: {
                        //图形颜色
                        type: "linear",
                        x: 0,
                        y: 0,
                        x2: 0,
                        y2: 1,
                        colorStops: [{
                                offset: 0,
                                color: "transparent", // 0% 处的颜色
                            },
                            {
                                offset: 1,
                                color: "transparent", // 100% 处的颜色
                            },
                        ],
                        global: false, // 缺省为 false
                    },
                    // shadowColor: "#D0D6E5",
                    // shadowBlur: 1,
                },
            },
        },
    ]
};