Android基础综合案例(七)《简易计算器UI界面设计》

《简易计算器UI界面设计》

一、要求:

1、 掌握UI界面的嵌套布局
2、EditText通过三种属性可以指定
     i. android:digits    数字 0~9 或 字母 a~z
     ii. android:inputType 自定义输入的类型
     iii. android:numeric 数字类型
3、掌握MVC设计模式的运用
4、掌握Menu组件的使用
5、AlertDialog.Builder对话框的使用

二:具体的代码的实现

1、activity_main.xml

<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:background="#000000"
    android:orientation="vertical"
       
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin" 
    tools:context=".MainActivity" >
    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" >
        <EditText
            android:id="@+id/etNum1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
           android:background="#FFFFFF"
            android:inputType="numberDecimal"           
            android:textSize="20sp" >
            <requestFocus />
        </EditText>

        <TextView
            android:id="@+id/tvOp"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"  
            android:textColor="#FFFFFF"
            android:text=""
            android:textSize="20sp" />

        <EditText
            android:id="@+id/etNum2"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:inputType="numberDecimal"
            android:background="#FFFFFF"
            android:textSize="20sp" >

            <requestFocus />
        </EditText>

        <TextView
            android:id="@+id/textView2"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:textColor="#FFFFFF"
            android:text="="        
            android:textSize="20sp" />

      <TextView
            android:id="@+id/tvResult"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1" 
            android:textColor="#FFFFFF"           
            android:text=""        
            android:textSize="20sp" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content" 
        android:layout_marginTop="10dp">
        <Button
            android:id="@+id/add"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:onClick="add"
            android:text="+"
            android:textColor="#EA0000"
            android:textSize="30sp" />

        <Button
            android:id="@+id/sub"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:onClick="sub"
            android:text="-"
              android:textColor="#EA0000"
            android:textSize="30sp" />

        <Button
            android:id="@+id/multiply"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:onClick="multiply"
            android:text="*"
            android:textColor="#EA0000"
            android:textSize="30sp" />

        <Button
            android:id="@+id/divide"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:onClick="divide"
            android:text="/"
            android:textColor="#EA0000"
            android:textSize="30sp" />
    </LinearLayout>

</LinearLayout>

2、MainActivity.java

package com.example.jisuanqi;

import com.example.jisuanqi.model.Calculator;

import android.os.Bundle;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.DialogInterface.OnClickListener;

import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.EditText;
import android.widget.Switch;
import android.widget.TextView;
import android.widget.Toast;

public class MainActivity extends Activity {
  private EditText etNum1;
  private EditText etNum2;
  private TextView tvOp;
  private TextView tvResult;
  double num1;
  double num2;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		initViews();
	}
	
	private void initViews() {
		etNum1=(EditText) this.findViewById(R.id.etNum1);
		etNum2=(EditText) this.findViewById(R.id.etNum2);
		tvOp=(TextView) this.findViewById(R.id.tvOp);
		tvResult=(TextView) this.findViewById(R.id.tvResult);		
	}
	
	@Override
	public boolean onCreateOptionsMenu(Menu menu) { 		 
		//menu.add(0, 1, 1,R.id.about);		 
	      //menu.add(0, 2, 2,R.id.exit);	
		getMenuInflater().inflate(R.menu.main, menu);
		return super.onCreateOptionsMenu(menu); 		 
		}  		 		 
		public boolean onOptionsItemSelected(MenuItem item) { 
			switch (item.getItemId()){
			case R.id.about:
			AlertDialog.Builder alertDialog=new AlertDialog.Builder(this);
			alertDialog.setTitle(R.string.menu_about);
			alertDialog.setMessage(R.string.dialog_message);
			alertDialog.setPositiveButton("确定", new OnClickListener() {
				
				@Override
				public void onClick(DialogInterface dioDialog, int which) {
					dioDialog.dismiss();
					
					
				}
			});
			alertDialog.create().show();
				break;
			case R.id.exit:
				Toast.makeText(this,"exit", Toast.LENGTH_SHORT).show();
			default:
				break;
			}
			return super.onOptionsItemSelected(item);
			


		}

	public void add(View view){
		getDate();
		tvOp.setText("+");
		tvResult.setText(""+Calculator.add(num1, num2));
				
	}

	private void getDate() {
		String strNum1=etNum1.getText().toString();
		String strNum2=etNum2.getText().toString();
		 num1=Double.parseDouble(strNum1);
		 num2=Double.parseDouble(strNum2);
	}
	public void sub(View view){
    	getDate();
		tvOp.setText("-");
		tvResult.setText(""+Calculator.sub(num1, num2));
				
		
	}
     public void multiply(View view){
    	 getDate();
    	  		tvOp.setText("*");
 		tvResult.setText(""+Calculator.multiply(num1, num2));
 				
		
	}
     public void divide(View view){
    	 getDate();
 		tvOp.setText("/");
 		tvResult.setText(""+Calculator.divide(num1, num2));
 				
 		
 	}

}

3、Calculator.java

package com.example.jisuanqi.model;

import android.R.dimen;

public class Calculator{
	public static double add(double num1,double num2){//方便调用
		return num1+num2;
		
	}
	public static double sub(double num1,double num2){//方便调用
		return num1-num2;
		
	}
	public static double multiply(double num1,double num2){//方便调用
		return num1*num2;
		
	}
	public static double divide(double num1,double num2){//方便调用
		if(num2==0){
			throw new ArithmeticException("除数不能为0");//抛出异常处理
		}
		return num1/num2;
		
	}
	

}

4、Strings.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="app_name">Jisuanqi</string>
    <string name="action_settings">Settings</string>
  <string name="menu_about">关于</string>
    <string name="menu_exit">退出</string>
    <string name="dialog_message">作者:xixi\n版本:1.0</string>

</resources>

5、menu文件下的main.xml

<menu xmlns:android="http://schemas.android.com/apk/res/android" >

    <item
        android:id="@+id/about"
        android:orderInCategory="100"
        android:showAsAction="never"
        android:title="@string/menu_about" 
        android:icon="@android:drawable/ic_menu_help" 
        />
     <item
        android:id="@+id/exit"
        android:orderInCategory="100"
        android:showAsAction="never"
        android:icon="@android:drawable/ic_menu_delete"
        android:title="@string/menu_exit"
        />

</menu>

三、运行效果图

1、计算界面


2、点击menu菜单后的界面



3、点击“关于”后显示信息的界面




  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值