今天开始重新踏上Android的学习历程也学习网上楼主们开始写一写Android的一些学习过程中的问题以便以后再犯,所以有了写博客的念头,不知道自己写出的东西会不会得到大家的认可,但毕竟是刚刚开始没有经验,望读者们提出宝贵意见是自己的文笔得到提高些吧、、、黑黑
今天的第一步开始学习Android教程的Activity与Intent的应用吧》》
首先介绍一下Activity吧:=
Activty在我的理解上是一个个手机的界面其中每个activity中又包含了许许多多的控件:Button (按钮) ,TextView(文本) ,progressBar(进度条),EditText(可编辑文本)等等;
activity的运作方式是有一定的周期性的:Android中的activity的生命周期是交给系统统一管理的;
activity的状态转换有六个基本状态:
onCreat方法:
Activity的实例被启动时调用的第一个方法。一般情况下,我们都覆盖该方法作为应用程序的一个入口点,在这里做一些初始化数据、设置用户界面等工作。大多数情况下,我们都要在这里从xml中加载设计好的用户界面。例如:
setContentView(R.layout.main);
注:当然,也可从savedInstanceState中读我们保存到存储设备中的数据,但是需要判断savedInstanceState是否为null,因为Activity第一次启动时并没有数据被存贮在设备中:
if(savedInstanceState!=null){
savedInstanceState.get("Key");
}
protectedvoidonStart()该方法在onCreate()方法之后被调用,或者在Activity从Stop状态转换为Active状态时被调用。
protectedvoidonResume()在Activity从Pause状态转换到Active状态时被调用。
protectedvoidonResume()在Activity从Active状态转换到Pause状态时被调用。
protectedvoidonStop()在Activity从Active状态转换到Stop状态时被调用。一般我们在这里保存Activity的状态信息。
protectedvoidonDestroy()在Active被结束时调用,它是被结束时调用的最后一个方法,在这里一般做些释放资源,清理内存等工作。
Paused当Activity被另一个透明或者Dialog样式的Activity覆盖时的状态。此时它依然与窗口管理器保持连接,系统继续维护其内部状 态,所以它仍然可见,但它已经失去了焦点故不可与用户交互。
Stoped当Activity被另外一个Activity覆盖、失去焦点并不可见时处于Stoped状态。
publicclassOurActivityextendsActivity{
protectedvoidonCreate(BundlesavedInstanceState);
protectedvoidonStart();
protectedvoidonResume();
protectedvoidonPause();
protectedvoidonStop();
protectedvoidonDestroy();
}
此外,Android还定义了一些不常用的与生命周期相关的方法可用:
protectedvoidonPostCreate(BundlesavedInstanceState);
protectedvoidonRestart();
protectedvoidonPostResume();
Android提供的文档详细的说明了它们的调用规则。
Activity文件:
public class EX01 extends Activity{
private static final String LOG_TAG=EX01.class.getSimpleName();
@Override
public void onCreate(BundlesavedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Log.e(LOG_TAG,"onCreate");
}
@Override
protected void onStart(){
Log.e(LOG_TAG,"onStart");
super.onStart();
}
@Override
protected void onResume(){
Log.e(LOG_TAG,"onResume");
super.onResume();
}
@Override
protected void onPause(){
Log.e(LOG_TAG,"onPause");
super.onPause();
}
@Override
protected void onStop(){
Log.e(LOG_TAG,"onStop");
super.onStop();
}
@Override
protected void onDestroy(){
Log.e(LOG_TAG,"onDestroy");
super.onDestroy();
}
}
了解了activity的生命周期后在eclipse中练习着打以上的代码运行以上程序然后看logcat中的打印内容;实现activity与activity之间的跳转
CurrentActivity是当前的activity,
OtherActivity是要跳转的activity
Activity.startActivity()方法可以根据传入的参数启动另外一个Activity:
Intent intent=new Intent(CurrentActivity.this,OtherActivity.class);
startActivity(intent);
当然,OtherActivity同样需要在AndroidManifest.xml中定义。
Activity之间通信:使用Intent通信
在Android中,不同的Activity实例可能运行在一个进程中,也可能运行在不同的进程中。因此我们需要一种特别的机制帮助我们在Activity之间传递消息。Android中通过Intent对象来表示一条消息,一个Intent对象不仅包含有这个消息的目的地,还可以包含消息的内容,这好比一封Email,其中不仅应该包含收件地址,还可以包含具体的内容。对于一个Intent对象,消息“目的地”是必须的,而内容则是可选项。
在上面的实例中通过Activity.startActivity(intent)启动另外一个Activity的时候,我们在Intent类的构造器中指定了“收件人地址”。
如果我们想要给“收件人”Activity说点什么的话,那么可以通过下面这封“e-mail”来将我们消息传递出去:
Intentintent=newIntent(CurrentActivity.this,OtherActivity.class);
//创建一个带“收件人地址”的email
Bundlebundle=newBundle();//创建email内容
bundle.putBoolean("boolean_key",true);//编写内容
bundle.putString("string_key","string_value");
intent.putExtra("key",bundle);//封装email
startActivity(intent);//启动新的Activity
那么“收件人”该如何收信呢?在OtherActivity类的onCreate()或者其它任何地方使用下面的代码就可以打开这封“e-mail”阅读其中的信息:
Intentintent=getIntent();//收取email
Bundlebundle=intent.getBundleExtra("key");//打开email
bundle.getBoolean("boolean_key");//读取内容
bundle.getString("string_key");
上面我们通过bundle对象来传递信息,bundle维护了一个HashMap
Intentintent=newIntent(EX06.this,OtherActivity.class);
intent.putExtra("boolean_key",true);
intent.putExtra("string_key","string_value");
startActivity(intent);
接收:
Intentintent=getIntent();
intent.getBooleanExtra("boolean_key",false);
intent.getStringExtra("string_key");
使用SharedPreferences
SharedPreferences使用xml格式为Android应用提供一种永久的数据存贮方式。对于一个Android应用,它存贮在文件系统的/data/data/your_app_package_name/shared_prefs/目录下,可以被处在同一个应用中的所有Activity访问。Android提供了相关的API来处理这些数据而不需要程序员直接操作这些文件或者考虑数据同步问题。
//写入SharedPreferences
SharedPreferencespreferences=getSharedPreferences("name",MODE_PRIVATE);
Editoreditor=preferences.edit();
editor.putBoolean("boolean_key",true);
editor.putString("string_key","string_value");
editor.commit();
//读取SharedPreferences
SharedPreferencespreferences=getSharedPreferences("name",MODE_PRIVATE);
preferences.getBoolean("boolean_key",false);
preferences.getString("string_key","default_value");
其它方式:
AndroidManifest.xml文件:
Android提供了包括SharedPreferences在内的很多种数据存贮方式,比如SQLite,文件等,程序员可以通过这些API实现Activity之间的数据交换。如果必要,我们还可以使用IPC方式。
Activity的IntentFilter
IntentFilter描述了一个组件愿意接收什么样的Intent对象,Android将其抽象为android.content.IntentFilter类。在Android的AndroidManifest.xml配置文件中可以通过
当程序员使用startActivity(intent)来启动另外一个Activity时,如果直接指定intent了对象的Component属性,那么ActivityManager将试图启动其Component属性指定的Activity。否则Android将通过Intent的其它属性从安装在系统中的所有Activity中查找与之最匹配的一个启动,如果没有找到合适的Activity,应用程序会得到一个系统抛出的异常。这个匹配的过程如下:
图4.Activity种IntentFilter的匹配过程
Action匹配
Action是一个用户定义的字符串,用于描述一个Android应用程序组件,一个IntentFilter可以包含多个Action。在AndroidManifest.xml的Activity定义时可以在其
……
如果我们在启动一个Activity时使用这样的Intent对象:
Intent intent=new Intent();
intent.setAction("com.zy.myaction");
那么所有的Action列表中包含了“com.zy.myaction”的Activity都将会匹配成功。
Android预定义了一系列的Action分别表示特定的系统动作。这些Action通过常量的方式定义在android.content.Intent中,以“ACTION_”开头。我们可以在Android提供的文档中找到它们的详细说明。
URI数据匹配
一个Intent可以通过URI携带外部数据给目标组件。在
mimeType属性指定携带外部数据的数据类型,scheme指定协议,host、port、path指定数据的位置、端口、和路径。如下:
android:host="host"android:port="port"android:path="path"/> 如果在IntentFilter中指定了这些属性,那么只有所有的属性都匹配成功时URI数据匹配才会成功。 Category类别匹配 一些关于Activity的技巧 锁定Activity运行时的屏幕方向 Android内置了方向感应器的支持。在G1中,Android会根据G1所处的方向自动在竖屏和横屏间切换。但是有时我们的应用程序仅能在横屏/竖屏时运行,比如某些游戏,此时我们需要锁定该Activity运行时的屏幕方向, android:label="@string/app_name" android:screenOrientation="portrait">//竖屏,值为landscape时为横屏 ………… 全屏的Activity 要使一个Activity全屏运行,可以在其onCreate()方法中添加如下代码实现: //设置全屏模式 getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); //去除标题栏 requestWindowFeature(Window.FEATURE_NO_TITLE); 在Activity的Title中加入进度条 为了更友好的用户体验,在处理一些需要花费较长时间的任务时可以使用一个进度条来提示用户“不要着急,我们正在努力的完成你交给的任务”。如下图: 在Activity的标题栏中显示进度条不失为一个好办法,下面是实现代码: //不明确进度条 requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS); setContentView(R.layout.main); setProgressBarIndeterminateVisibility(true); //明确进度条 requestWindowFeature(Window.FEATURE_PROGRESS); setContentView(R.layout.main); setProgress(5000);