Android简易实战教程--第一话《最简单的计算器》

转载请注明出处:http://blog.csdn.net/qq_32059827/article/details/51707931

从今天开始,本专栏持续更新Android简易实战类博客文章。和以往专栏不同,此专栏只有实例。每个实例尽量按照知识点对应相应一章节的内容去写,循序渐进。有些实例可能会与另一个专栏有重复的文章。

开始本专栏的第一个简易案例:

首先设置两个布局文件,一个布局文件进行输入数据,获取加法运算;另一个布局文件进行显示最终结果。Activity1启动Activity2,并传递计算结果值给Activity2.

main.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
<EditText 
	android:id="@+id/factorOne"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
	/>
<TextView  
	android:id="@+id/symbol"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    />
<EditText 
	android:id="@+id/factorTwo"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
	/>
<Button
	android:id="@+id/calculate"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
	/>
</LinearLayout>

页面展示:

result.xml

activity03活动:

package mars.activity03;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
//1.在Activity03当中,要声明四个控件
//2.要为其中的两个控件设置显示的值
//3.创建一个监听器类,监听按钮按下的动作
//4.将监听器类的对象,绑定在按钮对象上
public class Activity03 extends Activity {
    /** Called when the activity is first created. */
	private EditText factorOne ;
	private EditText factorTwo;
	private TextView symbol;
	private Button calculate;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        //根据控件的ID来取得代表控件的对象
        factorOne = (EditText)findViewById(R.id.factorOne);
        factorTwo = (EditText)findViewById(R.id.factorTwo);
        symbol = (TextView)findViewById(R.id.symbol);
        calculate = (Button)findViewById(R.id.calculate);
        //为symbol和calculate设置显示的值
//        symbol.setText("乘以");
//        calculate.setText("计算");
        symbol.setText(R.string.symbol);//这里通过引用的方式,去String文件中引用。保证了业务逻辑、视图、引用资源分开
        calculate.setText(R.string.calculate);
        //将监听器的对象绑定到按钮对象上面
        calculate.setOnClickListener(new CalculateListener());
    }
    //当客户点击MENU按钮的时候,调用该方法
    @Override
	public boolean onCreateOptionsMenu(Menu menu) {
    	menu.add(0, 1, 1, R.string.exit);
    	menu.add(0,2,2,R.string.about);
		return super.onCreateOptionsMenu(menu);
	}
    //当客户点击菜单当中的某一个选项时,会调用该方法
	@Override
	public boolean onOptionsItemSelected(MenuItem item) {
		if(item.getItemId() == 1){
			finish();
		}
		return super.onOptionsItemSelected(item);
	}
	class CalculateListener implements OnClickListener{

		@Override
		public void onClick(View v) {
			//取得两个EditText控件的值
			String factorOneStr = factorOne.getText().toString();
			String factorTwoStr = factorTwo.getText().toString();
			//将这两个值存放到Intent对象当中
			Intent intent = new Intent();
			intent.putExtra("one",factorOneStr);
			intent.putExtra("two",factorTwoStr);
			intent.setClass(Activity03.this, ResultActivity.class);
			//使用这个Intent对象来启动ResultActivity
			Activity03.this.startActivity(intent);
		}
    }
}

resultActivity:

package mars.activity03;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.widget.TextView;
//1.接受从Activity03当中所传递的值
//2.计算两个值的积
//3.将计算的结果显示在Activity上
public class ResultActivity extends Activity{
	private TextView resultView;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.result);
		resultView = (TextView)findViewById(R.id.result);
		//得到Intent对象当中的值 
		Intent intent = getIntent();
		String factorOneStr = intent.getStringExtra("one");
		String factorTwoStr = intent.getStringExtra("two");
		int factorOneInt = Integer.parseInt(factorOneStr);
		int factorTwoInt = Integer.parseInt(factorTwoStr);
		//计算两个值的积
		int result = factorOneInt * factorTwoInt;
		resultView.setText(result + "");
	}

}

String.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="hello">Hello World, Activity03!</string>
    <string name="app_name">activity03</string>
    <string name="resultLabel">result</string>
    <string name="symbol">乘以</string>
    <string name="calculate">计算</string>
    <string name="exit">退出</string>
    <string name="about">关于</string>
</resources>

最后再看一下配置文件:活动都要进行注册,并且设置Activity03为主活动

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="mars.activity03"
      android:versionCode="1"
      android:versionName="1.0">
    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".Activity03"
                  android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
		<activity android:name=".ResultActivity" android:label="@string/resultLabel"/><!--这里使ResultActivity标题栏显示result-->
    </application>
    <uses-sdk android:minSdkVersion="4" />

</manifest> 

结果:



本页内容版权归属为原作者,如有侵犯您的权益,请通知我们删除。

详解数组,链表和ADT - 2016-06-19 14:06:42

数组 先由一个例子复习一下数组的操作: class HighArray{ private long [] a; private int nElems; //----------------------------------- public HighArray ( int max) //构造函数 { a= new long [max]; nElems = 0 ; } //----------------------------------- public boolean find ( long searc
(一)带阴影的TextView 涉及到的几个属性: 运行效果如下: 实现代码: TextView android: id = "@+id/textView1" android:layout_width= "wrap_content" android:layout_height= "wrap_content" android:layout_alignParentTop= "true" android:layout_centerHorizontal= "true" android:layout_marginT

Android课程表的设计开发 - 2016-06-19 14:06:07

Android课程表的设计开发 导语 实现了教务系统中课程的导入,分类显示课程。学期的修改,增加,修改。课程按照周的显示。课程修改上课星期和上课周。上课课程的自动归类。 一、主要功能界面 开发过程 一开始因为毕设有关课程表的要求不明,主要就是利用jsoup拉取学校教务管理系统的课程数据进行课程表界面的填充显示,并不能课程的个性化调整。 后来重新调整了需求,参考了超级课程表的功能。重新设计了实体类,利用bmob移动端云作为爬取到的数据的数据服务器进行了重新的开发。 主要代码 1、课程实体类 package

BroadcastReceiver简介 - 2016-06-19 14:06:05

涉及到的内容 接收系统广播 发送自定义广播 无序广播 intent携带数据 有序广播 终止广播 修改广播数据 得到广播数据 指定最终广播接受者,即使被终止,也会受到 系统常用广播的配置 应用方面 拦截短信 串改短信内容 拦截电话 串改拨出的号码 特殊情况 (屏幕开关的事件) 代码注册 代码注销 BroadcastReceiver入门(一) 什么是广播接受者 BroadcastReceiver就是一台收音机 用来接收android系统发出的一些广播(不仅仅是系统发出的广播,我们也可自定义广播) 可以理解为系
iOS10 权限崩溃问题 每日更新关注 : http://weibo.com/hanjunqiang   新浪微博!         今天 手机升级了 iOS10 Beta,然后用正在开发的项目 装了个ipa包,发现点击有关 权限访问 直接Crash了,并在控制台输出了一些信息: This app has crashed because it attempted to access privacy-sensitive data without a usage description.  The app's

图片处理的一些方法 - 2016-06-19 14:06:58

在请求网络时。我们经常会从服务端获取图片,下面我总结了一些图片的处理方法,希望能够帮助其他人 防止批量加载图片时出现OOM(OutOfMemory) 压缩图片 BitmapUtils 图片操作的工具类 //width 图片显示的宽度 height图片显示的高度 Bitmap loadBitmap(is, width, height){ } Android中图片缓存的实现 Java中的引用 1强引用 Strong References 就算出现OOM,Java虚拟机都不会销毁该引用。 2软引用 Soft R

Android初级教程图片信息 - 2016-06-19 14:06:58

对图片常规信息要了解其性质。图片大小、像素、位图等等概念总结如下: 图片在计算机中的大小 图片的总大小 = 图片的总像素 * 每个像素占用的大小(图片的总像素=像素尺寸也就是分辨率,例如设定800*400)(每个像素大小不相同)才导致图片总的大小不相同。 单色位图:只能表示2种颜色 使用两个数字:0和1 使用一个【长度为1】的二进制数字就可以表示了 每个像素占用1/8个字节 总大小=图片的总像素 * 每个像素占用的大小=320000/8=40000字节(查看图片信息与之基本匹配) 16色位图:能表示16种
最近项目有一个需求,需要多层可滑动控件的嵌套展示,demo效果如下,demo的下载地址在最后 咋一看好像挺简单啊,不就是一个ScrollView + ViewPager + ListView吗,我开始也这样觉得,也用的这种方式实现,结果始终和效果不对劲。这里总结几点问题: 两个或两个以上的滑动控件嵌套时,如果layout_height采用的是wrap_content会造成内部滑动控件的高度不能正确的计算,会导致内部滑动控件的高度始终为0,除非你用定值设置,比如300dp。 两个相同滑动方向的滑动控件嵌套,
Grand Central Dispatch简介 Grand Central Dispatch 简称 GCD 是苹果公司开发的技术,是对于多核编程的较新解决方案。它主要用于优化应用程序以支持多核处理器以及其他对称多处理系统。 GCD 提供了一种很简单的操作方式来实现并行处理。你可以把你要的并发执行的代码放在一个block钟,然后把这个block加入到一个queue当中。 在GCD中为我们需要执行的block提供了3种队列: Main:这个队列顺序执行我们的block,并保证这些block都在主线程中执行。

[置顶] Android消息循环机制 - 2016-06-19 14:06:38

转载请注明出处: http://blog.csdn.net/crazy1235/article/details/51707527 Android的消息循环机制主要先关的类有: Handler Looper Message MessageQueue ActivityThread 实际上 应用程序启动的时候,会创建一个UI线程,然后该线程关联一个消息队列,相关操作封装一个个消息放入队列中,主线程会 不断循环 从队列中取出消息进行分发处理。 为什么用Handler 大家都知道,Android规定【访问UI只能在