(呕心沥血 仅供参考)
测试效果演示
用appinventor制作课本记背应用程序(基于遗忘曲线设计)
目录
效果演示
项目重难点
总体设计
系统功能模块设计
总体结构如下图所示:
功能模块
详细设计与实现
登录界面
界面与功能总体设计
“账号密码列表”数据库设计
“注册/修改密码”按钮功能设计与实现
“登录按钮”按钮的功能设计与实现
录入新课界面
界面与功能整体设计
对应账号课文列表数据库的设计
日期选择功能与时间相关功能设计与实现
判断课文是否需要复习的相关功能设计与设计
存储当前课文相关信息的功能设计与实现
复习清单界面
界面与功能整体设计
复习清单功能设计与实现
语言复习界面
界面与功能整体设计
课文正确率数据库设计
语言识别功能的设计与实现
“对比正确率”和“总体正确率”按钮相关功能与实现
文本比较算法的设计(难能可贵,脑子烧了)
复习率统计界面
正确率数据的查找
测试
测试计划
测试结果
不足与展望
存在问题
未来展望
项目重难点
1.整体系统功能的设计、设计模式框架的搭建
2.使用人工智能API--OCR功能和语音转文字
3.文本正确率对比设计
4.数据库关系模型搭建
总体设计
系统功能模块设计
总体结构如下图所示:
功能模块
(1)登录页面:进行账号登陆功能:进入登录界面输入账号密码,如果忘记密码或者还没有账号,可以选择“注册/修改密码”按钮。
(2)录入新课界面:选择当前的日期,输入课文的标题,点击“添加并识别内容”按钮,会调用照相机进行拍照,利用OCR识别文字,点击“完成”按钮进行数据的存储,并进入到复习界面。
(3)复习清单界面:显示根据艾宾浩斯遗忘曲线设置的复习间隔时间和复习次数,可以选择清单中的课文,进入到语音复习界面。
(4)语音复习界面:可以点击“开始复习按钮”进行语音转文字的过程,当文本输入完成后,点击“对比正确率”按钮即可看到自己的正确率,点击“总体正确率”按钮可以进入到复习率统计界面。
(5)复习率统计界面:看到某个账号对应某篇课文的复习正确率曲线。
(6)结束界面: 点击“退出”按钮,关闭app,点击“返回”按钮,回到登录界面
详细设计与实现
登录界面
界面与功能总体设计
主要是实现用户登录功能,界面设计如下图所示:
“账号密码列表”数据库设计
将存储用户账号密码的数据库命名为“账号密码列表”,使用appinventor中的微数据库(存储空间地址为TinyDB1—默认地址,可以在其他界面调用)来存储数据,微数据库的使用类似于python中字典的使用,便签相当于字典的键,其中的二维列表相当于字典的值。
设计的数据示例如下:
{“账号密码列表”:[ [账号1,密码1],[账号2,密码2] ] } 账号为唯一标识。
“注册/修改密码”按钮功能设计与实现
当用户没有账号时或者是忘记了密码时可以按这个按钮进行设置,核心代码如下图所示:
1)确保账号和密码不为空。
2)如果都不为空,就判断是否已经有该账号(有的话进行的是修改密码的操作,没有的话进行的是注册账号的操作)。
3)修改密码----遍历从微数据库中获取到的“账号密码列表”,遍历到对应账号的列表项,修改列表的第2项(密码)为当前密码输入文本框的内容。
4)注册账号----创建列表追加到目前的账号密码列表。
5)最后进行微数据库中“账号密码列表”的更新。
“登录按钮”按钮的功能设计与实现
当用户在文本框中输入账号和密码后,点击该按钮,进行账号和密码的判断,核心代码如下图所示:
1)遍历微数据库中存储的“账号密码列表”是否有对应的账号和密码。
2)如果有就进入到录入新课界面并传递账号参数(唯一标识),如果没有就显示短暂的消息提醒。
录入新课界面
界面与功能整体设计
选择当前的日期,输入课文的标题,点击“添加并识别内容”按钮,会调用照相机进行拍照,利用OCR技术识别文字,点击“完成”按钮进行今天需要复习的课文相关信息的存储,并进入到复习界面,界面设计如下图所示:
对应账号课文列表数据库的设计
①将存储某个用户的课文列表的数据库命名为“xxx” (“xxx”为账号密码列表中的账号),存储每个账号对应的课文列表,而课文列表包括了5个参数:标题、内容、课文上次学习时间、是第几次学习、是否应该复习,数据库设计示例如下:
数据示例: { XXX:[ [ 标题一,内容一,2024-4-2,0,0 ],
[ 标题二,内容二,2024-3-13,2,1 ] ]
XXX1:[ [ 标题一,内容一,2024-4-2,0,0 ],
[ 标题二,内容二,2024-3-13,2,1 ] ]
} 说明:账号为唯一标识,用于区别不同的课文列表
②用微数据库存储某个用户的上次登录时间(只有一个数据),命名为“xxx上次登录时间”,该数据可用于语音复习界面更新某个课文“上次学习时间”和用于下一次相隔时间的计算。
③用微数据库存储某个用户的上次登录时间和现在时间对比的登录相隔时间(只有一个数据),命名为“xxx相隔时长”,会用到复习清单界面的时间提醒标签上。
日期选择功能与时间相关功能设计与实现
①登录相隔时间的计算,用于显示在复习清单界面中。
当设置了当天的日期,就跟上次登录的时间进行对比,主要是通过调用“距离上一次学习的时长”函数并且传递数据库中的上次登录时间和当前输入的时间(日期选择框设定的时间),从而实现这个功能,核心代码如下图所示:
其中“具体上一次学习的时长”函数的设计主要是通过循环累加天数来统计相隔的时长,其中还涉及了是否为闰年、具体月份天数的判断,核心代码如下图所示:
在录入新课界面和课文清单界面用的微数据库是同一个地址,在本界面进行数据的存储,因而能在课文清单界面中的“时间提示”标签中进行显示,核心代码如下图所示:
②日期选择功能
当在日期选择框中完成了日期的设定,在上一步计算好相隔时间后,就更新“xxx上次登录时间”的数据库,方便下次再登录该界面时进行时间相隔的计算。
判断课文是否需要复习的相关功能设计与设计
功能设计如下:
当用户登录后,会利用用户的账号寻找存储其对应的课文列表,并更新当前的时间,判断该课文是否需要复习,如果需要复习,则会转递到课文清单界面进行选择。当日期选择后,如果该用户的课文列表不为空,就会根据当前的时间进行更新课文列表的操作,涉及到的代码如下图所示:
如上图,主要是通过遍历课文列表中的每一个课文项,根据当前登录时间、课文录入时间、已复习次数进行条件的设置,从而判断该课文是否应该要复习了,并进行数据的替换,具体时间判断逻辑如下表所示:
每篇课文会提醒复习4次。从你开始录入课文开始计时。 第一次复习在录入后第1周 第二次复习在录入后第3周 第三次复习在录入后第6周 第四次复习在录入后 第9周 | 第几次学习 | 要复习的相隔时间 | 说明 |
0 | 0天 | 之前录入的一次都没有复习的课文,就会更新一下日期,等价于这次录入的新课文,从这个时间开始计算遗忘曲线的周期 | |
1 | 7天 | 之前已经学习过一次,在一周后进行复习 | |
2 | 14天 | 相隔2周(第一周和第三周间隔) | |
3 | 21天 | 相隔3周(第三周和第六周间隔) | |
4 | 21天 | 相隔3周(第六周和第九周间隔)当复习完(第5次学习)后,课文就不会再出现显示在复习清单中 |
存储当前课文相关信息的功能设计与实现
功能设计如下:
首先是在标题的文本输入框中输入课文的标题,然后点击“添加并识别内容”按钮,去调用百度智能云的OCR技术的API接口,将识别到的文本显示在内容的文本输入框中,进行修改后,点击“完成”按钮,实现课文的存储和界面的跳转。
①“添加并识别内容”按钮功能设计
具体的逻辑顺序为,当界面初始化时,先会去访问token客户端的网址,发送GET请求(需要自己注册百度智能云账号,获取到API_id和API_secret,从而确定要访问的URL是什么),获取到acess_token参数,当按钮被点击时,先会调用照相机拍照,当照相机拍照完成后,就会利用相机获取到的图像文件路径和之前获取到的acess_token参数向Http客户端2发送POST请求,调用对应的API服务,核心代码如下图所示:
涉及到的智能百度云的界面如下图所示:
(get)
(post)
当点击完成按钮时,会根据输入的课文标题、OCR识别并自己调整后的课文内容进行课文的保存,核心代码如下图所示,主要是调用“保存课文”函数,向下一个界面(复习清单界面)转递用户名参数。(复习清单界面通过同一个地址的数据库能获取到应当复习的课文)
因为保存的课文是刚录入的课文,因此是当天需要复习的课文,课文的第4项(第几次学习)为0,第5项(是否应该学习)为1(应当学习)。最后将当前课文追加到课文列表,保存到对应账户名的数据库数据,函数代码设计如下图所示:
复习清单界面
界面与功能整体设计
显示根据艾宾浩斯遗忘曲线设置的复习间隔时间和复习次数,可以选择清单中的课文,进入到语音复习界面,界面如下图所示:
复习清单功能设计与实现
①获取要复习的课文列表,主要是通过获取数据库中存储的该账号(从录入新课界面传递过来的参数)的课文列表,判断其中哪些是需要复习的课文(判断课文项的第5项是否为1)。核心代码如下图所示:
②当点击“查看清单”按钮时,就会调用“初始化课表显示框”函数,appinventor中的列表显示框模块可以通过“,”来实现元素的分割/换行。
显示的课文样例(标题 点击 已复习次数: 上次学习日期)如下:
主要是取出应背课文列表中的元素,通过“合并文本”的积木,依次连接各个课文项,核心代码如下图所示:
最后当我们选择列表选择框的某一项时,就传递存储用户名和对应课文的标题的列表到语音复习界面。
语言复习界面
界面与功能整体设计
可以点击“开始复习按钮”进行语音转文字的过程,当文本输入完成后,点击“对比正确率”按钮即可看到自己的正确率,点击“总体正确率”按钮可以进入到复习率统计界面,界面设计如下图所示:
课文正确率数据库设计
这里的课文正确率指的是针对某一个用户所录入的某篇课文在不同复习阶段所展现的正确率,会用于在课文正确率统计界面进行曲线的绘制。
①将存储每个用户复习课文的记录存储到一个表中,命名为“用户记录表”,每个列表项包括4个参数(ID,当前的用户名,当前复习的课文标题,当前的正确率),数据示例如下:
{“用户记录表”:[1,用户1,标题1,0.8 ],
[2,用户2,标题1,0.8 ],
[3,用户1,标题2,0.8 ],
[4,用户2,标题2,0.8 ],
[5,用户1,标题1,0.7]
} 说明:ID为唯一标识,每一个记录的ID都不同。
语言识别功能的设计与实现
主要是通过获取百度智能云中语音识别API接口参数,在appinventor中编写简单的代码,涉及到操作的图片如下:
“对比正确率”和“总体正确率”按钮相关功能与实现
①首先获取当前的复习的课文内容,是利用上一个屏幕中传递过来的账户和对应课文标题列表中的“账号”参数获取到微数据库中对应的账号的课文列表,通过“文章标题”参数遍历课文列表,从而获取到对应的课文内容,核心代码如下图所示:
②当用语音输入了文本并进行了调整,点击“对比正确率”按钮,调用“文本比对算法”函数进行正确率的计算,这里设计了当正确率大于60%时,就算复习完成,整体代码如下图所示:
同时在这个过程中会调用“添加用户记录”函数,追加当前复习的记录到“用户记录表”中,调用“更新数据库课文的复习”函数,让课文的学习次数+1,更新其上次学习时间,然后存储到对应的数据库中,代码如下图所示:
③“总体正确率”按钮,主要是设置了转递账号和对应文章标题到下一个界面的逻辑,复习率统计界面会根据这两个参数到“用户记录表”中查找对应的正确率,并绘制曲线,代码设计如下图所示:
文本比较算法的设计(难能可贵,脑子烧了)
模拟了python的jieba库,是通过基于前缀词典的前向最大匹配算法来实现词汇的划分,然后通过把两段文本通过词汇编码、计算频率转化为向量,计算它们的余弦相似度,详细的操作说明如下图所示:
核心代码如下图所示。流程:创建词汇列表(create_vocabulary和tokenize)—词频向量化(encode_text)---套用余弦函数(cosine_similarity)。
复习率统计界面
正确率数据的查找
当在语音复习界面点击了“总体正确率”按钮,就会转递有账号和文章标题的列表,根据这个数据在“用户记录表”中查找满足账号相同且文章标题相同的记录项,代码设计如下图:
并把记录项存储到“该用户记录表”的列表中,并根据这个列表的长度,创建相同长度的颜色数组、次数数组、正确率数组(每一个项为“该用户记录表”中的第4项—正确率),代码设计如下图所示:
绘制曲线功能的实现
用了现有的扩展组件,如下图所示,实现了对应的功能。
主要是通过上一步得到的次数数组、正确率数组作为x、y坐标,调用SimpleChart组件的CreateLineGraph函数绘制折线图,代码设计如下图所示:
测试
测试计划
测试结果
时间 | 界面 | |||
4.1 | ||||
4.8 |
| |||
4.10 | ||||
4.17 | ||||
4.22 | ||||
5.1 | ||||
6.10 | 只复习绝句 | |||
7.25 | 都进行复习 | |||
9.27 | ||||
最后的正确率曲线—编程小队的《绝句正确率》曲线 |
不足与展望
存在问题
①语音识别只能识别短文本,不太稳定。可能需要使用手机自带的语音转文字功能。
②日期输入必须比之前大,还没有实现通过系统自动获取时间,需要手动输入日期。
③两个百度识别(OCR、语音识别)的功能都需要保证网络的通畅。
④app用久了会卡顿,没有做屏幕的清除和关闭。
未来展望
实现更加智能的艾宾浩斯遗忘曲线,根据自己对课文的熟悉程序去调整复习的周期,在复习完后,学生可以选择自己对课文的熟悉程度,当很陌生时进入上一个周期,增加复习的次数,当觉得很熟悉时,可以进入下一个周期,提前完成任务,参考案例如下图所示: