Android之Activity跳转

Posted 被罚站的树

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Android之Activity跳转相关的知识,希望对你有一定的参考价值。

简述


  如果把每个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传递数据,建议使用下面的方式。

 

 应用场景


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

以上是关于Android之Activity跳转的主要内容,如果未能解决你的问题,请参考以下文章

Android开发之Activity的创建跳转及传值

ANDROID开发之问题积累及解决方案(不断更新)

Android系统路由之-scheme实现网页链接携带参数跳转到Activity

Android开发之Activity跳转动画以及finish动画

Android 事件分发事件分发源码分析 ( Activity 中各层级的事件传递 | Activity -> PhoneWindow -> DecorView -> ViewGroup )(代码片段

android如何中自动跳转activity