前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >android计算器开发实例_安卓开发计算器代码

android计算器开发实例_安卓开发计算器代码

作者头像
全栈程序员站长
发布2022-11-15 15:28:06
1.8K0
发布2022-11-15 15:28:06
举报
文章被收录于专栏:全栈程序员必看

大家好,又见面了,我是你们的朋友全栈君。

实习第四天了,第一天熟悉了一下java,这三天学习了解了一下安卓开发的一些基础知识。做了一个小程序—计算器,以此帖来记录一下。也许也有人可以参考一下)功能真的只有最基本哈哈,最最新手的人可以参考hh 首先是activity_main.xml的布局代码

代码语言:javascript
复制
<GridLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/GridLayout1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:columnCount="4" android:orientation="horizontal" android:rowCount="6" >
<TextView android:layout_width="1200dp" android:layout_height="110dp" android:layout_columnSpan="4" android:layout_centerHorizontal="true" android:layout_centerVertical="true" android:layout_gravity="fill" android:layout_marginLeft="5dp" android:layout_marginRight="5dp" android:id="@+id/textview_1" android:text="" android:background="@drawable/rectborder" android:textSize="80sp" />
<Button android:layout_width="600dp" android:layout_height="90dp" android:layout_columnSpan="2" android:layout_gravity="fill" android:textSize="60sp" android:layout_marginLeft="5dp" android:id="@+id/back_btn" android:text="回退" />
<Button android:layout_width="600dp" android:layout_columnSpan="2" android:textSize="60sp" android:layout_marginRight="5dp" android:layout_gravity="fill" android:id="@+id/delete_btn" android:text="清空" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:layout_marginLeft="5dp" android:id="@+id/plus_btn" android:text="+" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/num1_btn" android:text="1" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/num2_btn" android:text="2" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:layout_marginRight="5dp" android:textSize="60sp" android:id="@+id/num3_btn" android:text="3" />
<Button android:layout_width="320dp" android:textSize="60sp" android:layout_height="90dp" android:layout_marginLeft="5dp" android:text="-" android:id="@+id/minus_btn"/>
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:text="4" android:id="@+id/num4_btn"/>
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/num5_btn" android:text="5" />
<Button android:layout_width="320dp" android:textSize="60sp" android:layout_height="90dp" android:layout_marginRight="5dp" android:text="6" android:id="@+id/num6_btn"/>
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:layout_marginLeft="5dp" android:id="@+id/mult_btn" android:text="*" />
<Button android:layout_width="320dp" android:textSize="60sp" android:layout_height="90dp" android:id="@+id/num7_btn" android:text="7" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/num8_btn" android:text="8" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:layout_marginRight="5dp" android:id="@+id/num9_btn" android:text="9" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:layout_marginLeft="5dp" android:id="@+id/divide_btn" android:text="/" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/dot_btn" android:text="." />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/num0_btn" android:text="0" />
<Button android:layout_width="320dp" android:layout_height="90dp" android:textSize="60sp" android:id="@+id/result_btn" android:text="=" />
</GridLayout>

这是布局的效果,渐变文本框的效果还需要加一个drawable布局资源

在这里插入图片描述
在这里插入图片描述

需要用到drawable里的rectborder.xml如下:

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" >
<!-- 设置一个黑色边框 -->
<!-- <stroke android:width="2px" android:color="#000000"/>-->
<!-- 渐变 -->
<gradient android:angle="270" android:endColor="#545454" android:startColor="#C0C0C0" />
<!-- 设置一下边距,让空间大一点 -->
<padding android:left="5dp" android:top="5dp" android:right="5dp" android:bottom="5dp"/>
</shape>

接下来是MainActivity.java文件

代码语言:javascript
复制
package com.example.test_0;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
public class MainActivity extends AppCompatActivity { 

private Button num0_btn;
private Button num1_btn;
private Button num2_btn;
private Button num3_btn;
private Button num4_btn;
private Button num5_btn;
private Button num6_btn;
private Button num7_btn;
private Button num8_btn;
private Button num9_btn;
private Button mult_btn;
private Button divide_btn;
private Button dot_btn;
private Button result_btn;
private Button back_btn;
private Button delete_btn;
private Button plus_btn;
private Button minus_btn;
private TextView textview_1;
private double NO1=0;
private int flag=0;
private int flag_1=0;
private double NO2=0;
private double end=0;
@Override
protected void onCreate(Bundle savedInstanceState) { 

super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
num0_btn = (Button) findViewById(R.id.num0_btn);
num1_btn = (Button) findViewById(R.id.num1_btn);
num2_btn = (Button) findViewById(R.id.num2_btn);
num3_btn = (Button) findViewById(R.id.num3_btn);
num4_btn = (Button) findViewById(R.id.num4_btn);
num5_btn = (Button) findViewById(R.id.num5_btn);
num6_btn = (Button) findViewById(R.id.num6_btn);
num7_btn = (Button) findViewById(R.id.num7_btn);
num8_btn = (Button) findViewById(R.id.num8_btn);
num9_btn = (Button) findViewById(R.id.num9_btn);
divide_btn = (Button) findViewById(R.id.divide_btn);
mult_btn = (Button) findViewById(R.id.mult_btn);
dot_btn = (Button) findViewById(R.id.dot_btn);
result_btn = (Button) findViewById(R.id.result_btn);
delete_btn = (Button) findViewById(R.id.delete_btn);
back_btn = (Button) findViewById(R.id.back_btn);
plus_btn = (Button) findViewById(R.id.plus_btn);
minus_btn = (Button) findViewById(R.id.minus_btn);
textview_1 = (TextView) findViewById(R.id.textview_1);
num0_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("0");
if (flag==0) { 

NO1 = 10 * NO1 + 0;
}
else { 

NO2 =10* NO2+0;
}
}
});
num1_btn.setOnClickListener(new View.OnClickListener(){ 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("1");
if (flag==0) { 

NO1 = 10 * NO1 + 1;
}
else { 

NO2 =10* NO2+1;
}
}
});
num2_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("2");
if (flag==0) { 

NO1 = 10 * NO1 + 2;
}
else { 

NO2 =10* NO2+2;
}
}
});
num3_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("3");
if (flag==0) { 

NO1 = 10 * NO1 + 3;
}
else { 

NO2 =10* NO2+3;
}
}
});
num4_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("4");
if (flag==0) { 

NO1 = 10 * NO1 + 4;
}
else { 

NO2 =10* NO2+4;
}
}
});
num5_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("5");
if (flag==0) { 

NO1 = 10 * NO1 + 5;
}
else { 

NO2 =10* NO2+5;
}
}
});
num6_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("6");
if (flag==0) { 

NO1 = 10 * NO1 + 6;
}
else { 

NO2 =10* NO2+6;
}
}
});
num7_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("7");
if (flag==0) { 

NO1 = 10 * NO1 + 7;
}
else { 

NO2 =10* NO2+7;
}
}
});
num8_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("8");
if (flag==0) { 

NO1 = 10 * NO1 + 8;
}
else { 

NO2 =10* NO2+8;
}
}
});
num9_btn.setOnClickListener(new View.OnClickListener() { 

@Override
public void onClick(View view) { 

// System.out.println(textview_1.getText());
if (flag_1!=0)
{ 

textview_1.setText("");
flag_1=0;
}
textview_1.append("9");
if (flag==0) { 

NO1 = 10 * NO1 + 9;
}
else { 

NO2 =10* NO2+9;
}
}
});
delete_btn.setOnClickListener(new View.OnClickListener()
{ 

@Override
public void onClick(View view) { 

if (textview_1.getText()=="0")
{ 

textview_1.setText("");
}
textview_1.setText("");
flag=0;
}
});
plus_btn.setOnClickListener(new View.OnClickListener()
{ 

@Override
public void onClick(View view) { 

flag=1;
flag_1=1;
// textview_1.setText("");
}
});
mult_btn.setOnClickListener(new View.OnClickListener()
{ 

@Override
public void onClick(View view) { 

flag=3;
flag_1=1;
//textview_1.setText("");
}
});
divide_btn.setOnClickListener(new View.OnClickListener()
{ 

@Override
public void onClick(View view) { 

flag=4;
flag_1=1;
//textview_1.setText("");
}
});
minus_btn.setOnClickListener(new View.OnClickListener()
{ 

@Override
public void onClick(View view) { 

flag=2;
flag_1=1;
//textview_1.setText("");
}
});
result_btn.setOnClickListener(new View.OnClickListener()
{ 

@Override
public void onClick(View view) { 

if (flag==1)
{ 
   end=NO1+NO2;
textview_1.setText((String.valueOf(end)));
NO1=0;
NO2=0;
}
else if (flag==3)
{ 

end=NO1*NO2;
textview_1.setText((String.valueOf(end)));
NO1=0;
NO2=0;
}
else if (flag==2)
{ 

end=NO1-NO2;
textview_1.setText((String.valueOf(end)));
NO1=0;
NO2=0;
}
else if (flag==4)
{ 

end=NO1/NO2;
textview_1.setText((String.valueOf(end)));
NO1=0;
NO2=0;
}
}
});
// divide_btn.setOnClickListener(this);
// mult_btn.setOnClickListener(this);
// dot_btn.setOnClickListener(this);
// result_btn.setOnClickListener(this);
}
}

然后这个最最最最基础的计算器就做完啦。 可以进行最简单的加减乘除,每次结果算出来之后得按清除才可以进行下一次计算hh

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/234293.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年11月3日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云开发 CloudBase
云开发(Tencent CloudBase,TCB)是腾讯云提供的云原生一体化开发环境和工具平台,为200万+企业和开发者提供高可用、自动弹性扩缩的后端云服务,可用于云端一体化开发多种端应用(小程序、公众号、Web 应用等),避免了应用开发过程中繁琐的服务器搭建及运维,开发者可以专注于业务逻辑的实现,开发门槛更低,效率更高。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档