iOS实现计算器小功能

本文实例为大家分享了iOS实现计算器小功能,供大家参考,具体内容如下

本文利用ios实现计算器app,后期将用mvc结构重构

import UIKit

class CalculViewController: UIViewController {

    @IBOutlet weak var display: UILabel!

    var userIsInTheMiddleOFTypingANumber:Bool=false

    @IBAction func appendDigit(sender: UIButton) {
        let digit=sender.currentTitle!
        if userIsInTheMiddleOFTypingANumber {
        display.text=display.text!+digit
        }else{
            display.text=digit
            userIsInTheMiddleOFTypingANumber=true
        }
    }
    var operandstack:Array<Double>=Array<Double>()

    @IBAction func operate(sender: UIButton) {
        let operation=sender.currentTitle!;
        if userIsInTheMiddleOFTypingANumber {
            enter()
        }
        switch operation {
        case "×":performeOperation{$0*$1}
        case "÷":performeOperation{$1/$0}
        case "+":performeOperation{$0+$1}
        case "-":performeOperation{$1-$0}
        case "√":performeOperation{sqrt($0)}
        default:
            break
        }

    }

//    func multiply(op1:Double,op2:Double) -> Double {
//        return op1*op2;
//    }

    func performeOperation(operation:(Double,Double)->Double){
        if operandstack.count>=2 {
            displayValue=operation(operandstack.removeLast(),operandstack.removeLast())
            enter()
        }

    }

     private func performeOperation(operation:Double->Double){
        if operandstack.count>=1 {
            displayValue=operation(operandstack.removeLast())
            enter()
        }

    }

    @IBAction func enter() {
        userIsInTheMiddleOFTypingANumber=false
        operandstack.append(displayValue)
        print("operandstack=\(operandstack)")

    }

    var displayValue:Double{
        get{
            return NSNumberFormatter().numberFromString(display.text!)!.doubleValue
        }
        set{
            display.text="\(newValue)"
            userIsInTheMiddleOFTypingANumber=false
        }
    }

知识点如下

计算型属性的setter与getter
swift利用函数作为参数
swift的重载,详情参见:swift override

效果如下

增加model文件

import Foundation

class CalculatorBrain {
    private enum Op : CustomStringConvertible{
        case operand(Double)
        case UnaryOperation(String,Double->Double)
        case BinaryOperation(String,(Double,Double)->Double)

        var description:String{
            get{
                switch self {
                case .operand(let operand):
                    return "\(operand)"
                case .BinaryOperation(let symbol,_):
                    return symbol
                case .UnaryOperation(let symbol, _):
                    return symbol

                }
            }

        }

    }

    private var opstack=[Op]()
    private var knowOps=[String:Op]()

    init(){
        func learnOp(op:Op){
            knowOps[op.description]=op
        }
        learnOp(Op.BinaryOperation("×"){$0*$1})
        learnOp(Op.BinaryOperation("÷"){$1/$0})
        learnOp(Op.BinaryOperation("+"){$0+$1})
        learnOp(Op.BinaryOperation("-"){$1-$0})
        learnOp(Op.UnaryOperation("√"){sqrt($0)})
//        knowOps["×"]=Op.BinaryOperation("×"){$0*$1}
//        knowOps["÷"]=Op.BinaryOperation("÷"){$1/$0}
//        knowOps["+"]=Op.BinaryOperation("+"){$0+$1}
//        knowOps["-"]=Op.BinaryOperation("-"){$1-$0}
//        knowOps["√"]=Op.UnaryOperation("√"){sqrt($0)}
    }

    private func evaluate(ops:[Op])->(result:Double?,remainOps:[Op]){
        if !ops.isEmpty {
            var remainOps=ops;
            let op=remainOps.removeLast()
            switch op {
            case Op.operand(let operand):
                return(operand,remainOps)
            case Op.UnaryOperation(_, let operation):
                let operandEvalution=evaluate(remainOps)
                if let operand=operandEvalution.result{
                    return(operation(operand),operandEvalution.remainOps)
                }
            case Op.BinaryOperation(_, let operation):
                let operandEvlution1=evaluate(remainOps)
                if let operand1=operandEvlution1.result {
                    let operandEvlution2=evaluate(operandEvlution1.remainOps)
                    if let operand2=operandEvlution2.result {
                        return (operation(operand1,operand2),operandEvlution2.remainOps)
                    }
                }

            }
        }

        return (nil,ops)
    }

    func evaluate()->Double?{
        let (result,remainder)=evaluate(opstack)
        print("\(opstack)=\(result)with\(remainder)left over")
        return result
    }

    func pushOperand(operand:Double)->Double?{
        opstack.append(Op.operand(operand))
        return evaluate()
    }

    func performOperation(symbol:String)->Double?{
        if let operation=knowOps[symbol]{
            opstack.append(operation)
        }

        return evaluate()

    }

}

controll修改为

import UIKit

class CalculViewController: UIViewController {

    @IBOutlet weak var display: UILabel!

    var userIsInTheMiddleOFTypingANumber:Bool=false
    var brain=CalculatorBrain()

    @IBAction func appendDigit(sender: UIButton) {
        let digit=sender.currentTitle!
        if userIsInTheMiddleOFTypingANumber {
        display.text=display.text!+digit
        }else{
            display.text=digit
            userIsInTheMiddleOFTypingANumber=true
        }
    }
    //var operandstack:Array<Double>=Array<Double>()

    @IBAction func operate(sender: UIButton) {

        if userIsInTheMiddleOFTypingANumber {
            enter()
        }
        if let operation=sender.currentTitle{
            if let result=brain.performOperation(operation) {
                displayValue=result
            }else{
                displayValue=0
            }
        }

    }

    @IBAction func enter() {
        userIsInTheMiddleOFTypingANumber=false
        if let result=brain.pushOperand(displayValue){
            displayValue=result
        }else{
            displayValue=0
        }

    }

    var displayValue:Double{
        get{
            return NSNumberFormatter().numberFromString(display.text!)!.doubleValue
        }
        set{
            display.text="\(newValue)"
            userIsInTheMiddleOFTypingANumber=false
        }
    }

}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • iOS实现小型计算器

    作为一名初学者,编辑一款能够在IOS操作系统上运行的计算器是一件很值得自豪的事情,网络上虽然后很多相关的文章和代码,功能也很强大但是我感觉相关的计算器比加复杂,晦涩难懂,所以我想通过这个小小的计算器,能够帮到大家,如果有不完美的地方,还请大家多多批评指教. 首先呢,编辑这个计算器用到了两种控件,Label和Button控件,Label控件用于显示结果,而Button则是相应的键.我把计算器的键分为三种numButton,caculatorButton和clearButton.numButton主

  • 基于AngularJS实现iOS8自带的计算器

    前言 首先创建angularjs的基本项目就不说了,最好是利用yeoman这个脚手架工具直接生成,如果没有该环境的,当然也可以通过自行下载angularjs的文件引入项目. 实例详解 main.js是项目的主要js文件,所有的js都写在这个文件中,初始化之后,该文件的js代码如下 angular .module('calculatorApp', [ 'ngAnimate', 'ngCookies', 'ngResource', 'ngRoute', 'ngSanitize', 'ngTouch'

  • iOS实现简单计算器功能

    本文实例为大家分享了iOS实现简单计算器功能的具体代码,供大家参考,具体内容如下 //  ZYAppDelegate.m //  Calculator // //  Created by mac on 15-7-30. //  Copyright (c) 2015年 zhiyou. All rights reserved. //   #import "ZYAppDelegate.h"   @implementation ZYAppDelegate   - (BOOL)applicati

  • iOS开发实现计算器功能

    本文实例为大家分享了iOS实现计算器功能的具体代码,供大家参考,具体内容如下 效果图 Masonry 使用数组来自动约束 NSArray *buttonArrayOne = @[_buttonAC, _buttonLeftBracket, _buttonRightBracket, _buttonDivide]; //withFixedSpacing: 每个view中间的间距 //leadSpacing: 左最开始的间距 //tailSpacing:; 右边最后的的间距 [buttonArrayO

  • iOS实现计算器小功能

    本文实例为大家分享了iOS实现计算器小功能,供大家参考,具体内容如下 本文利用ios实现计算器app,后期将用mvc结构重构 import UIKit class CalculViewController: UIViewController {     @IBOutlet weak var display: UILabel!     var userIsInTheMiddleOFTypingANumber:Bool=false     @IBAction func appendDigit(sen

  • iOS实现简单计算器小功能

    本文实例为大家分享了iOS实现简单计算器小功能的具体代码,供大家参考,具体内容如下 SimpleCaculatorViewController.h // //  SimpleCaculatorViewController.h //  SimpleCaculator // //  Created by LI Junui on 14-2-12. //  Copyright (c) 2014年 LEE JUNHUI. All rights reserved. //   #import <UIKit/U

  • PHP实现计算器小功能

    本文实例为大家分享了PHP实现计算器小功能的具体代码,供大家参考,具体内容如下 <?php if (isset($_POST['sub'])) { $f = true; $error = "有以上问题: <br>"; if ($_POST["num1"] == "") { $f = false; $error .= "第一个数不能为空.<br>"; } else { if(!is_numeric(

  • C#实现简单的计算器小功能

    本文实例为大家分享了C#实现简单的计算器小功能的具体代码,供大家参考,具体内容如下 先来张效果图吧(5分钟写好,莫怪) 代码: 数字按钮绑定的是button_Clickd()方法 运算符按钮绑的是Button_Clickp()方法 思想:按下数字按钮,将数字按钮的值连接到textbox上,然后按下运算符判断是否为等于,并记录运算符的内容,以便后面做处理. using System; using System.Collections.Generic; using System.ComponentM

  • C#实现简易计算器小功能

    本文实例为大家分享了C#实现简易计算器小功能的具体代码,供大家参考,具体内容如下 简易的登陆界面. 具有幻灯片效果.(picturebox time控件)计算器支持多位数,小数,括号的运算. 音乐是一个练习用的小控件(Listbox),可以选择指定的歌曲播放,直接忽略掉吧. 建立winform窗体 数字和运算符都为button,输入和输出的为textbox 基本代码 在所有button控件的click事件均为加上所对应的文本.例如:数字1所对应的button就为 textBox1.Text +=

  • python实现计算器小功能

    本文实例为大家分享了python实现计算器功能的具体代码,供大家参考,具体内容如下 1. 案例介绍 本例利用 Python 开发一个可以进行简单的四则运算的图形化计算器,会用到 Tkinter 图形组件进行开发.主要知识点:Python Tkinter 界面编程:计算器逻辑运算实现.本例难度为初级,适合具有 Python 基础和 Tkinter 组件编程知识的用户学习. 2. 设计原理 要制作一个计算器,首先需要知道它由哪些部分组成.示意如下图所示. 从结构上来说,一个简单的图形界面,需要由界面

  • jquery实现计算器小功能

    本文实例为大家分享了jquery实现计算器功能的具体代码,供大家参考,具体内容如下 用jquery实现计算器对于我来说有三个难点 1.单纯的html页面,怎么实现计算2.显示屏用什么标签,又怎么把他显示出来3.要想实现删除,怎么把字符串最后一个字母删除 解决 1.看了别人的计算器,我发现eval()可以实现这个目的eg: alert(eval(“3+5”));没错,会弹出 8.2.看了几个人的博客,都是用span元素节点当显示屏,通过jQuery的html()函数来实现把内容显示出来.3.有两个

  • 微信小程序实现计算器小功能

    微信小程序现在越来越火爆了,我也看到很多在校大学生都在自学了,那些专门从事APP开发,网页开发的工作者更是看到了小程序的前景,在小程序领域也掺上一脚,本人也是自学小程序的,初期跟很多人一样,遇到一些不懂的想问问别人,到贴吧去,一大堆广告,根本没人帮忙解决问题. 今天教一些刚入门的同学做一款计算器,如果C语言是编程的最佳入门语言,那计算器应该算得上是小程序的入门demo了,希望刚入门的同学们认真品味下面的代码,从wxml到js,再到wxss(页面的布局),每个代码都要弄懂他的意思 废话不多说,先上

  • JavaScript实现简易计算器小功能

    本文实例为大家分享了JavaScript实现简易计算器的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>计算器</title> </head> <body> <!--页面布局--> <input type="text&

  • js实现简易计算器小功能

    本文实例为大家分享了js实现简易计算器的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>

随机推荐