与windows的计算器差不多,不需要太复杂,只要有+,-,*,/就可以啦!!!

解决方案 »

  1.   

    C:\Program Files\Microsoft Visual Studio\MSDN98\98VS\2052\SAMPLES\VB98\Calc
      

  2.   

    ' ------------------------------------------------------------------------
    '               Copyright (C) 1994 Microsoft Corporation
    '
    ' You have a royalty-free right to use, modify, reproduce and distribute
    ' the Sample Application Files (and/or any modified version) in any way
    ' you find useful, provided that you agree that Microsoft has no warranty,
    ' obligations or liability for any Sample Application Files.
    ' ------------------------------------------------------------------------
    Option Explicit
    Dim Op1, Op2                ' Previously input operand.
    Dim DecimalFlag As Integer  ' Decimal point present yet?
    Dim NumOps As Integer       ' Number of operands.
    Dim LastInput               ' Indicate type of last keypress event.
    Dim OpFlag                  ' Indicate pending operation.
    Dim TempReadout' Click event procedure for C (cancel) key.
    ' Reset the display and initializes variables.
    Private Sub Cancel_Click()
        Readout = Format(0, "0.")
        Op1 = 0
        Op2 = 0
        Form_Load
    End Sub' Click event procedure for CE (cancel entry) key.
    Private Sub CancelEntry_Click()
        Readout = Format(0, "0.")
        DecimalFlag = False
        LastInput = "CE"
    End Sub' Click event procedure for decimal point (.) key.
    ' If last keypress was an operator, initialize
    ' readout to "0." Otherwise, append a decimal
    ' point to the display.
    Private Sub Decimal_Click()
        If LastInput = "NEG" Then
            Readout = Format(0, "-0.")
        ElseIf LastInput <> "NUMS" Then
            Readout = Format(0, "0.")
        End If
        DecimalFlag = True
        LastInput = "NUMS"
    End Sub' Initialization routine for the form.
    ' Set all variables to initial values.
    Private Sub Form_Load()
        DecimalFlag = False
        NumOps = 0
        LastInput = "NONE"
        OpFlag = " "
        Readout = Format(0, "0.")
        'Decimal.Caption = Format(0, ".")
    End Sub' Click event procedure for number keys (0-9).
    ' Append new number to the number in the display.
    Private Sub Number_Click(Index As Integer)
        If LastInput <> "NUMS" Then
            Readout = Format(0, ".")
            DecimalFlag = False
        End If
        If DecimalFlag Then
            Readout = Readout + Number(Index).Caption
        Else
            Readout = Left(Readout, InStr(Readout, Format(0, ".")) - 1) + Number(Index).Caption + Format(0, ".")
        End If
        If LastInput = "NEG" Then Readout = "-" & Readout
        LastInput = "NUMS"
    End Sub' Click event procedure for operator keys (+, -, x, /, =).
    ' If the immediately preceeding keypress was part of a
    ' number, increments NumOps. If one operand is present,
    ' set Op1. If two are present, set Op1 equal to the
    ' result of the operation on Op1 and the current
    ' input string, and display the result.
    Private Sub Operator_Click(Index As Integer)
        TempReadout = Readout
        If LastInput = "NUMS" Then
            NumOps = NumOps + 1
        End If
        Select Case NumOps
            Case 0
            If Operator(Index).Caption = "-" And LastInput <> "NEG" Then
                Readout = "-" & Readout
                LastInput = "NEG"
            End If
            Case 1
            Op1 = Readout
            If Operator(Index).Caption = "-" And LastInput <> "NUMS" And OpFlag <> "=" Then
                Readout = "-"
                LastInput = "NEG"
            End If
            Case 2
            Op2 = TempReadout
            Select Case OpFlag
                Case "+"
                    Op1 = CDbl(Op1) + CDbl(Op2)
                Case "-"
                    Op1 = CDbl(Op1) - CDbl(Op2)
                Case "X"
                    Op1 = CDbl(Op1) * CDbl(Op2)
                Case "/"
                    If Op2 = 0 Then
                       MsgBox "Can't divide by zero", 48, "Calculator"
                    Else
                       Op1 = CDbl(Op1) / CDbl(Op2)
                    End If
                Case "="
                    Op1 = CDbl(Op2)
                Case "%"
                    Op1 = CDbl(Op1) * CDbl(Op2)
                End Select
            Readout = Op1
            NumOps = 1
        End Select
        If LastInput <> "NEG" Then
            LastInput = "OPS"
            OpFlag = Operator(Index).Caption
        End If
    End Sub' Click event procedure for percent key (%).
    ' Compute and display a percentage of the first operand.
    Private Sub Percent_Click()
        Readout = Readout / 100
        LastInput = "Ops"
        OpFlag = "%"
        NumOps = NumOps + 1
        DecimalFlag = True
    End Sub
      

  3.   

    那不是一个网址,是MSDN带的一个例子,你在你的机器上装一个MSDN的帮助就可以了