Android之Activity跳转

时间:2024-05-29 14:04:26

简述


  如果把每个activity看成一个页面的话,那么activity之间的跳转和页面的之间的跳转基本上是一样的。首先需要监听一个事件,当这个事件发生的时候,就进行跳转。html中有个<a src="..."></a>的链接标签,当我们点击这个链接的时候就会发送跳转。这是因为浏览器会自动监听这个链接是否被点击,如果被点击那个浏览器自己执行跳转动作。但是在Android中就没这么简单,程序员需要自己去监听某个事件,当这个事件发生的时候,需要自己指定目的Activity,当然还可以携带一些数据传递给下一个Activity。原理上还是与页面跳转相同的。

显示与隐式


跳转分为隐式和显示跳转,显示跳转比较简答,先简述一下显示跳转。不同应用之间跳转用隐式,同一应用跳转用显示

Android之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传递数据,建议使用下面的方式。

Android之Activity跳转

Android之Activity跳转

应用场景


在应用之间跳转用隐式跳转,在一个应用内进行跳转用显示跳转。