锐单电子商城 , 一站式电子元器件采购平台!
  • 电话:400-990-0325

疫情数据可视化-湖北省疫情可视化软件设计大赛作品

时间:2022-09-09 13:30:00 厚膜无感功率电阻zmp50油位传感器xgyw310低浓度甲烷传感器gjc4电子台秤传感器yzogwk40温度传感器bk6电阻器

湖北省疫情监测中心(疫情数据可视化)目录

  • 前言
  • 一、数据可视化
  • 二、疫情可视化
    • 湖北疫情监测中心
      • ① 主要框架
      • ② 数据爬取
      • ③ 疫情可视化模块(疫情监测模块)
      • ④ 便利信息可视化模块(检测信息模块)
      • ⑤ 学生信息可视化模块(信息服务模块)
      • ⑥ 总结

前言

这是参加软件设计大赛的可视化作品,已获省级一等奖,仅供参考。


一、数据可视化

① 疫情仍在蔓延。如何利用全面有效、及时的数据和可视化技术准确感知疫情形势,为决策者和管理者提供宏观数据依据,节省决策时间,使数据可视化成为管理者和时间赛跑的助手,是快速打赢这场战疫的关键。 ② 大数据屏幕的设计需要掌握、分析和呈现动态数据的能力,以宏观的视野和细致的工匠的心,使冷数据产生温度。它包括图表的科学运用、色彩的运用、数据层次的控制和视觉层次与功能需求的完美融合。 ③ 我们运用专业知识可视化疫情。对于疫情决策者和监管者来说,通过大数据可视化屏幕掌握疫情发展,可以更直观地了解全局信息,有效节省决策时间。

二、疫情可视化

湖北疫情监测中心

在这里插入图片描述

① 主要框架

整体是基础 Python Flask Echarts 湖北省疫情监测系统建设。使用的技术包括但不限于:
Python网络爬虫
Python 与 MySQL 数据库交互
使用 Flask 框架构建Web端
基于 Echarts 数据可视化显示

② 数据爬取


③ 疫情可视化模块(疫情监测模块)


采用相关图表 Echart 官网 option
Ⅰ. 全国累计趋势折线图

相关js的option代码:

var ec_left1_Option = { 
           tooltip: { 
             trigger: 'axis',        axisPointer: { 
            type: 'line',    lineStyle: { 
             color: '#01ecee'    }   },     position: function (pt) { 
               return [pt[0], '10%'];     }   },   title: { 
             text: "全国累计趋势",     textStyle: { 
               color: '#ffffff',     },     left: 'left'   },   toolbox: { 
             feature: { 
               dataZoom: { 
                 yAxisIndex: 'none'       },       restore: { 
        },       saveAsImage: { 
        }     }   },   xAxis: { 
             type: 'category',     boundaryGap: false,     axisLabel: { 
            show: true,    color: 'rgba(255,255,255,0.65)',     },     data: []   },   yAxis: { 
             type: 'value',     boundaryGap: [0, '100%'],     axisLabel: { 
            show: true,    color: 'rgba(255,255,255,0.65)',     },   },
  dataZoom: [
    { 
        
      type: 'inside',
      start: 0,
      end: 10
    },
    { 
        
      start: 0,
      end: 10
    }
  ],
  series: [
    { 
        
      name: '全国累计确诊(当日)',
      type: 'line',
      symbol: 'none',
      sampling: 'lttb',
      itemStyle: { 
        
        color: 'rgb(1,236,238)'
      },
      areaStyle: { 
        
        color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
          { 
        
            offset: 0,
            color: 'rgba(69,221,162,0.7)'
          },
          { 
        
            offset: 1,
            color: 'rgba(255,255,255,0.6)'
          }
        ])
      },
      data: []
    }
  ]
};

Ⅱ. 湖北省累积趋势折线图

相关js的option代码:

var ec_right1_Option = { 
        
	tooltip: { 
        
		trigger: 'axis',
		//指示器
		axisPointer: { 
        
			type: 'line',
			lineStyle: { 
        
				color: '#01ecee'
			}
		},
	},
	legend: { 
        
		data: ['累计确诊', '现有确诊', '累计治愈','累计死亡'],
		right: "5%",
		top: "10%",
		textStyle: { 
        
			color: '#ffffff',
		},
	},
	//标题样式
	title: { 
        
		text: "湖北累计趋势",
		textStyle: { 
        
			color: '#ffffff',
		},
		left: 'left'
	},
	//图形位置
	grid: { 
        
		left: '4%',
		right: '6%',
		bottom: '4%',
		top: 100,
		containLabel: true
	},
	xAxis: [{ 
        
		type: 'category',
		//x轴坐标点开始与结束点位置都不在最边缘
		// boundaryGap : true,
		axisLabel: { 
        
			show: true,
			color: 'rgba(255,255,255,0.65)',
    },
		data: []
	}],
	yAxis: [{ 
        
		type: 'value',
		//y轴字体设置

		//y轴线设置显示
		axisLine: { 
        
			show: true
		},
		axisLabel: { 
        
			show: true,
			color: 'rgba(255,255,255,0.65)',
			fontSize: 12,
			formatter: function(value) { 
        
				if (value >= 1000) { 
        
					value = value / 1000 + 'k';
				}
				return value;
			}
		},
		//与x轴平行的线样式
		splitLine: { 
        
			show: true,
			lineStyle: { 
        
				//color: '#01ecee',指示器颜色
				width: 1,//指示器线条宽度
				// type: 'solid',
			}
		}
	}],
	series: [{ 
        
		name: "累计确诊",
		type: 'line',
		smooth: true,
		data: []
	}, { 
        
		name: "现有疑似",
		type: 'line',
		smooth: true,
		data: []
	},{ 
        
		name: "累计治愈",
		type: 'line',
		smooth: true,
		data: []
	},{ 
        
		name: "累计死亡",
		type: 'line',
		smooth: true,
		data: []
	}]
};

Ⅲ. 湖北累计确诊(地图展示)
该模块用了 Echarts 的 hubei.js

相关js的option代码:

var ec_center_Option = { 
        
    title: { 
        
        text: '湖北累计确诊',
        textStyle: { 
        
            color: '#01ecee',
        },
        subtext: '',
        x: 'left',
        fontcolor:'#01ecee',
    },

    tooltip: { 
        
        trigger: 'item'
    },
    //左侧小导航图标
    visualMap: { 
        
        show: true,
        x: 'left',
        y: 'bottom',
        textStyle: { 
        
            fontSize: 16,

        },
        splitList: [{ 
         start: 1,end: 9, label: '确诊1-9人', color: '#4df8f2'},
            { 
        start: 10, end: 99, label: '确诊10-99人', color: '#54c9c9'},
			{ 
        start: 100, end: 999, label: '确诊100-499人', color: '#3db9b6'},
            { 
        start: 1000, end: 9999, label:'确诊500-9999人', color: '#1f8684'},
            { 
        start: 10000, label: '大于等于1000人', color: '#30867a'}],
    },
    //配置属性
    series: [{ 
        
        name: '现有确诊人数',
        type: 'map',
        mapType: '湖北',
        roam: true, //拖动和缩放
        itemStyle: { 
        
            normal: { 
        
                borderWidth: 1.5, //区域边框宽度
                borderColor: 'rgb(2,9,30)', //区域边框颜色
                areaColor: "rgba(100,215,250,0.6)", //区域颜色
            },
            emphasis: { 
         //鼠标滑过地图高亮的相关设置
                borderWidth: 1.5,
                borderColor: '#ffffff',
                areaColor: "#01ecee",
            }
        },
        label: { 
        
            normal: { 
        
                show: true, //省份名称
                fontSize: 13,
                color: "rgb(1,236,238)",
            },
            emphasis: { 
        
                show: true,
                fontSize: 20,
                color: "rgb(255,255,255)",
            }
        },
        data: [] //mydata //数据
    }]
};

Ⅳ. 湖北省各市累计确诊柱状图

相关js的option代码

let dataAxis = [];
// prettier-ignore
let data = [];
let yMax = 500;
let dataShadow = [];
for (let i = 0; i < data.length; i++) { 
        
  dataShadow.push(yMax);
}
var ec_right2_Option = { 
        
	//标题样式
  title: { 
        
    text: '湖北各市累计确诊',
    textStyle: { 
        
      color: '#ffffff',
    },
  },
  grid:{ 
        
    left : '16%',
    top : '17%',
    bottom : '10%',
  },

  xAxis: { 
        
    data: dataAxis,
    axisLabel: { 
        
      inside: true,
      color: '#fff'
    },
    axisTick: { 
        
      show: false
    },
    axisLine: { 
        
      show: false
    },
    z: 10
  },
  yAxis: { 
        
    axisLine: { 
        
      show: false
    },
    axisTick: { 
        
      show: false
    },
    axisLabel: { 
        
      color: 'rgba(1,236,238,0.65)'
    }
  },
  dataZoom: [
    { 
        
      type: 'inside'
    }
  ],
  series: [
    { 
        
      type: 'bar',
      showBackground: true,
      itemStyle: { 
        
        color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
          { 
         offset: 0, color: '#83bff6' },
          { 
         offset: 0.5, color: '#188df0' },
          { 
         offset: 1, color: '#188df0' }
        ])
      },
      emphasis: { 
        
        itemStyle: { 
        
          color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
            { 
         offset: 0, color: '#2378f7' },
            { 
         offset: 0.7, color: '#2378f7' },
            { 
         offset: 1, color: 'rgba(1,236,238,0.65)' }
          ])
        }
      },
      data: data
    }
  ]
};
// Enable data zoom when user click bar.
const zoomSize = 6;
ec_right2.on('click', function (params) { 
        
  console.log(dataAxis[Math.max(params.dataIndex - zoomSize / 2, 0)]);
  ec_right2.dispatchAction({ 
        
    type: 'dataZoom',
    startValue: dataAxis[Math.max(params.dataIndex - zoomSize / 2, 0)],
    endValue:
      dataAxis[Math.min(params.dataIndex + zoomSize / 2, data.length - 1)]
  });
});

该模块展示完毕。

④ 便民信息可视化模块(检测信息模块)


Ⅰ. 地图模块

相关js代码:

var map = new AMap.Map('container', { 
        
    resizeEnable: true,
    center: [114.338783, 30.348732],
    zoom: 15,
    viewMode: '3D' //使用3D视图
});
AMap.plugin('AMap.ToolBar', function() { 
        
    var toolbar = new AMap.ToolBar();
    map.addControl(toolbar)
});

var marker = new AMap.Marker({ 
        
    position: map.getCenter(), //标记的位置坐标
    offset: new AMap.Pixel(-5, -5), //标记相对位置的偏移,对应style的left和top
    icon: ico, //创建好的icon,也可以在后面使用setIcon()方法添加
    zoom: 13
});

marker.setTitle("坐标点");
marker.setLabel({ 
        
    offset: new AMap.Pixel(10, 30),// 图标尺寸
    content: "您的位置"
});

var ico = new AMap.Icon({ 
        
    size: new AMap.Size(24, 30), // 图标尺寸
    image: 'static/333.jpeg', // Icon的图像
    imageOffset: new AMap.Pixel(0, 0), // 图像相对展示区域的偏移量,适于雪碧图等
    imageSize: new AMap.Size(24, 30) // 根据所设置的大小拉伸或压缩图片,对应style的width和height
});
map.add(marker); //将创建好的marker放到地图上面

Ⅱ. 疫苗接种率圆环图及每百人疫苗接种率

相关js的option代码:

#疫苗接种率圆环图
var bo_cav_1_Option = { 
        
  	title: { 
        
		text: "疫苗接种率",
		textStyle: { 
        
			color: '#ffffff',
		},
		left: 'center',
	},
  tooltip: { 
        
    trigger: 'item'
  },
  legend: { 
        
      orient: 'horizontal',
      bottom: '3%',
      left: 'center',
      textStyle:{ 
        
        color: "rgba(153,225,241,0.6)"
      }
   },
  series: [
    { 
        
      name: '疫苗接种率',
      type: 'pie',
      radius: ['40%', '70%'],
      avoidLabelOverlap: false,
      itemStyle: { 
        
        borderRadius: 10,
        borderColor: 'rgb(255,255,255)',
        borderWidth: 1.5,
      },
      label: { 
        
        show: false,
        position: 'center',
      },
      emphasis: { 
        
        label: { 
        
          show: true,
          fontSize: '40',
          fontWeight: 'bold'

        }
      },
      labelLine: { 
        
        show: false
      },
      data: [
        { 
         value: /填入数据/, name: '已接种人数', itemStyle: { 
         color: '#2fc7b4' }},
        { 
         value: /填入数据/, name: '未接种人数', itemStyle: { 
         color: '#ced350' }},
      ]
    }
  ]
};



#每百人疫苗接种率
var spirit = 'image://';
var bo_cav_2_Option = { 
        
  title:{ 
        
    text:'每百人疫苗接种率',
    textStyle: { 
        
      color: '#ffffff',
    },
    left:'center'
  },
  tooltip: { 
        
    formatter:'{b}每百人接种率: {c}%',
    trigger: 'axis',
    axisPointer: { 
        
			type: 'line',
			lineStyle: { 
        
				color: '#01ecee'
			}
		},
  },
  xAxis: { 
        
    max: 100,
    splitLine: { 
        show: false},
    offset: 10,
    axisLine: { 
        
      lineStyle: { 
        
        color: 'rgba(153,225,241,0.6)'
      }
      },
    axisLabel: { 
        
      margin: 10
    }
    },
  yAxis: { 
        
    data: ['中国', '全球'],
    inverse: true,
    axisTick: { 
        show: false},
    axisLine: { 
        show: false},
    axisLabel: { 
        
      margin: 15,
      color: 'rgba(153,225,241,0.84)',
      fontSize: 16
    },
    },
  grid: { 
        
    top: 'center',
    height: 180,
    left: 70,
    right: 100,
  },
  series: [{ 
        
    //实际数据
    type: 'pictorialBar',
    symbol: spirit,
    symbolRepeat: 'fixed',
    symbolMargin: '5%',
    symbolClip: true,
    symbolSize: 30,
    symbolBoundingData: 100,
    data: [{ 
        'name': '中国', 'value': 53.02}, { 
        'name': '全球', 'value': 26.83}],
    markLine: { 
        
      symbol: 'none',
      label: { 
        
        formatter: 'max: {c}%',
        position: 'start'
      },
      lineStyle: { 
        
        color: 'rgba(153,225,241,0.84)',
        type: 'dotted',
        opacity: 0.5,
        width: 3
      },
      data: [{ 
        
        type: 'max'
      }]
    },
    z: 10
  }, { 
        
    //对比数据
    type: 'pictorialBar',
    itemStyle: { 
        
      normal: { 
        
        opacity: 0.2
      }
      },
    label: { 
        
      show: true,
      formatter: function (params) { 
        
        return params.value + ' %';
        },
      position: 'right',
      offset: [10, 0],
      color: 'rgba(153,225,241,0.84)',
      fontSize: 18
    },
    animationDuration: 0,
    symbolRepeat: 'fixed',
    symbolMargin: '5%',
    symbol: spirit,
    symbolSize: 30,
    symbolBoundingData: 100,
    data: [{ 
        'name': '中国', 'value': 53.02}, { 
        'name': '全球', 'value': 26.83}],
    z: 5
  }]
};



#全球疫苗接种率圆环图
var bo_cav_3_Option = { 
        
    title: { 
        
        text: '全球接种疫苗比率',
        //subtext: 'by Krystal',
        textStyle: { 
        
            color: '#ffffff',
        },
        left: 'center'
    },
    tooltip: { 
        
        trigger: 'item',
        formatter:'{b}:{c}剂'
    },
    legend: { 
        
        orient: 'horizontal',
        bottom: '3%',
        textStyle:{ 
        
            color: "rgba(153,225,241,0.6)"
        }
    },
    series: [
        { 
        
            name: '全球接种疫苗比率',
            type: 'pie',
            radius: '50%',
            itemStyle: { 
        
                borderRadius: 10,
                borderColor: 'rgb(255,255,255)',
                borderWidth: 1.5,
            },
            data: [{ 
        value: 763065000, name: '中国接种', itemStyle: { 
         color: '#ff5858' }},
                { 
        value: 2091617616, name: '海外接种', itemStyle: { 
         color: 'rgb(7,214,252)' }}
            ],
            emphasis: { 
        
                itemStyle: { 
        
                    shadowBlur: 10,
                    shadowOffsetX: 0,
                    shadowColor: 'rgba(0, 0, 0, 0.5)'
                }
            }
        }
        ]
};

该模块展示完毕。

⑤ 学生信息可视化模块(信息服务模块)


Ⅰ. 我校学生实际返校占比圆环复合图(双圆环图)
相关js的option代码:

var students_Option = { 
        
  title: { 
        
    text: '我校学生实际返校占比统计',
    left:'center',
    textStyle: { 
        
      color: '#ffffff',
    },
  },
  tooltip: { 
        
    trigger: 'item',
    formatter: '{a} 
{b}: {c} ({d}%)'
}, legend: { bottom: 5, icon: "circle", textStyle:{ color: "rgba(8,202,222,0.63)" }, data: [ '信息工程学院', '经济与管理学院', '人文学院', '艺术与传媒学院', '继续教育学院', '国家教育学院', ], }, series: [ { name: '各年级实际返校占比统计', type: 'pie', selectedMode: 'single', radius: [0, '30%'], itemStyle: { borderRadius: 10, borderColor: 'rgb(255,255,255)', borderWidth: 1, }, label: { position: 'inner', fontSize: 14 }, labelLine: { show: true }, data: [ { value: /填入数据/, name: '大一' }, { value: /填入数据/, name: '大二' }, { value: /填入数据/, name: '大三' }, { value: /填入数据/, name: '大四', selected: true } ] }, { name: '各级学院实际返校占比', type: 'pie', radius: ['45%', '60%'], itemStyle: { borderRadius: 10, borderColor: 'rgb(255,255,255)', borderWidth: 1, }, labelLine: { length: 20 }, label: { formatter: '{a|{a}}{abg|}\n{hr|}\n {b|{b}:}{c} {per|{d}%} ', backgroundColor: '#F6F8FC', borderColor: '#8C8D8E', borderWidth: 1, borderRadius: 4, rich: { a: { color: '#6E7079', lineHeight: 22, align: 'center' }, hr: { borderColor: '#8C8D8E', width: '100%', borderWidth: 1, height: 0 }, b: { color: '#4C5058', fontSize: 14, fontWeight: 'bold', lineHeight: 33 }, per: { color: '#fff', backgroundColor: '#4C5058', padding: [3, 4元器件数据手册
IC替代型号,打造电子元器件IC百科大全!

相关文章