当前位置: 移动技术网 > 移动技术>移动开发>Android > Android studio设计简易计算器

Android studio设计简易计算器

2019年07月23日  | 移动技术网移动技术  | 我要评论
本文实例为大家分享了android studio设计简易计算器的具体代码,供大家参考,具体内容如下 效果显示: 第一步,简单的界面布局 <

本文实例为大家分享了android studio设计简易计算器的具体代码,供大家参考,具体内容如下

效果显示:

第一步,简单的界面布局

<?xml version="1.0" encoding="utf-8"?>
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 android:orientation="vertical"
 tools:context=".mainactivity"
 android:background="#000000">
 
 <textview
  android:id="@+id/text1"
  android:layout_width="match_parent"
  android:layout_height="170dp"
  android:layout_marginleft="10dp"
  android:layout_margintop="10dp"
  android:layout_marginright="10dp"
  android:background="#ffffff"
  android:gravity="right|bottom"
  android:hint="0"
  android:paddingright="5dp"
  android:textcolor="#000000"
  android:textsize="40sp" />
 <linearlayout
  android:id="@+id/relative"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:layout_margintop="10dp"
  android:layout_marginright="10dp"
  android:layout_marginleft="10dp"
  android:orientation="vertical">
 
  <linearlayout
 android:layout_width="match_parent"
 android:layout_height="wrap_content">
  <button
   android:id="@+id/btn_7"
   style="@style/buttonstyle"
   android:text="@string/btn_7" />
  <button
   android:id="@+id/btn_8"
   style="@style/buttonstyle"
   android:text="@string/btn_8" />
  <button
   android:id="@+id/btn_9"
   style="@style/buttonstyle"
   android:text="@string/btn_9" />
  <button
   android:id="@+id/btn_clear"
   style="@style/buttonstyle"
   android:text="@string/btn_clear"/>
 </linearlayout>
  <linearlayout
   android:layout_width="match_parent"
   android:layout_height="wrap_content">
   <button
    android:id="@+id/btn_4"
    style="@style/buttonstyle"
    android:text="@string/btn_4" />
   <button
    android:id="@+id/btn_5"
    style="@style/buttonstyle"
    android:text="@string/btn_5" />
   <button
    android:id="@+id/btn_6"
    style="@style/buttonstyle"
    android:text="@string/btn_6" />
   <button
    android:id="@+id/btn_plus"
    style="@style/buttonstyle"
    android:text="@string/btn_plus"/>
  </linearlayout>
  <linearlayout
   android:layout_width="match_parent"
   android:layout_height="wrap_content">
   <button
    android:id="@+id/btn_1"
    style="@style/buttonstyle"
    android:text="@string/btn_1" />
   <button
    android:id="@+id/btn_2"
    style="@style/buttonstyle"
    android:text="@string/btn_2" />
   <button
    android:id="@+id/btn_3"
    style="@style/buttonstyle"
    android:text="@string/btn_3" />
   <button
    android:id="@+id/btn_minus"
    style="@style/buttonstyle"
    android:text="@string/btn_minus"/>
  </linearlayout>
  <linearlayout
   android:layout_width="match_parent"
   android:layout_height="wrap_content">
   <button
    android:id="@+id/btn_0"
    style="@style/buttonstyle"
    android:text="@string/btn_0" />
   <button
    android:id="@+id/btn_equal"
    style="@style/buttonequalstyle"
    android:text="@string/btn_equal" />
   <button
    android:id="@+id/btn_divide"
    style="@style/buttonstyle"
    android:text="@string/btn_divide" />
   <button
    android:id="@+id/btn_multiply"
    style="@style/buttonstyle"
    android:text="@string/btn_multiply"/>
  </linearlayout>
 </linearlayout>
 
</linearlayout>

string.xml文件

<resources>
 <string name="app_name">计算器</string>
 <string name="text1">显示文本框</string>
 <string name="relative">布局</string>
 <string name="btn_1">1</string>
 <string name="btn_2">2</string>
 <string name="btn_3">3</string>
 <string name="btn_4">4</string>
 <string name="btn_5">5</string>
 <string name="btn_6">6</string>
 <string name="btn_7">7</string>
 <string name="btn_8">8</string>
 <string name="btn_9">9</string>
 <string name="btn_0">0</string>
 <string name="btn_clear">c</string>
 <string name="btn_plus">+</string>
 <string name="btn_minus">-</string>
 <string name="btn_multiply">×</string>
 <string name="btn_divide">÷</string>
 <string name="btn_equal">=</string>
</resources>

采用的是linearlayout线性布局,而因为按钮的基本属性相同,所以采用使用样式的方式来设置,代码如下

<resources>
 <style name="apptheme" parent="theme.appcompat.light.darkactionbar">
  <!-- customize your theme here. -->
  <item name="colorprimary">@color/colorprimary</item>
  <item name="colorprimarydark">@color/colorprimarydark</item>
  <item name="coloraccent">@color/coloraccent</item>
 </style>
 <style name="buttonbasestyle">
  <item name="android:layout_width">40dp</item>
  <item name="android:layout_height">70dp</item>
  <item name="android:layout_margin">10dp</item>
  <item name="android:padding">10dp</item>
  <item name="android:textcolor">@android:color/black</item>
  <item name="android:textsize">30sp</item>
 </style>
 <style name="buttonstyle" parent="buttonbasestyle">
  <item name="android:background">@drawable/bg_selector</item>
  <item name="android:layout_weight">1</item>
 </style>
 <style name="buttonequalstyle" parent="buttonbasestyle">
  <item name="android:background">@drawable/ping_bg</item>
  <item name="android:layout_weight">1</item>
 </style>
</resources>

white_bg.xml文件

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<corners android:radius="5dp"/>
 <solid android:color="#ffffff"/>
</shape>

pink_bg.xml文件

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<corners android:radius="5dp"></corners>
 <solid android:color="#ee82ee"></solid>
</shape>

 selector_bg.xml文件

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
 <item android:drawable="@drawable/white_bg" android:state_pressed="false"></item>
 <item android:drawable="@drawable/ping_bg"
  android:state_pressed="true"></item>
</selector>

事件java代码

为了简单快捷的给各个按钮设置监听事件,将按钮都放在一个数组里面,然后使用for语句给按钮添加监听事件。

在onclick()放中,首先会获取文本框的id(注意是文本框的id)。

然后获取文本框里面的输入。获取字符串后,使用switch或者for语句对点击的按钮进行判断,当只点击数字按钮0到9时,输入不会break掉,只会将前面所有的字符连接组成字符串显示在文本框里。

注意:如果点击的第一个数字是0,那么就只显示0后面输入的数字。

package com.example.exp3;
import android.os.bundle;
import android.support.v7.app.appcompatactivity;
import android.text.textutils;
import android.view.view;
import android.widget.button;
import android.widget.textview;
import android.widget.toast;
import java.util.regex.matcher;
import java.util.regex.pattern;
 
public class mainactivity extends appcompatactivity implements view.onclicklistener {
 @override
 protected void oncreate(bundle savedinstancestate) {
  super.oncreate(savedinstancestate);
  setcontentview(r.layout.activity_main);
  int[] ids = {r.id.btn_0, r.id.btn_1, r.id.btn_2, r.id.btn_3, r.id.btn_4, r.id.btn_4,
    r.id.btn_5, r.id.btn_6, r.id.btn_7, r.id.btn_8, r.id.btn_9, r.id.btn_equal,
    r.id.btn_clear, r.id.btn_multiply, r.id.btn_minus, r.id.btn_divide, r.id.btn_plus};
  //将所有按钮整合成一个数组
  for (int i = 0; i < ids.length; i++)
   findviewbyid(ids[i]).setonclicklistener(this);//给每个按钮设置一个监听事件
 }
 @override
 public void onclick(view v) {
  textview tv_input = (textview) findviewbyid(r.id.text1);
  button btn = (button)v;
  string str=tv_input.gettext().tostring();//获取xml那里的输入
  string strbutton =btn.gettext().tostring();//点击按钮得到的文本
  switch (v.getid()){
   case r.id.btn_0:
   case r.id.btn_1:
   case r.id.btn_2:
   case r.id.btn_3:
   case r.id.btn_4:
   case r.id.btn_5:
   case r.id.btn_6:
   case r.id.btn_7:
   case r.id.btn_8:
   case r.id.btn_9:
    if (str.equals("0"))
     tv_input.settext(strbutton);
    else
     tv_input.settext(str+strbutton);
    break;
   case r.id.btn_clear:
    tv_input.settext("0");
    break;
   case r.id.btn_plus:
   case r.id.btn_minus:
   case r.id.btn_multiply:
   case r.id.btn_divide:
    tv_input.settext(str+strbutton);
    break;
   case r.id.btn_equal:
    mycalc obj=new mycalc(str);
    double ret = obj.calc();
    int ret = (int)ret;
    if (ret == ret)
     tv_input.settext(string.valueof(ret));
    else
     tv_input.settext(string.valueof(ret));
    break;
  }
 }
 
 class mycalc {
  private string input;
 
  public mycalc(string input) {
   this.input = input;
  }
 
  public double calc() {
   if (textutils.isempty(input))
    return 0;
   pattern pattern = pattern.compile("[+(×)(÷)/-]");
   string[] nums = pattern.split(input);
   matcher matcher = pattern.matcher(input);
   if (matcher.find() == false)
    return 0;
   string op = matcher.group(0);
   double first = double.parsedouble(nums[0]);
   double second = double.parsedouble(nums[1]);
   double sum = 0;
   try {
    switch (op) {
     case "+":
      sum = first + second;
      break;
     case "-":
      sum = first - second;
      break;
     case "×":
      sum = first * second;
      break;
     case "÷":
      sum = first / second;
      break;
    }
   } catch (exception e) {
    toast.maketext(mainactivity.this, "出错", toast.length_long).show();
   }
   return sum;
  }
 }
}

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

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网