之前自己的编程完全是在PC上进行的,而且主要是在算法和数据结构上。由于某些需要加之认识到Android的重要性,且大学走到现在基本上没什么课了,空闲时间很多,于是就开始学习Android。本系列博客都将围绕Android应用程序设计展开,由于本人是完全没有Android程序设计基础,所以内容都很基础,希望与大家交流学习并得到指点。

加上昨天,总共看了两天Android书,觉得似乎可以写点东西了,于是动手写了个简易计算器,在此总结一下。由于本系列博客主要作为我学习Android的读书笔记,所以写的东西侧重语言,功能相对一般,在后面我将尽我所能增强这个计算器的功能,争取推出一个人工智能版的。

1.Android布局

由于手机作为人的延伸,主要是面对绝对的用户,让他们来打发空闲时间的。基于此,我觉得用户界面UI是个非常重要的方面,而Android的布局Layout是关乎UI的。Android中一共有5种布局:线性布局、表格布局、相对布局、帧布局、绝对布局等等。本次我采用的是表格布局,主要是基于计算器界面的对称性考虑的。可以直接在对应的XLM文件中设计。

<?xml version="1.0" encoding="utf-8"?><TableLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:background="#111111"    android:stretchColumns="4" >    <TextView        android:id="@+id/tv"        android:layout_height="200px"        android:background="#FFFFFF"        android:gravity="right"        android:textColor="#00FF00"        android:textSize="80px" />    <TableRow android:paddingTop="80px" >        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt1"            android:padding="80px"            android:text="1"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt2"            android:padding="80px"            android:text="2"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt3"            android:padding="80px"            android:text="3"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBtBack"            android:padding="80px"            android:text="D"            android:textColor="#0000FF"            android:textSize="80px" />        <Button            android:layout_width="fill_parent"            android:layout_height="fill_parent"            android:onClick="onClickBtAdd"            android:text="+"            android:textColor="#FF0000" />    </TableRow>    <TableRow android:paddingTop="80px" >        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt4"            android:padding="80px"            android:text="4"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt5"            android:padding="80px"            android:text="5"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt6"            android:padding="80px"            android:text="6"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBtMod"            android:padding="80px"            android:text="%"            android:textColor="#FF0000"            android:textSize="80px" />        <Button            android:layout_width="fill_parent"            android:layout_height="fill_parent"            android:onClick="onClickBtSub"            android:text="-"            android:textColor="#FF0000" />    </TableRow>    <TableRow android:paddingTop="80px" >        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt7"            android:padding="80px"            android:text="7"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt8"            android:padding="80px"            android:text="8"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt9"            android:padding="80px"            android:text="9"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBtExp"            android:padding="80px"            android:text="^"            android:textColor="#FF0000"            android:textSize="80px" />        <Button            android:layout_width="fill_parent"            android:layout_height="fill_parent"            android:onClick="onClickBtMul"            android:text="*"            android:textColor="#FF0000" />    </TableRow>    <TableRow android:paddingTop="80px" >        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBt0"            android:padding="80px"            android:text="0"            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBtCE"            android:padding="80px"            android:text="C"            android:textColor="#0000FF"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBtPoint"            android:padding="80px"            android:text="."            android:textColor="#00FF00"            android:textSize="80px" />        <Button            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:onClick="onClickBtEqual"            android:padding="80px"            android:text="="            android:textSize="80px" />        <Button            android:layout_width="fill_parent"            android:layout_height="fill_parent"            android:onClick="onClickBtDiv"            android:text="/"            android:textColor="#FF0000" />    </TableRow></TableLayout>
3.Android控件

本次一共用了两种控件,文本框TextView、按钮Button。通过为按钮增加监听事件来调用相应的命令,完成预定功能。关于Button有两种使用方法:

a、设置监听器并在监听器中的代码实现中添加事件处理代码来响应事件

bt1.setOnClickListener(new Button.OnClickListener()    {public void onClick(View v) {//完成功能}    })

b、在XML文件中为按钮的android:onClick的属性制定一个方法来响应事件,如android:onClick="onClickBt1",然后在定义public方法public void onClickBt1(View v)

public void onClickBt1(View v) {//完成功能}

还有菜单menu的使用,比较简单,在此就不说了。

3.运行截图

目前不支持多次运算,无法表示负数,但可以显示表达式,清0与删除前一位。

4.源代码

package com.example.calculator;import android.os.Bundle;import android.app.Activity;import android.view.Menu;import android.view.MenuItem;import android.view.View;import android.view.View.OnClickListener;import android.widget.TextView;import android.widget.Toast;public class MainActivity extends Activity {private String opA, opB, opC, show;private int op;private TextView tv;private int flag;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);flag = 0;opA = opB = opC = show = "";tv = (TextView) findViewById(R.id.tv);}public void onClickBt1(View v) {if (0 == flag)opA += "1";elseopB += "1";show += "1";tv.setText(show);}public void onClickBt2(View v) {if (0 == flag)opA += "2";elseopB += "2";show += "2";tv.setText(show);}public void onClickBt3(View v) {if (0 == flag)opA += "3";elseopB += "3";show += "3";tv.setText(show);}public void onClickBt4(View v) {if (0 == flag)opA += "4";elseopB += "4";show += "4";tv.setText(show);}public void onClickBt5(View v) {if (0 == flag)opA += "5";elseopB += "5";show += "5";tv.setText(show);}public void onClickBt6(View v) {if (0 == flag)opA += "6";elseopB += "6";show += "6";tv.setText(show);}public void onClickBt7(View v) {if (0 == flag)opA += "7";elseopB += "7";show += "7";tv.setText(show);}public void onClickBt8(View v) {if (0 == flag)opA += "8";elseopB += "8";show += "8";tv.setText(show);}public void onClickBt9(View v) {if (0 == flag)opA += "9";elseopB += "9";show += "9";tv.setText(show);}public void onClickBt0(View v) {if (0 == flag)if (0 == flag)opA += "0";elseopB += "0";show += "0";tv.setText(show);}public void onClickBtAdd(View v) {flag=1;show += "+";op = 1;tv.setText(show);}public void onClickBtSub(View v) {flag=1;show += "-";op = 2;tv.setText(show);}public void onClickBtMul(View v) {flag=1;show += "*";op = 3;tv.setText(show);}public void onClickBtDiv(View v) {flag=1;show += "/";op = 4;tv.setText(show);}public void onClickBtPoint(View v) {if (0 == flag)opA += ".";elseopB += ".";show += ".";tv.setText(show);}public void onClickBtMod(View v) {flag=1;show += "%";op = 5;tv.setText(show);}public void onClickBtExp(View v) {flag=1;show += "^";op = 6;tv.setText(show);}public void onClickBtBack(View v) {if (0 == flag && opA.length() != 0) {opA = opA.substring(0, opA.length() - 1);show = show.substring(0, show.length() - 1);} else if (1 == flag) {if (opB.length() != 0) {opB = opB.substring(0, opB.length() - 1);show = show.substring(0, show.length() - 1);} else {show = show.substring(0, show.length() - 1);if(show.length()==opA.length())    flag = 0;}}tv.setText(show);}public void onClickBtCE(View v) {flag = 0;opA = opB = opC = show = "";tv.setText(show);}public void onClickBtEqual(View v) {switch (op) {case 1:opC = String.valueOf(Double.parseDouble(opA)+ Double.parseDouble(opB));break;case 2:opC = String.valueOf(Double.parseDouble(opA)- Double.parseDouble(opB));break;case 3:opC = String.valueOf(Double.parseDouble(opA)* Double.parseDouble(opB));break;case 4:opC = String.valueOf(Double.parseDouble(opA)/ Double.parseDouble(opB));break;case 5:opC = String.valueOf(Double.parseDouble(opA)% Double.parseDouble(opB));break;case 6:opC = String.valueOf(Math.pow(Double.parseDouble(opA),Double.parseDouble(opB)));break;}show += "\n=" + opC;tv.setText(show);flag = 0;opA = opB = opC = show = "";}@Overridepublic boolean onCreateOptionsMenu(Menu menu) {menu.add(0, 1, 1, "退出");menu.add(0, 2, 2, "版权");menu.add(0, 3, 3, "功能");return super.onCreateOptionsMenu(menu);}public boolean onOptionsItemSelected(MenuItem item) {if (item.getItemId() == 1) {finish();}if (item.getItemId() == 2) {Toast.makeText(MainActivity.this, "作者:晓风残月xj    时间:2014-5-13",Toast.LENGTH_LONG).show();}if (item.getItemId() == 3) {Toast.makeText(MainActivity.this, "后续有智能版本", Toast.LENGTH_LONG).show();}return super.onOptionsItemSelected(item);}}

如有错误,欢迎斧正!由于初学,水平有限,我把重点放在Android语言的试用,在后面的版本中力争推出一个可与市面上相比的人工智能版本。源码下载请点击源码地址。



更多相关文章

  1. Android(安卓)事件分发
  2. android 监控软键盘确定 搜索 按钮并赋予点击事件
  3. Android的多媒体框架OpenCore(PacketVideo)介绍
  4. Android事件分发机制详解:史上最全面、最易懂
  5. JavaEye新闻频道的第一个新闻专题Google Android发布
  6. 【Android(安卓)内存优化】Android(安卓)Profiler 工具常用功能
  7. Android计算器低级错误?都是二进制惹的祸!
  8. Android中各种JAVA包的功能描述
  9. Android中的事件分发机制

随机推荐

  1. 在bootstrap中为同一元素使用两个数据切
  2. 【Unity3D】学习笔记(第3记) 2D游戏开发基
  3. window.open()实现打开窗口
  4. JavaScript原型机制详解
  5. [Javascript] 关于prototype的一些说明
  6. Tree资源树的实战研究
  7. 如何为requirejs和qunit设置咕哝任务
  8. 如何从Vue.js中的变量名加载组件?
  9. javascript应该注意的小case--操作符
  10. Lua与javascript的差异