结对作业2-疫情可视化(编程实现)
这个作业属于 | 2020软工实践W班 |
---|---|
这个作业要求在 | 作业要求 |
结对学号 | 221701333/221701340 |
作业目标 | 某次疫情可视化的实现 |
作业正文 | 如下 |
其他文献 |
- Notice:deline 2020-03-14 23:00
一. Git仓库仓库以及代码规范链接
Git仓库:https://github.com/fzu-hhj/InfectStatisticWeb
代码规范:代码规范
二.成品展示
主要功能:
扩展功能:
二.结对过程描述
即刚开始拿到题目后,和队友怎么讨论,解决问题和查找资料的过程,并提供两人结对讨论的截图。。
刚拿到题目,我们思考的是通过什么工具实现原型的功能,选择有3个:纯前端(html与js),JAVAEE和php,最后考虑到前后端分离的优越性以及对JAVAEE有初步的理解,我们尝试使用JAVAEE来完成此次作业。
出现的第二个问题是git高级功能的使用,对此我们学习了Git的帮助手册
第三个问题是地图以及折线图的实现,考虑到老师给的建议echart,我们通过网络学习了echart创建地图和折线图。
最后是框架的搭建,我们参考了JAVAEE课老师给的示例程序,搭建了由领域对象层,DAO层,业务逻辑层,控制器层,表现层组成的JAVAEE架构。
中途我们还遇到了许多的小bug,通过互助都一一解决。
三.设计实现过程
给出功能结构图。
- javaEE
四.代码说明
/*确诊患者,疑似患者,治愈者,死亡者的父类*/
public class PersonStatus {
public static String[] PROVINCE = {*****};
private String date;
private int[] num ;
public PersonStatus(String d , int[] n) {
date = d;
num = n ;
}
public String getDate() {
return date;
}
public int[] getNum() {
return num;
}
public void setDate(String date) {
this.date = date;
}
public void setNum(int[] n) {
this.num = n;
}
public int getNum(int i) {
return num[i];
}
public int getProNum(String name) {
for(int i = 0;i < PROVINCE.length;i++)
if(name.equals(PROVINCE[i]))
return i;
return -1;
}
//根据省名获得数据
public int getNum(String province) {
return num[getProNum(province)];
}
}
/*DAO层获得数据库的数据*/
public class IpDAOImpl implements IpDAO {
@Override
public List list(){
DBUtil dbUtil = new DBUtil();
List ips = new ArrayList();
try {
Connection conn = dbUtil.getConnection();
Statement stmt = conn.createStatement();
String sql = "select * from ip";
ResultSet rs = stmt.executeQuery(sql);
while(rs.next()) {
int[] a = new int[35];
for(int i = 0;i < 35 ; i++) {
a[i] = rs.getInt(i+2);
}
Ip ip = new Ip(rs.getString("时间") , a);
ips.add(ip);
}
}catch (Exception e) {
e.printStackTrace();
}
return ips;
}
/*折线图的Servlet,用DAO获得数据,传入请求的参数,然后将页面跳转到jsp*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
//response.getWriter().append("Served at: ").append(request.getContextPath());
request.setCharacterEncoding("utf-8");
IpDAO ipDAO = new IpDAOImpl();
List ips = ipDAO.list();
SpDAO spDAO = new SpDAOImpl();
List sps = spDAO.list();
CureDAO cureDAO = new CureDAOImpl();
List cures = cureDAO.list();
DeadDAO deadDAO = new DeadDAOImpl();
List deads = deadDAO.list();
request.setAttribute("ips" , ips);
request.setAttribute("sps", sps);
request.setAttribute("cures", cures);
request.setAttribute("deads", deads);
request.setAttribute("province", getProvince());
request.getRequestDispatcher("LineChart.jsp").forward(request, response);
}
//负责显示各省数据的jsp页面
<%String province = (String)request.getAttribute("province");
Ip ip = (Ip)request.getAttribute("ip");
Sp sp = (Sp)request.getAttribute("sp");
Cure cure = (Cure)request.getAttribute("cure");
Dead dead = (Dead)request.getAttribute("dead");
%>
<%=province %>
现有确诊
<%=ip.getNum(province)%>人
......
//别的标签