鄙人新手 整了 快两天 终于搞定了。。

1.首先是MainActivity 中 在Oncreate函数中 注册

2.按+ 或者 - 号 来分成两大字符串 s1 和 s2

  再将s2 分为更小的s1 和 s2 直到 s2不包含+ 或者 -号

思路就是这样,没用递归,递归速度太慢,也不擅长用递归。

3.就是找各种Bug 还有装饰

基本达成目标 和自己手机上安卓的自带计算器基本一样。

改正 双击等于 死机

改正 除数可以为0

改正 不能多个运算符

...未知

项目代码如下:

链接: http://pan.baidu.com/s/1c0dj748 密码: hkyx

写法如下package com.example.administrator.myapplication;


import android.app.Activity;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText; public class MainActivity extends Activity implements OnClickListener {
private Button bt_0;
private Button bt_1;
private Button bt_2;
private Button bt_3;
private Button bt_4;
private Button bt_5;
private Button bt_6;
private Button bt_7;
private Button bt_8;
private Button bt_9;
private Button bt_point; private Button bt_C;
private Button bt_DEL;
private Button bt_minuse;
private Button bt_multipy;
private Button bt_plus;
private Button bt_divide;
private Button bt_dengyu; private EditText input_text; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); // 注册Button
bt_0 = (Button) findViewById(R.id.bt_0);
bt_1 = (Button) findViewById(R.id.bt_1);
bt_2 = (Button) findViewById(R.id.bt_2);
bt_3 = (Button) findViewById(R.id.bt_3);
bt_4 = (Button) findViewById(R.id.bt_4);
bt_5 = (Button) findViewById(R.id.bt_5);
bt_6 = (Button) findViewById(R.id.bt_6);
bt_7 = (Button) findViewById(R.id.bt_7);
bt_8 = (Button) findViewById(R.id.bt_8);
bt_9 = (Button) findViewById(R.id.bt_9);
bt_point = (Button) findViewById(R.id.bt_point); bt_C = (Button) findViewById(R.id.bt_clear);
bt_DEL = (Button) findViewById(R.id.bt_del);
bt_minuse = (Button) findViewById(R.id.bt_minuse);
bt_multipy = (Button) findViewById(R.id.bt_multipy);
bt_plus = (Button) findViewById(R.id.bt_plus);
bt_divide = (Button) findViewById(R.id.bt_divide);
bt_dengyu = (Button) findViewById(R.id.bt_dengyu); input_text = (EditText) findViewById(R.id.edit_text1); // 监听事件
bt_0.setOnClickListener(this);
bt_1.setOnClickListener(this);
bt_2.setOnClickListener(this);
bt_3.setOnClickListener(this);
bt_4.setOnClickListener(this);
bt_5.setOnClickListener(this);
bt_6.setOnClickListener(this);
bt_7.setOnClickListener(this);
bt_8.setOnClickListener(this);
bt_9.setOnClickListener(this);
bt_point.setOnClickListener(this); bt_C.setOnClickListener(this);
bt_DEL.setOnClickListener(this);
bt_minuse.setOnClickListener(this);
bt_multipy.setOnClickListener(this);
bt_plus.setOnClickListener(this);
bt_divide.setOnClickListener(this);
bt_dengyu.setOnClickListener(this); } @Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId(); //noinspection SimplifiableIfStatement
if (id == R.id.action_settings) {
return true;
} return super.onOptionsItemSelected(item);
} @Override
public void onClick(View v) {
String str = input_text.getText().toString();
switch (v.getId()) {
case R.id.bt_0:
case R.id.bt_1:
case R.id.bt_2:
case R.id.bt_3:
case R.id.bt_4:
case R.id.bt_5:
case R.id.bt_6:
case R.id.bt_7:
case R.id.bt_8:
case R.id.bt_9:
input_text.setText(str + ((Button) v).getText());
break;
case R.id.bt_point:
if (!str.contains(".")) input_text.setText(str + ((Button) v).getText());
break;
case R.id.bt_plus:
case R.id.bt_minuse:
case R.id.bt_multipy:
case R.id.bt_divide:
if(str.equals(""));
else {
char a =str.charAt(str.length()-1);
Log.i("str",str+"");
Log.i("最后一位字符",a+"");
if( a ==' ' );
else {
input_text.setText(str + " " + ((Button) v).getText() + " ");
}
a =str.charAt(str.length()-1);
break;
}
break; case R.id.bt_clear:
input_text.setText(null);
break;
case R.id.bt_del:
if (str != null && !str.equals("")) {
input_text.setText(str.substring(0, str.length() - 1));
}
break;
case R.id.bt_dengyu:
getRseult();
break; }
} //运算结果
private void getRseult() {
String str = input_text.getText().toString();
if (str == null || str.equals(""))
return;
if(!str.contains("+") &&!str.contains("-")&&!str.contains("×")&&!str.contains("÷") )
return;
//遍历计算result
double result = 0;
char a =str.charAt(str.length()-2);
if(a == '+' || a == '-'){
str = str + '0';
}
else if(a == '×' || a == '÷'){
str = str + '1';
} int i = 0;
int start = 0;
char temp =' '; int flag = 1; if(!str.contains("+") &&!str.contains("-")){
result += calculate_include_multy_or_minuse(str);
}
else {
for (; i < str.length(); i++) {
char c = str.charAt(i); if (c == '+' || c == '-') {
String s1 = str.substring(start, i);
Log.i("S1是", s1 + "");
if(flag == 0) result -= calculate_include_multy_or_minuse(s1);
else result += calculate_include_multy_or_minuse(s1); start = i + 1; if(c == '-') flag = 0;
else flag = 1;
String s2 = str.substring(start, str.length());
Log.i("S2是", s2 + ""); if (s2.contains("+") || s2.contains("-")) {
temp = c;
continue;
}
else {
if(flag == 0) {
result -= calculate_include_multy_or_minuse(s2);
}
else result += calculate_include_multy_or_minuse(s2); }
}
}
}
int r = 0;
String result_string = Double.toString(result);
    if(Double.toString(result) == "Infinity") input_text.setText("傻啊?除数为0");
else if ((int)result == result){
r = (int)result;
input_text.setText(r + "");
}
else
input_text.setText(result + ""); } private double calculate(String s) {
double sum = 1;
int start = 0;
int flag = 0;
int flag2 = 0;
s = s + '×'; char op = ' ';
for (int i = 0; i < s.length(); i++) {
char c = s.charAt(i);
if (c == '×' || c == '÷') { if (flag2 == 0) op = c;
String s1 = s.substring(start, i);
if (flag == 0) {
sum *= Double.parseDouble(s1);
// Log.i("第一个是"," "+sum);
flag = 1;
flag2 = 1;
} else {
switch (op) {
case '×':
// Log.i("s1是"," "+s1);
sum = sum * Double.parseDouble(s1);
// Log.i("sum是"," "+sum);
break;
case '÷':
// Log.i("s2是"," "+s1);
sum = sum / Double.parseDouble(s1);
// Log.i("sum是"," "+sum);
break;
}
}
op = c;
start = i + 1;
}
}
// Log.i("sum的结果是", " " + sum); return sum;
} private double calculate_include_multy_or_minuse(String s) {
double sum = 0;
if (s.contains("×") || s.contains("÷")) {
sum = calculate(s);
} else {
sum = Double.parseDouble(s);
} return sum;
}
}

  

  

Android 计算器制作 2.注册View 构建函数的更多相关文章

  1. Android 计算器制作 1.布局

    1.activity_main.xml文件布局 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/andr ...

  2. Android模板制作

    本文详细介绍模板相关的知识和如何制作Android模版及使用,便于较少不必要的重复性工作.比如我在工作中如果要创建一个新的模块,就不要需要创建MVP相关的几个类:Model.View.Presente ...

  3. Android中制作自定义dialog对话框的实例

    http://www.jb51.net/article/83319.htm   这篇文章主要介绍了Android中制作自定义dialog对话框的实例分享,安卓自带的Dialog显然不够用,因而我们要继 ...

  4. Android项目实战登录&注册

    由于项目中大部分界面都有一个后退键和一个标题栏,为避免代码冗杂以及便于利用,我们可以将后推荐和标题栏单独抽取出来定义一个标题栏布局,在 res/layout 目录下新建一个 Layout resour ...

  5. Android——Activity中的六个主要函数

    Android Activity中的六个主要函数 Android中一个Activity一般都需要实现六个函数: onCreate(), onStart(), onResume(),onPause(), ...

  6. Android计算器简单逻辑实现

    Android计算器简单逻辑实现 引言: 我的android计算器的实现方式是:按钮输入一次,就处理一次. 但是如果你学过数据结构(栈),就可以使用表达式解析(前缀,后缀)处理. 而这个方式已经很成熟 ...

  7. Android项目实战登录&注册

    由于项目中大部分界面都有一个后退键和一个标题栏,为避免代码冗杂以及便于利用,我们可以将后推荐和标题栏单独抽取出来定义一个标题栏布局,在 res/layout 目录下新建一个 Layout resour ...

  8. .NET Core中间件的注册和管道的构建(1)---- 注册和构建原理

    .NET Core中间件的注册和管道的构建(1)---- 注册和构建原理 0x00 问题的产生 管道是.NET Core中非常关键的一个概念,很多重要的组件都以中间件的形式存在,包括权限管理.会话管理 ...

  9. request_irq() | 注册中断服务函数【转】

    本文转载自:http://blog.csdn.net/wealoong/article/details/7566546#t0 参考  : ARM Linux 中断机制分析.pdf linux-2.6. ...

随机推荐

  1. Windows To Go 制作详解

    拥有 Mac 的同学大概都会碰到一个头疼的问题,那就是使用 Windows 的使用需求.macOS 虽好,不过总是会有一些讨厌的软件没有 Mac 版本,这时就不得不在 Mac 上跑 Windows 了 ...

  2. centos7 的system

    1.vim /etc/systemd/system/alertmanager.service [Unit] Description=Alertmanager After=network-online. ...

  3. python中 __file__的小坑坑

    在python脚本中,我们难免会需要用到自身文件所在的绝对路径,第一想法可能就是用os.path.dirname(__file__) 但是这里有个大坑,我就踩了,这种方式得到路径会出现问题,脚本执行报 ...

  4. [转帖]nginx1.17.2版本源码安装

    nginx1.17.2版本源码安装 原创: 沧海书生 Ansible爱好者 昨天 公众号里面的内容 这里简单测试了下 在x86的虚拟机里面编译安装 nginx 仅make make install n ...

  5. 小菜鸟之HTML第三课

    jquery的引入 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  6. dubbo分布式服务框架-study1

    本文参考“如何给老婆解释RPC”一文进行的... 1.首先了解下dubbo: dubbo是一款高性能.轻量级的开源java RPC服务框架(RPC即远程过程调用,具体解释见:https://www.j ...

  7. SpringBoot起飞系列-自定义starter(十)

    一.前言 到现在,我们可以看出来,如果我们想用一些功能,基本上都是通过添加spring-boot-starter的方式来使用的,因为各种各样的功能都被封装成了starter,然后把相关服务注入到容器中 ...

  8. 从入门到自闭之Python--RESTful API规范与序列化

    RESTful API规范 REST全称是Representational State Transfer,中文意思是表述(编者注:通常译为表征)性状态转移. 它首次出现在2000年Roy Fieldi ...

  9. 思科设备ACL与NAT技术

    ACL 访问控制列表(Access Control Lists),是应用在路由器(或三层交换机)接口上的指令列表,用来告诉路由器哪些数据可以接收,哪些数据是需要被拒绝的,ACL的定义是基于协议的,它适 ...

  10. java实现spark常用算子之TakeSample

    import org.apache.spark.SparkConf;import org.apache.spark.api.java.JavaRDD;import org.apache.spark.a ...