基于Andriod的简易计算器

栏目: IT技术 · 发布时间: 4年前

内容简介:这学期有安卓这门课,这里做了一个简易的计算器,实现了两位数加减乘除的基本功能,比较简单适合用来入门学习。实现这个计算器之前要先了解实现计算器需要的基本组件

这学期有安卓这门课,这里做了一个简易的计算器,实现了两位数加减乘除的基本功能,比较简单适合用来入门学习。

运行效果

基于Andriod的简易计算器

预备知识

实现这个计算器之前要先了解实现计算器需要的基本组件

1.TextView

TextView是一个文本显示组件,提供了基本的显示文本功能,因为大多数UI系统组件都需要展示信息,所有它也是大多数UI系统组件的父类。

(1)TextView的常用属性和方法

属性名 对应方法 说明
android:autoLink setAutoLinkMask(int) 设置是否当文本为:URL链接、E-mail、电话号码、Map时,文本显示为可单机的链接
android:gravity setGravity(int) 设置文本框的对应方式
android:layout_gravity 设置组件本身相对于父组件的显示位置
android:lines setLines(int) 设置文本的行数,设置两行就显示两行,即使第二行没有数据
android:text setText(CharSequence) 设置文本框显示的文本内容
android:textColor setTextColor(int) 设置文本显示的颜色
android:textSize setTextSize(float) 设置文字大小,推荐度量单位"sp"
android:textStyle setTypeface(Typeface) 设置字形:粗体、斜体等
android:layout_width 设置文本框在屏幕上的宽度
android:layout_height 设置文本框在屏幕上的高度

(2)gravity和layout_gravity的属性值及说明

属性值 说明
top 顶部对齐
bottom 底部对齐
left 左边对齐
right 右边对齐
center_horizontal 横向中央位置对齐

2.Button

Button是TextView的子类,所以TextView上很多属性也可以直接应用到Button上。实际开发中对于Button操作主要是按下后执行何种操作。

(1)Button的常用属性和方法

属性名 对应方法 说明
android:clickable setClickable(boolean) 设置是否允许点击按钮(true/false)
android:background setBackgroudResource 通过资源文件设置背景色
android:onClick setOnClickListener(OnClickListener) 设置点击事件

(2)监听事件

每一个添加到UI上的Button一般都需要给它绑定监听事件,给Button绑定监听事件通常有两类方法:

  • 内部类(匿名内部类、定义内部类)
  • 给Button设置onClick属性(在代码中定义onClick指明的对应方法)

了解完了组件之后还要了解一个布局,才能将组件更好的摆放在界面上。此计算器使用线性布局实现的。

3.LinerLayout

线性布局是Android应用程序开发时较为常见的一种布局类型,它可以将用户界面上的组件拜访水平(horizontal)或垂直(vertical)的形式。

LinerLayout的常用属性和对应方法

属性名 对应方法 说明
android:orientation setOrientation(int) 设置线性布局的方向,有horizontal(水平)和vertical(垂直)两个值,必须设置
android:layout_gravity 设置组件本身相对于父组件的显示位置
android:divider 设置分割线的图片
android:layout_weight 设置权重,即让一行或一列的组件按比例显示

计算器的具体设计与实现

一、主界面设计

根据运行效果可以看出,计算器主要实现了加、减、乘、除的计算功能。

  • 主界面上用11个Button组件显示数字0 9和".",用于输入0 9数字和小数点;
  • 用4个Button组件显示"+"、""、""、""运算符,用于实现加、减、乘、除运算;
  • 用3个Button组件显示"="、"C" 和 "DEL", "=" 用于计算结果、 "C" 用于将显示结果的TextView清零、 "DEL" 用于删除输入的1个字符。

采用嵌套的线性布局

具体结构如下:

基于Andriod的简易计算器

整体是一个垂直的线性布局,最上面放置一个TextView,下面是五个水平的线性布局用来放置按钮。

按钮的宽度是用weight权重设置而成,让观感更好。

最外层的线性布局添加了属性 android:layout_margin="8dp" 让布局与边框有了8dp的间隔,也是使观感更好。

二、实例化对象与监听事件

  1. 实例化组件对象
  • 创建init函数, 将TextView以及功能性组件通过 this.findViewById(R.id.具体id) 进行实例化。
  1. 给对象绑定监听事件
  • 内部类
    * 匿名内部类
    * 定义内部类
  • onClick属性
    * 定义public类型的方法

数字按键的功能只是显示到TextView中所以使用的是添加onClick属性并指定方法绑定监听事件,功能按键使用的是匿名内部类定义其功能。

三、功能的实现

(1)定义变量和初始化组件

private Button btnAdd, btnDec, btnMul, btnDev, btnEqu, btnClear, btnDel;
private TextView txtResult; //显示结果
private StringBuffer digtalA = new StringBuffer(),digtalB = new StringBuffer();
private boolean isChar = false; //是否为运算符
private int operater = 0; // 判断是哪种运算符 0+ 1- 2* 3/
private boolean isDigtalA = true;

void initView(){
    txtResult = (TextView) this.findViewById(R.id.txtResults);
    btnAdd = (Button) this.findViewById(R.id.btnAdd);
    btnDec = (Button) this.findViewById(R.id.btnDec);
    btnMul = (Button) this.findViewById(R.id.btnMul);
    btnDev = (Button) this.findViewById(R.id.btnDev);
    btnEqu = (Button) this.findViewById(R.id.btnEqu);
    btnClear = (Button) this.findViewById(R.id.btnC);
    btnDel = (Button) this.findViewById(R.id.btnDel);
}

(2)数字0~9及小数点的监听事件定义了myOnclick()方法来实现

public void myOnclick(View v){
    switch (v.getId()){
        case R.id.btn0:
            setVal("0");
            break;
        case R.id.btn1:
            setVal("1");
            break;
        //...中间代码省略
        case R.id.btnDot:
            setVal(".");
            break;
    }
}

setVal()方法是对重复代码的抽取。

public void setVal(String s){
    if (isChar){
        digtalB.append(s);
        txtResult.setText(digtalB.toString());
    }else{
        digtalA.append(s);
        txtResult.setText(digtalA.toString());
    }
}

此代码作用是判断当前输入的数字是运算的第一个数还是第二个数。对其进行赋值(digtalA为StringBuffer存储第一个运算数,B存储第二个运算数)并显示到TextView中。

(3)运算法"+"的监听事件

btnAdd.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if (digtalA.length() == 0){
                return;
            }
            operater = 0;
            isChar = true;
            isDigtalA = false;
            txtResult.setText("+");
        }
    });

减乘除与其类似。

(4)清空按钮 "C" 的监听事件

btnClear.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            digtalA = new StringBuffer();
            digtalB = new StringBuffer();
            isChar = false;
            isDigtalA = true;
            txtResult.setText("0");
        }
    });

(5)等于号 "=" 的监听事件

btnEqu.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if (digtalA.length() == 0 || digtalB.length() == 0){
                return;
            }
            float a = Float.parseFloat(digtalA.toString());
            float b = Float.parseFloat(digtalB.toString());
            float c = 0;
            switch (operater){
                case 0:
                    c = a + b;
                    break;
                case 1:
                    c = a - b;
                    break;
                case 2:
                    c = a * b;
                    break;
                case 3:
                    c = a / b;
                    break;
            }
            txtResult.setText(c+"");
            digtalA = new StringBuffer();
            digtalB = new StringBuffer();
            isChar = false;
            isDigtalA = true;
        }
    });
}

先判断两个运算数是否为空,为空直接返回,再进行相应的加减乘除操作,将结果显示到屏幕中,并清空A,B及其他标识符。

(6)退格删除 "DEL" 的监听事件

btnDel.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            if (isDigtalA){
                if (digtalA.length() > 0){
                    String temp = digtalA.substring(0,digtalA.length()-1);
                    digtalA = new StringBuffer();
                    digtalA.append(temp);
                    txtResult.setText(digtalA.toString());
                }else{
                    digtalA = new StringBuffer();
                    digtalA.append("0");
                }
            }else{
                if (digtalB.length() > 0){
                    String temp = digtalB.substring(0,digtalB.length()-1);
                    digtalB = new StringBuffer();
                    digtalB.append(temp);
                    txtResult.setText(digtalB.toString());
                }else{
                    digtalB = new StringBuffer();
                    digtalB.append("0");
                }
            }
        }
    });

isDigtalA 是用来判断当前输入数字是第一个运算数还是第二个,退格用StringBuffer的substring截断最后一位数字。

(7)其他说明

单位 说明
px(像素) 相当于实际屏幕的像素,由于不同屏幕的像素数差异比较大,因此这个单位不推荐用于尺寸单位
dp/dip(密度无关像素) 一种与屏幕密度无关的尺寸单位,当屏幕密度是160dpi时,1dp=1px。当运行在高dpi的屏幕上时,dp就会按比例放大,当运行在低dpi的屏幕上时,dp就会按比例缩小。因此dp是一种简单解决view在不同大小屏幕上显示问题的解决方案
sp 与dp相似,但是它会随着用户对系统字体大小的设置进行比例缩放,即它能够跟随用户系统字体大小变化。所以它更适合作为字体大小的单位

以上所述就是小编给大家介绍的《基于Andriod的简易计算器》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

HTML5移动应用开发入门经典

HTML5移动应用开发入门经典

凯瑞恩 / 林星 / 人民邮电出版社 / 2013-3 / 55.00元

《HTML5移动应用开发入门经典》总共分为24章,以示例的方式对如何使用HTML5及相关技术进行移动应用开发做了全面而细致的介绍。《HTML5移动应用开发入门经典》首先讲解了HTML5的起源以及它为什么适用于移动设备,然后讲解了HTML5的基本元素以及所做的改进、canvas(画布)、视音频、微格式、微数据、拖曳等新增特性,还讲解了WebSocket、WebWorkers、Web存储、离线Web应......一起来看看 《HTML5移动应用开发入门经典》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

html转js在线工具
html转js在线工具

html转js在线工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换