(一)概览
学习机房收费时,当我们对它有个大概了解,能够理清基本内在逻辑关系以后,就该动手操作了。我刚敲得的时候,逻辑还比较混乱,以为大概都明白,其实不然。对上下机这部分看法也一直停留在它太难,完全不知道怎么办的阶段,耽误了很多时间,其实不管看起来多难的内容,都一定要动手实践,动手的过程就是很好的学习过程。
学习上下机之前,我们需要知道上下机的按钮怎样可以添加到MDI窗体上,其实就是在窗体上添加一个pictureBox控件,其他操作则都是在pictureBox上进行。
学习上下机,我们需要先通过原程序分析该程序的内在逻辑,初步了解程序是以怎样的逻辑与顺序在运行,再看它实际运行的效果,最后对上下机画一个简单的流程图或导图(这一阶段动手画图很重要)。当完成对上下机的流程学习后,代码自然就顺理成章了。
(二)导图
(三)思路分析
1.上机
上机部分,我们的大概思路是:首先判断卡号文本框是否为空,若是,提示,若否,判断该卡号是否注册(存在),若否,给出提示,若是,判断该卡号是否正在上机,若是,提示,若否,查看数据库中该卡号用户的余额是否充足,若否,给出提示,若是,允许上机,此时上机成功。
总之,上机需满足的条件就是:1.卡号不为空 2.卡号已注册 3.该卡号未上机 4.余额充足
2.下机
下机部分的大概思路和上机有很大相似之处,首先判断卡号文本框是否为空,若是,提示,若否,判断该卡号是否注册(存在),若否,给出提示,若是,判断该卡号是否正在上机,若否,提示,若是,允许下机,此时下机成功。
总之,下机需满足的条件就是:1.卡号不为空 2.卡号已注册 3.该卡号已上机 4.余额充足
(四)其他
1.计算消费时间(t)
datediff函数
消费时间
(注:一定要将日期和时间都进行比较)
(1) t=当前时间-登录时间
代码如下:
contime = DateDiff("n",Onlmrc.Fields(9),Format(Now(),"yyyy-mm-dd hh:mm:ss"))(2)t=( 当前日期-登录日期)+( 当前时刻-登录时刻)
代码如下:
Time1 = DateDiff("n",Trim(txtOndate.Text),Trim(txtOffdate.Text)) Time2 = DateDiff("n",Trim(txtOntime.Text),Trim(txtOfftime.Text)) contime = Val(Time1 + Time2)
2.计算消费金额(m)
概念
下机部分的难点在于计算消费金额,在这里主要涉及到几对概念:
(2)消费金额与时间的关系:消费时间,准备时间,至少上机时间,递增单位时间
(3)下机方式:正常下机,强制下机
具体分析
(1)固定用户和临时用户由于单位费用不同,所以当消费时间超过至少上机时间时,要分开计算,但计算方法一致。
(2)计算
0<消费时间<=准备时间,m=0
准备时间<消费时间<=至少上机时间,m=单位金额*至少上机时间
消费时间>至少上机时间,m=(上机时间-准备时间)/递增单位时间*单位金额
(3)当用户余额充足,可以自己选择时间下机
当用户余额不足,系统会强制用户下机(此时需要程序利用timer事件,每固定时间比较该账户余额与最低余额之间的关系,一旦账户余额<最低余额,便强制用户下线。)
实际操作
1.计算消费金额时,常用到round函数。
round函数
作用:按指定的位数对数值进行四舍五入
语法:round(需要四舍五入的数字,四舍五入后数字的目标位数)
2.计算消费金额的代码:
If contime <= Basmrc.Fields(4) Then '消费时间<=准备时间 Consume = 0 ElseIf contime <= Basmrc.Fields(3) Then '消费时间<=至少上机时间 If txtType.Text = "固定用户" Then '固定用户消费 '消费金额=消费时间/60分钟 * 单位金额 Consume = Basmrc.Fields(0) / 60 * Basmrc.Fields(3) Else '临时用户消费 Consume = Basmrc.Fields(1) / 60 * Basmrc.Fields(3) End If ElseIf contime > Basmrc.Fields(3) Then '消费时间>至少上机时间 If txtType.Text = "固定用户" Then '计算消费金额时四舍五入 Consume = Round(((contime - Basmrc.Fields(4)) / 60) * Basmrc.Fields(0),2) Else Consume = Round(((contime - Basmrc.Fields(4)) / 60) * Basmrc.Fields(1),2) End If End If