Swift写简易计算器
来源:互联网 发布:ubuntu 分辨率不能调 编辑:程序博客网 时间:2024/06/04 18:17
用Swift写一个简单计算器的Demo
实验环境:
Xcode v6.4 & OS X Yosemite 10.10
功能描述:
1、实现加减乘除+根号(结果display为Double型)2、边界适应:各元素之间的距离固定,且适应手机旋转(Roate)(学习过程,根据Stanford的Swift课程而写的程序)
代码实现:
//// ViewController.swift// Calculator//// Created by VincentYau on 4/7/16.// Copyright (c) 2016 VincentYau. All rights reserved.//import UIKitclass ViewController: UIViewController{ @IBOutlet weak var display: UILabel! var userIsInTheMiddleOfTypingANumber:Bool = false //用户是否已经输入数字,由于Swift的变量必须负初始值,所以设为false @IBAction func appendDigit(sender: UIButton){ let digit = sender.currentTitle!//直接获取Button的数字 //若已输入过数字,则直接往display中添加数字,否则直接现实新点击数字,去除原始0的操作 if userIsInTheMiddleOfTypingANumber{ display.text = display.text! + digit }else{ display.text = digit userIsInTheMiddleOfTypingANumber = true } } //对数字进行运算 @IBAction func operate(sender: UIButton) { let operation = sender.currentTitle! if userIsInTheMiddleOfTypingANumber{ enter() } switch operation{ /*swift算法极为简洁,当调用方法performOperation时,其自动对比方法的参数,而无需在 *调用方法时写明参数类型,例如,这里的参数$0 与 $1并没有指明类型,而Swift会直接将其适应为 *方法performOpetation中的Double型 */ case "×": performOperation { $0 * $1 } case "÷": performOperation { $1 / $0 } case "+": performOperation { $0 + $1 } case "−": performOperation { $1 - $0 } case "√": performOperation { sqrt($0) } default: break } } //两个参数进行运算的方法 func performOperation(operation: (Double,Double) -> Double){ if operandStack.count >= 2 { displayValue = operation(operandStack.removeLast(),operandStack.removeLast()) enter() } } //一个参数进行运算的方法,Swift支持方法的重载,但Obj-C不允许,这里继承了Obj-C的 //类UIViewColler,不能重载方法performOperation,故将其变为Private方法 private func performOperation(operation: Double -> Double){ if operandStack.count >= 1 { displayValue = operation(operandStack.removeLast()) enter() } } var operandStack = Array<Double>() //若用户点击enter,则将相应数字添加至数组Array中 @IBAction func enter() { userIsInTheMiddleOfTypingANumber = false operandStack.append(displayValue) println("operandStack = \(operandStack)") } var displayValue: Double { get{ return NSNumberFormatter().numberFromString(display.text!)!.doubleValue } set{ display.text = "\(newValue)" userIsInTheMiddleOfTypingANumber = false } }}
注意:
这里容易忽略的是,各元素之间的距离还有元素与边界的距离,设置好后如下:
0 0
- Swift写简易计算器
- swift 项目 简易计算器
- Javascript写简易计算器
- 写了一个简易计算器
- MFC下写简易计算器
- 用C写的简易计算器
- 用JS写的一个简易计算器
- C语言写的简易计算器
- js简易计算器(自写)
- 用Android写的一个简易计算器
- 用JAVA写的简易计算器
- C语言写的一个简易计算器
- JS写简易计算器的原理
- html javascript css写简易计算器
- 用swift写的计算器demo
- 简易计算器
- 简易计算器。。。
- 简易计算器
- 下拉菜单
- 宏基 F5 572g 预装win10改win7
- 一些不常被注意到的Java问题
- 栈的思想用于求解迷宫问题
- Netty线程模型
- Swift写简易计算器
- UVa 514 Rails
- 欢迎使用CSDN-markdown编辑器
- RPC Learn
- 前端开发学习笔记04---JavaScript
- 欧拉函数的两种实现
- android:paddingBottom=“@dimen/activity_horizontal_margin"的意思
- JavaScript之分之结构
- Java 的集合+IO