宅家无聊,不如学点技术!
最近新冠病毒导致的肺炎疫情,很多人都只能宅在家里。为了不让自己那么无聊,给自己找点事情,做一个**“疫情数据信息实时监控项目”**,去年开始学习的Qt/C++,拿这个小项目练练手吧。当然如果你也和我一样,建议你使用熟悉的编程语言自己实现一下,即学习了知识,又打发了时间。在做之前我先去Github上搜索了一下,看看有没有相关资料,看来已经有很多人在做了:
不过大多都是基于JavaScript或Python的项目,使用Qt/C++平台开发的还没有。
界面也很简单,主要包括实时数据和历史数据的显示,实时疫情动态信息的显示,辟谣信息的展示。数据来自腾讯新闻,UI设计参考了腾讯新闻的界面。
一共使用了两个数据接口,来自腾讯新闻,一个是包括实时数据、历史数据和疫情动态的接口,一个是包含辟谣信息的接口。
功能也很简单:
现在,各大网站都发布了自己的实时疫情显示平台,如丁香园、腾讯、新浪、百度、知乎、网易等等,包括个人开发者也开发了一些接口,数据都是来自国家或各地卫健委发布的信息。
https://ncov.dxy.cn/ncovh5/view/pneumonia
https://news.qq.com/zt2020/page/feiyan.htm
https://news.sina.cn/zt_d/yiqing0121
https://voice.baidu.com/act/newpneumonia/newpneumonia
https://www.zhihu.com/special/19681091
https://news.163.com/special/epidemic/
我使用的是腾讯数据源,数据为JSON格式, 也很容易解析。下面我以Chrome浏览器为例,演示如何获取腾讯数据接口的地址。
打开链接之后,按F12,切换到开发者模式。再次刷新网页,切换到Network,按Ctrl+F搜索当前全国确诊的人数:44765,然后回车,可以看到这个数据包含在一个JSON字符串中,而这个字符串是某一个请求地址返回的数据,而这个地址,就是数据的接口地址。
为了证实这个接口是正确的,我们复制这个地址,然后在地址栏输入回车,可以看到返回了一大堆字符串:
说明我们的地址找对了。完整的地址:
https://view.inews.qq.com/g2/getOnsInfo?name=disease_h5&callback=jQuery34109263209025042043_1581518730600&_=1581518730601
其中:
callback=jQuery34....00
参数是指定的回调函数名,可省略。_=1581518730601
是时间戳,可用于查询历史数据,可省略。时间戳是指格林威治时间1970年01月01日00时00分00秒(北京时间1970年01月01日08时00分00秒)起至现在的总毫秒数。
所以,如果想获取最新数据,以上两个参数可省略:
https://view.inews.qq.com/g2/getOnsInfo?name=disease_h5
如果想获取历史数据,只需要修改时间戳即可,其他网站的接口地址获取方式也大同小异。
这里我们只使用腾讯新闻的接口就够了,保存JSON文件,并格式化处理,可以看到包括的信息:
对于腾讯的这个数据,不得不多说一句,最近几天腾讯的JSON数据更新了好几次:
JSON数据文件的大小也从最开始的80KB到现在的160KB左右了。
对于谣言信息,腾讯是放在了另外两个接口,一个是查询最新的辟谣信息,一个是获取一条辟谣信息的详细内容。同理,和上面的数据接口地址获取的方法一样,我们可以获取到这两个地址。
查询最新的辟谣信息的地址:
https://vp.fact.qq.com/loadmore?page=0&callback=jQuery34109263209025042043_1581518730600&_=1581518730603
参数和数据接口一样,函数名和时间戳可省略:https://vp.fact.qq.com/loadmore?page=0
JSON文件格式:
在这个接口里,包含最新的10条辟谣信息,每条辟谣信息中包括标题,发布者,发布时间,图片地址,谣言类型,谣言id等。通过另一个接口,我们可以查询某一条辟谣新闻的详细信息。
如这条辟谣新闻:
我们访问这样一个地址: https://vp.fact.qq.com/miniArtData?id=a2141851348ee5f3772c761e25bb57d7
,就会得到这条谣言新闻的JSON格式详细信息,如下:
这个接口在我们实际开发中并没有使用,而是直接调用浏览器去打开这个地址的网页地址:
https://vp.fact.qq.com/article?id=8be33c500e00257c97419ac24ab59d8f
,不过这个界面是针对手机端的,电脑端的浏览效果并不好:
手机端:
主要涉及到的Qt知识如下:
QCustomplot绘图:
辟谣信息显示:
整个开发的过程,就是解决一个一个问题的过程,很多控件都是第一次使用,好在资料很多,主要难点如下:
历史数据折线图显示:
实时疫情新闻显示:
实时辟谣信息显示:
为了让没有安装Qt环境的用户也能用上我们开发的Qt程序,我们需要对生成的程序文件进行打包和发布,首先使用Qt自带的windeploy filename.exe
命令,添加运行这个程序所需要的所有组件,然后使用程序打包软件把这个文件打包成一个setup.exe
安装文件,用于在别的电脑上安装,或者是打包成一个绿色版软件,直接双击运行,我使用以下两个软件进行打包。
本项目Qt工程所有的代码和安装包下载地址,我都已经开源,如下:
https://github.com/whik/qt_2019_ncov
https://gitee.com/whik/qt_2019_ncov
如果你已经关注了我的公众号(ID:mcu149),可以在后台回复:疫情监控,我会把Qt工程发送给你。
总体来说,这个小项目使用到的Qt知识都是基础的,可以适合作为练手项目。还是有很多值得优化的地方:
虽然现在疫情有所缓解,但我们还是不要掉以轻心,好好宅家,趁着有时间,不如多陪陪家人,看几本书,看几部经典电影。专业的事交给专业的人去做,而我们只需要做好我们自己应该做的即可。
钟南山:我们已经采取强力的措施,特别是早发现、早隔离,这两条做到了,我们有足够的信心防止大爆发或者重新大爆发。
www.wangchaochao.top
mcu149