Android studio设计简易计算器
程序员文章站
2023-11-14 13:53:22
本文实例为大家分享了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; } } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: 一起学MyBatis之入门篇(2)
下一篇: PHP-FPM 的管理和配置详解