简述
如果把每个activity看成一个页面的话,那么activity之间的跳转和页面的之间的跳转基本上是一样的。首先需要监听一个事件,当这个事件发生的时候,就进行跳转。html中有个<a src="..."></a>的链接标签,当我们点击这个链接的时候就会发送跳转。这是因为浏览器会自动监听这个链接是否被点击,如果被点击那个浏览器自己执行跳转动作。但是在Android中就没这么简单,程序员需要自己去监听某个事件,当这个事件发生的时候,需要自己指定目的Activity,当然还可以携带一些数据传递给下一个Activity。原理上还是与页面跳转相同的。
显示与隐式
跳转分为隐式和显示跳转,显示跳转比较简答,先简述一下显示跳转。不同应用之间跳转用隐式,同一应用跳转用显示
package xidian.dy.com.chujia; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; public class MainActivity extends AppCompatActivity { Button btn; private Button second2; private Button panel; private Button panel2; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btn = (Button) findViewById(R.id.second); second2 = (Button) findViewById(R.id.second2); panel = (Button) findViewById(R.id.panel); panel2 = (Button) findViewById(R.id.panel2); //显示跳转至第二个Activity btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); intent.setClass(MainActivity.this, SecondActivity.class); startActivity(intent); } }); //隐式跳转到第二个Activity second2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); intent.setAction("xidian.dy.com.chujia.se"); intent.addCategory(Intent.CATEGORY_DEFAULT); startActivity(intent); } }); //隐式跳转至拨号盘 panel.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); intent.setAction(Intent.ACTION_DIAL);
inttent.setCategory(Intent.CATEGORY_DEFAULT); startActivity(intent); } }); //显示跳转至拨号盘 panel2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); //指定包名以及具体的Activity类名 intent.setClassName("com.android.contacts", "com.android.contacts.DialtactsContactsEntryActivityForDialpad"); startActivity(intent); } }); } }
上面的代码监听了四个按键,当按键被按下的时候进行Activity的跳转。在进行跳转时,我们需要定义一个意图对象(intent)来描述我们要干啥的细节,然后调用startActivity告诉系统启动一个Activity,并把细节传递进去。跳转分为显示跳转和隐式跳转,下面进行详细说明。
显示跳转
- 同一应用跳转
一个APP中会有多个Activity,这些Activity之间进行跳转时可以采用第一种方式 intent.setClass(MainActivity.this, SecondActivity.class); 第一个参数是当前的activity,第二个参数是要跳转的Activity类文件
- 跨应用跳转
要从一个APP的Activity跳转到另一个,需要使用第四种方式 intent.setClassName("com.android.contacts", "com.android.contacts.DialtactsContactsEntryActivityForDialpad"); 第一个参数是应用的包名,第二个参数是要跳转的Activity的类名。
隐式跳转
隐式跳转相对比较复杂,这里单独拿出来说。
首先,看一下清单文件。
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="xidian.dy.com.chujia"> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity" android:label="主界面"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <activity android:name=".SecondActivity" android:label="第二个界面"> <intent-filter> <action android:name="xidian.dy.com.chujia.se" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity> </application> </manifest>
APP中Activity如果要显示的话都需要在清单文件中进行注册。
第二个Activity:
<activity android:name=".SecondActivity" android:label="第二个界面"> .SecondActivity指定这个Activity对象的类文件,lable显示在Activity的最上面,如果是主界面的话还会显示在应用图标下面。
<action android:name="xidian.dy.com.chujia.se" /> 这里的值就和我们的隐式跳转有关系了。在做隐式跳转时,我们传递的字符串与这里的是一致的 intent.setAction("xidian.dy.com.chujia.se"); 。我们看到这个action是放在一个意图过滤器中的,当我们调用setAction时,系统会通过我们的请求传递给过滤器,过滤器会根据不同请求给出不同的相应(有点像MVC中控制器)。
<category android:name="android.intent.category.DEFAULT" /> 这里是对Activity的说明,如果没有特殊需要一般是DEFAULT。
第一个Activity:
<activity android:name=".MainActivity" android:label="主界面"> .MainActivity指定这个Activity对象的类文件,lable就是我们手机上显示的应用图标时下的文字。
<action android:name="android.intent.action.MAIN" /> 这里name的值是有特殊含义的,这是告诉系统这是我应用的入口Activity
<category android:name="android.intent.category.LAUNCHER" /> 这是来说明我的应用启动的时候就加载这个Activity,不要加载应用中其他的Activity。
隐式跳转流程简述
当我们的点击按钮后会触发监听事件,然后创建一个意图。对这个意图设置属性,然后过滤器会根据属性找到具体的Activity类。这里的过滤匹配是完全匹配,我们设置的属性不能多也不能少。清单文件中有几个属性,在设置的时候就应添加相同的属性。在第二Activity中我们在过滤其中定义了两个属性,那么在创建意图的时候也设置了两个属性。如果我们调用系统的Activity的话可以传递常量给意图。
数据传输
在Activity中如果需要使用到数据传输的话,可以参考一下代码。
清单文件
<?xml version="1.0" encoding="utf-8"?> <manifest xmlns:android="http://schemas.android.com/apk/res/android" package="xidian.dy.com.chujia"> <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/> <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/> <uses-permission android:name="android.permission.INTERNET" /> <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/> <application android:allowBackup="true" android:icon="@mipmap/ic_launcher" android:label="@string/app_name" android:supportsRtl="true" android:theme="@style/AppTheme"> <activity android:name=".MainActivity" android:label="主界面"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> <activity android:name=".SecondActivity" android:label="第二个界面"> <intent-filter> <action android:name="xidian.dy.com.chujia.se" /> <data android:scheme="my" android:mimeType="text/password" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity> </application> </manifest>
主布局文件
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="这是主Activity"/> <Button android:id="@+id/second" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="显示跳转至子Activity"/> </LinearLayout>
子布局
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="这是第二个Activity" /> </LinearLayout>
MainActivity.java
package xidian.dy.com.chujia; import android.content.Intent; import android.net.Uri; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; public class MainActivity extends AppCompatActivity { private Button btn; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btn = (Button) findViewById(R.id.second); btn.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Intent intent = new Intent(); intent.setAction("xidian.dy.com.chujia.se"); intent.addCategory(Intent.CATEGORY_DEFAULT); intent.setDataAndType(Uri.parse("my:123456"), "text/password"); startActivity(intent); } }); } }
SecondActivity.java
package xidian.dy.com.chujia; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.util.Log; import android.widget.Button; /** * Created by dy on 2016/7/2. */ public class SecondActivity extends AppCompatActivity{ Button btn; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_second); Intent intent = getIntent(); Log.i("SecondActivity", intent.getDataString()); } }
注意:虽然我们可以通过Data携带一些数据过来,但是毕竟类型有限,这里的话如果需要向下一个Activity传递数据,建议使用下面的方式。
应用场景
在应用之间跳转用隐式跳转,在一个应用内进行跳转用显示跳转。