机房收费(一)之上下机

(一)概览

       学习机房收费时,当我们对它有个大概了解,能够理清基本内在逻辑关系以后,就该动手操作了。我刚敲得的时候,逻辑还比较混乱,以为大概都明白,其实不然。对上下机这部分看法也一直停留在它太难,完全不知道怎么办的阶段,耽误了很多时间,其实不管看起来多难的内容,都一定要动手实践,动手的过程就是很好的学习过程。

       学习上下机之前,我们需要知道上下机的按钮怎样可以添加到MDI窗体上,其实就是在窗体上添加一个picturebox控件,其他操作则都是在picturebox上进行。

       学习上下机,我们需要先通过原程序分析该程序的内在逻辑,初步了解程序是以怎样的逻辑顺序在运行,再看它实际运行的效果,最后对上下机画一个简单的流程图或导图(这一阶段动手画图很重要)。当完成对上下机的流程学习后,代码自然就顺理成章了。

(二)导图


(三)思路分析

1.上机

       上机部分,我们的大概思路是:首先判断卡号文本框是否为空,若是,提示,若否,判断该卡号是否注册(存在),若否,给出提示,若是,判断该卡号是否正在上机,若是,提示,若否,查看数据库中该卡号用户的余额是否充足,若否,给出提示,若是,允许上机,此时上机成功。

        总之,上机需满足的条件就是:1.卡号不为空  2.卡号已注册  3.该卡号未上机  4.余额充足

2.下机

       下机部分的大概思路和上机有很大相似之处,首先判断卡号文本框是否为空,若是,提示,若否,判断该卡号是否注册(存在),若否,给出提示,若是,判断该卡号是否正在上机,若否,提示,若是,允许下机,此时下机成功。

        总之,下机需满足的条件就是:1.卡号不为空  2.卡号已注册  3.该卡号已上机  4.余额充足

(四)其他

1.计算消费时间(t)

计算消费时间的目的是为计算消费金额做铺垫。在这里,适用datediff函数。

datediff函数

作用:返回两个日期之间的差值。
语法:DateDiff("时间数据类型(年、月、日等 )", 开始时间, 结束时间)
时间数据类型举例:年(yy或yyyy)  月(mm或m)  日(dy或y)
                                 小时(hh)        分钟(n或mi)  秒(s或ss)

消费时间 

(注:一定要将日期和时间都进行比较) 

(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)

概念

 下机部分的难点在于计算消费金额,在这里主要涉及到几对概念

(1)用户分类:固定用户,临时用户

(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

(五)小结

            我的上下机过程真的是很曲折,错误连连 ,但正因如此,我对上下机的感受才更加深刻,也查找了更多的资料,尝试了更多的解决办法。每一个学习阶段,我们都将遇到很多问题,这便是我们学习中宝贵的财富。 而上下机部分远没有我们想象中的困难,理清逻辑关系,一切问题就会迎刃而解。



  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 87
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 87
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值