Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)

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

内容简介:Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)一、作业题目要求:

Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)

————安德风

一、作业题目要求:

Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)

二、实现题目第一问(等号通过按钮实现【button】)

1、前期需要在activity_main.xml文件设计布局

Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)

最终布局效果图

2、控件准备:

需要2个EditText控件(两个输入文本框):EditText1(用来作为加法1)、EditText2(用来作为加法2)

2个TextView控件: TextView1(用作“+”),TextView2(用作输出求和)

1个Button控件:Button1(用作“=”,用来点击等于时,TextView2作为输出和的结果)

PS:以上控件要求是用来作为布局使用,在MainActivity.java 文件中实现功能部分只用到:
EditText1(用来作为加法1) =》更改ID为et1 、EditText2(用来作为加法2) =》更改ID为et2

Button1(用作“=”,用来点击等于时,TextView2作为输出和的结果 )=>更改ID为bt

TextView2(用作输出求和) =》更改ID为tv

更改ID名可以自定义,要求规范更改控件ID名要求见明知意,还有控件ID最好与MainActivity.java 文件中声明变量一致便于修改。

3、activity_main.xml界面布局源代码:

 1 <?xml version="1.0" encoding="utf-8"?>
 2 <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
 3     xmlns:app="http://schemas.android.com/apk/res-auto"
 4     xmlns:tools="http://schemas.android.com/tools"
 5     android:layout_width="match_parent"
 6     android:layout_height="match_parent"
 7     tools:context=".MainActivity">
 8 
 9     <EditText
10         android:id="@+id/et1"
11         android:layout_width="60dp"
12         android:layout_height="45dp"
13         android:layout_marginStart="76dp"
14         android:layout_marginLeft="76dp"
15         android:layout_marginTop="140dp"
16         android:background="@drawable/border"
17         android:ems="10"
18         android:hint="加法1"
19         android:inputType="textShortMessage|numberSigned"
20         app:layout_constraintStart_toStartOf="parent"
21         app:layout_constraintTop_toTopOf="parent" />
22 
23     <TextView
24         android:id="@+id/tv"
25         android:layout_width="80dp"
26         android:layout_height="60dp"
27         android:layout_marginTop="132dp"
28         android:background="@drawable/border"
29         android:gravity="center"
30         android:hint="和"
31         android:textSize="24sp"
32         app:layout_constraintStart_toEndOf="@+id/bt"
33         app:layout_constraintTop_toTopOf="parent" />
34 
35     <TextView
36         android:id="@+id/textView"
37         android:layout_width="wrap_content"
38         android:layout_height="wrap_content"
39         android:layout_marginTop="140dp"
40         android:text="+"
41         android:background="@drawable/border"
42         android:textSize="24sp"
43         app:layout_constraintStart_toEndOf="@+id/et1"
44         app:layout_constraintTop_toTopOf="parent" />
45 
46     <EditText
47         android:id="@+id/et2"
48         android:layout_width="60dp"
49         android:layout_height="45dp"
50         android:layout_marginTop="140dp"
51         android:background="@drawable/border"
52         android:ems="10"
53         android:hint="加法2"
54         android:inputType="numberSigned|textPersonName"
55         app:layout_constraintStart_toEndOf="@+id/textView"
56         app:layout_constraintTop_toTopOf="parent" />
57 
58     <Button
59         android:id="@+id/bt"
60         android:layout_width="50dp"
61         android:layout_height="60dp"
62         android:layout_marginTop="132dp"
63         android:text="="
64         android:textSize="24sp"
65         app:layout_constraintStart_toEndOf="@+id/et2"
66         app:layout_constraintTop_toTopOf="parent" />
67 
68 </androidx.constraintlayout.widget.ConstraintLayout>

4、实现功能MainActivity.java源代码

 1 package com.example.computer;
 2 
 3 import androidx.appcompat.app.AppCompatActivity;
 4 
 5 import android.os.Bundle;
 6 import android.view.KeyEvent;
 7 import android.view.View;
 8 import android.widget.Button;
 9 import android.widget.EditText;
10 import android.widget.TextView;
11 
12 public class MainActivity extends AppCompatActivity implements View.OnClickListener {
13 
14     EditText et1;//声明加法1输入文本框变量为et1(与控件ID一致)
15     EditText et2;//声明加法2输入文本框变量为et2(与控件ID一致)
16     TextView tv;//声明和普通文本框变量为tv(与控件ID一致)
17     Button bt;//声明等于按钮控件变量为bt(与控件ID一致)
18     int sum;//定义一个sum自定义变量方便后面方法求和存放求和的值
19 
20     @Override
21     protected void onCreate(Bundle savedInstanceState) {
22         super.onCreate(savedInstanceState);
23         setContentView(R.layout.activity_main);
24 
25         et1 = findViewById(R.id.et1);//寻找加法1输入文本框ID
26         et2 = findViewById(R.id.et2);//寻找加法2输入文本框ID
27         tv = findViewById(R.id.tv);//寻找和普通文本框ID
28         bt=findViewById(R.id.bt);//寻找等于号普通按钮ID
29         bt.setOnClickListener(this);//给等于号普通按钮安装一个监听器,便于点击等于号按钮,和就能求出
30 
31 
32     }
33 //String => int =>String
34     @Override
35     public void onClick(View v) {
36     String j1=et1.getText().toString();//通过et1ID(加法1输入文本框)得到文本内容(数据类型为字符串型)赋值给j1(也就是说j1代表加法1,可以理解为是它的小名)
37     String j2=et2.getText().toString();//通过et2ID(加法2输入文本框)得到文本内容(数据类型为字符串型)赋值给j2(也就是说j2代表加法2,可以理解为是它的小名)
38     int num1=Integer.valueOf(j1).intValue();//将j1字符串类型强制转换为int类型
39     int num2=Integer.valueOf(j2).intValue();//将j2字符串类型强制转换为int类型
40     sum=num1+num2;//开始运算加法1+ 加法2=和(sum代表和的变量)
41     j1=String.valueOf(sum);//再将sum(和),由int类型转换为string型便于,setText()输出(只能输出字符串类型),赋值给j1或者j2帮忙代理存储数据
42    tv.setText(j1);//由于setText(只能输出字符串类型)所以通过j1(加法1或者j2加法2)代理帮忙存储来输出和的值
43 
60 
61     }
62 }

5、实现文本边框border.xml源代码:

 1 <selector xmlns:android="http://schemas.android.com/apk/res/android">
 2     <item android:state_pressed="true" >
 3         <shape>
 4             <solid
 5                 android:color="#449def" />
 6             <stroke
 7                 android:width="1dp"
 8                 android:color="#2f6699" />
 9             <corners
10                 android:radius="0dp" />
11             <padding
12                 android:left="5dp"
13                 android:top="5dp"
14                 android:right="5dp"
15                 android:bottom="5dp" />
16         </shape>
17     </item>
18     <item>
19         <shape>
20             <gradient
21                 android:startColor="#ffffff"
22                 android:endColor="#ffffff"
23                 android:angle="270" />
24             <stroke
25                 android:width="1dp"
26                 android:color="#2f6699" />
27             <corners
28                 android:radius="0dp" />
29             <padding
30                 android:left="5dp"
31                 android:top="5dp"
32                 android:right="5dp"
33                 android:bottom="5dp" />
34         </shape>
35     </item>
36 </selector>

6、最终在模拟器调试代码效果图:

Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)

三、实现题目思考题第二问(等号通过普通文本框实现【TextView】)


以上所述就是小编给大家介绍的《Androidstudio实现一个简易的加法器——分享两种方法实现(日常作业练习)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

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

Designing for Emotion

Designing for Emotion

Aarron Walter / Happy Cog / 2011-10-18 / USD 18.00

Make your users fall in love with your site via the precepts packed into this brief, charming book by MailChimp user experience design lead Aarron Walter. From classic psychology to case studies, high......一起来看看 《Designing for Emotion》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具