经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » iOS » 查看文章
iOS开发实现计算器功能
来源:jb51  时间:2021/10/11 9:22:44  对本文有异议

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

效果图

Masonry

使用数组来自动约束

  1. NSArray *buttonArrayOne = @[_buttonAC, _buttonLeftBracket, _buttonRightBracket, _buttonDivide];
  2. //withFixedSpacing: 每个view中间的间距
  3. //leadSpacing: 左最开始的间距
  4. //tailSpacing:; 右边最后的的间距
  5. [buttonArrayOne mas_distributeViewsAlongAxis:MASAxisTypeHorizontal withFixedSpacing:15 leadSpacing:15 tailSpacing:15];
  6. [buttonArrayOne mas_makeConstraints:^(MASConstraintMaker *make) {
  7. make.top.equalTo(@(selfHeight - (buttonHeight * 5 + 110)));
  8. make.height.equalTo(@(buttonHeight));
  9. }];

对最后一行单独处理

  1. [_buttonZero mas_makeConstraints:^(MASConstraintMaker *make) {
  2. make.left.equalTo(@15);
  3. make.top.equalTo(@(selfHeight - (buttonHeight + 50)));
  4. make.width.equalTo(@(buttonWidth * 2 + 15));
  5. make.height.equalTo(@(buttonHeight));
  6. }];
  7. [_buttonZero.titleLabel mas_makeConstraints:^(MASConstraintMaker *make) {
  8. make.left.equalTo(_buttonOne.titleLabel);
  9. }];
  10. //使0的数字对齐

计算部分:

  1. + (Result)CalculateFor:(char*) formula andLen: (long) length {
  2. Result result = {0, 0.0f};
  3. int numberOfDots = 0;
  4. int index;
  5. int digitsNum = 0;
  6. float digits[CALCULATE_MAX_DIGITS];
  7. memset(digits, 0, sizeof(digits));
  8. int optNum = 0;
  9. char operator[CALCULATE_MAX_OPERATOR];
  10. memset(operator, 0, sizeof(operator));
  11. int digitNum = 0;
  12. char digit[CALCULATE_MAX_DIGIT];
  13. memset(digit, 0, sizeof(digit));
  14. char *p = formula;
  15. while (length--) {
  16. switch (*p) {
  17. case '+':
  18. case '-':
  19. case '*':
  20. case '/':
  21. numberOfDots = 0;
  22. if (0 == digitNum && '-' == *p) {
  23. digit[digitNum++] = *p;
  24. } else {
  25. if (-1 == digitNum) {
  26. //刚计算过括号,符号前可以没有数字读入
  27. } else if (0 == digitNum || CALCULATE_MAX_DIGITS == digitsNum - 1) {
  28. result.error = CALCULATE_ERR;
  29. return result;
  30. } else {
  31. digits[digitsNum++] = atof(digit);
  32. memset(digit, '\0', sizeof(digit));
  33. }
  34. digitNum = 0;
  35. operator[optNum++] = *p;
  36. }
  37. break;
  38.  
  39. case '(': {
  40. char *pointer_son;
  41. int ExistEnd = 0;
  42. pointer_son = ++p;
  43. while(length--) {
  44. if ('(' == *p) {
  45. ExistEnd--;
  46. } else if (')' == *p) {
  47. ExistEnd++;
  48. }
  49. if (1 == ExistEnd) {
  50. break;
  51. }
  52. p++;
  53. }
  54. Result result_son = [self CalculateFor:pointer_son andLen:p - pointer_son];
  55. if (CALCULATE_ERR == result_son.error) {
  56. result.error = result_son.error;
  57. return result;
  58. }
  59. digits[digitsNum++] = result_son.value;
  60. memset(digit, 0, sizeof(digit));
  61. digitNum = -1;
  62. break;
  63. }
  64. case '0':
  65. case '1':
  66. case '2':
  67. case '3':
  68. case '4':
  69. case '5':
  70. case '6':
  71. case '7':
  72. case '8':
  73. case '9':
  74. case '.':
  75. digit[digitNum++] = *p;
  76. if (numberOfDots == 0 && *p == '.') {
  77. numberOfDots = 1;
  78. } else if (numberOfDots == 1 && *p == '.') {
  79. result.error = CALCULATE_ERR;
  80. return result;
  81. }
  82. break;
  83.  
  84. default:
  85. result.error = CALCULATE_ERR;
  86. return result;
  87.  
  88. }
  89. if (0 == length && 0 < digitNum) {
  90. digits[digitsNum++] = atof(digit);
  91. memset(digit, 0, sizeof(digit));
  92. digitNum = 0;
  93. }
  94. p ++;
  95. }
  96. if (digitsNum != optNum + 1) {
  97. result.error = CALCULATE_ERR;
  98. return result;
  99. }
  100. for (index = 0; index < optNum; index ++) {
  101. if ('*' == operator[index]) {
  102. digits[index + 1] = digits[index] * digits[index + 1];
  103. digits[index] = 0;
  104. operator[index] = '?';
  105. } else if ('/' == operator[index]) {
  106. if (digits[index + 1] == 0) {
  107. result.error = CALCULATE_ERR;
  108. return result;
  109. }
  110. digits[index + 1] = digits[index] / digits[index + 1];
  111. digits[index] = 0;
  112. operator[index] = '?';
  113. }
  114. }
  115. for (index = 0; index < optNum; index ++) {
  116. if ('?' == operator[index]) {
  117. if (0 == index) {
  118. operator[index] = '+';
  119. } else {
  120. operator[index] = operator[index - 1];
  121. }
  122. }
  123. }
  124. result.value = digits[0];
  125. for (index = 0; index < optNum; index ++) {
  126. if ('+' == operator[index]) {
  127. result.value += digits[index + 1];
  128. } else if ('-' == operator[index]) {
  129. result.value -= digits[index + 1];
  130. }
  131. }
  132. return result;
  133. }

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

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号