zoukankan      html  css  js  c++  java
  • Android初级教程理论知识(第五章页面跳转和数据传递)

    总体概述:

    Android四大组件

    • Activity
    • BroadCastReceiver
    • Service
    • ContentProvider

    创建第二个activity

    • 新创建的activity,必须在清单文件中做配置,否则系统找不到,在显示时会直接报错

      <activity android:name="com.it.createactivity.SecondActivity"></activity>
      
    • 只要有以下代码,那么就是入口activity,就会生成快捷图标

      <intent-filter>
              <action android:name="android.intent.action.MAIN" />
      
              <category android:name="android.intent.category.LAUNCHER" />
          </intent-filter>
      
    • 如果Activity所在的包跟应用包名同名,那么可以省略不写

    • 创建class类继承Activity

    • 创建布局文件,作为Activity的显示内容
    • 在清单文件中注册Activity

    Activity的跳转

    隐式跳转

    • 一个Activity如果需要隐式跳转,那么在清单文件中必须添加以下子节点

      <intent-filter >
          <action android:name="com.it.sa"/>
          <category android:name="android.intent.category.DEFAULT"/>
      </intent-filter>
      
    • action节点的name是自己定义的,定义好之后,这个name的值就会成为这个activity动作,在隐式启动Activity时,意图中设置的action必须跟"com.it.sa"是完全匹配的。即intent.setAction("com.it.sa");

    应用场景

    • 显示意图:启动同一个应用中的Activity
    • 隐式意图:启动不同应用中的Activity
    • 在启动效率上,隐式远远低于显式
    • 如果系统中有多个Activity与意图设置的Action匹配,那么在启动Activity时,会弹出一个对话框,里面包含所有可启动的与之匹配的Activity

    Activity生命周期

    • oncreate:Activity对象创建完毕,但此时不可见
    • onstart:Activity在屏幕可见,但是此时没有焦点
    • onResume:Activity在屏幕可见,并且获得焦点
    • onPause:Activity此时在屏幕依然可见,但是已经没有焦点
    • onStop:Activity已经不可见了,但此时Activity的对象还在内存中(有可能被回收)
    • onDestroy:Activity对象被销毁

    内存不足

    • 内存不足时,系统会优先杀死后台Activity所在的进程,都杀光了,如果内存还是不足,那么就会杀死暂停状态的Activity所在的进程,如果还是不够,有可能杀死前台进程
    • 如果有多个后台进程,在选择杀死的目标时,采用最近最少使用算法(LRU)

    Activity任务栈

    • 应用运行过程中,内存中可能会打开多个Activity,那么所有打开的Activity都会被保存在Activity任务栈
    • 栈:后进先出,最先进栈,就会最后出栈。子弹

    Activity的启动模式

    • 标准模式:默认就是这个模式
    • singleTop:如果目标Activity不在栈顶,那么就会启动一个新的Activity,如果已经在栈顶了,那么就不会再启动了
    • singleTask:如果栈中没有该Activity,那么启动时就会创建一个该Activity,如果栈中已经有该Activity的实例存在了,那么在启动时,就会杀死在栈中处于该Activity上方的所有Activity全部杀死,那么此时该Activity就成为了栈顶Activity。
      • singleTask的作用:保证整个栈中只有一个该Activity的实例
    • singleInstance:设为此模式的Activity会有一个自己独立的任务栈,该Activity的实例只会创建一个,保存在独立的任务栈中
      • singleInstance的作用:保证整个系统的内存中只有一个该Activity的实例

    横竖屏的切换

    • Activity在横竖屏切换时会销毁重建,目的就是为了读取新的布局文件
    • 写死方向,不允许切换

      android:screenOrientation="portrait"
      android:screenOrientation="landscape"
      
    • 配置Activity时添加以下属性,横竖屏切换时就不会销毁重建

      android:configChanges="orientation|keyboardHidden|screenSize"
      

    Activity返回时传递数据

    • 请求码:用来区分数据来自于哪一个Activity
    • 结果码:用来区分,返回的数据时属于什么类型

    具体内容:

    创建第二个Activity

    • 需要在清单文件中为其配置一个activity标签
    • 标签中如果带有这个子节点,则会在系统中多创建一个快捷图标

       <intent-filter>
           <action android:name="android.intent.action.MAIN" />
           <category android:name="android.intent.category.LAUNCHER" />
       </intent-filter>
      
    • 一个应用程序可以在桌面创建多个快捷图标。
    • activity的名称、图标可以和应用程序的名称、图标不相同

      android:icon="@drawable/ic_launcher"
      android:label="@string/app_name"
      

    Activity的跳转

    Activity的跳转需要创建Intent对象,通过设置intent对象的参数指定要跳转Activity

    通过设置Activity的包名和类名实现跳转,称为显式意图

    通过指定动作实现跳转,称为隐式意图

    显式意图

    • 跳转至同一项目下的另一个Activity,直接指定该Activity的字节码即可

      Intent intent = new Intent();
      intent.setClass(this, SecondActivity.class);
      startActivity(intent);
      
    • 跳转至其他应用中的Activity,需要指定该应用的包名和该Activity的类名

      Intent intent = new Intent();
      //启动系统自带的拨号器应用
      intent.setClassName("com.android.dialer", "com.android.dialer.DialtactsActivity");
      startActivity(intent);
      

    隐式意图

    • 隐式意图跳转至指定Activity

      Intent intent = new Intent();
      //启动系统自带的拨号器应用
      intent.setAction(Intent.ACTION_DIAL);
      startActivity(intent);
      
    • 要让一个Activity可以被隐式启动,需要在清单文件的activity节点中设置intent-filter子节点

      <intent-filter >
          <action android:name="com.it.second"/>
          <data android:scheme="asd" android:mimeType="aa/bb"/>
          <category android:name="android.intent.category.DEFAULT"/>
      </intent-filter>
      
      • action 指定动作(可以自定义,可以使用系统自带的)
      • data 指定数据(操作什么内容)
      • category 类别 (默认类别,机顶盒,车载电脑)
    • 隐式意图启动Activity,需要为intent设置以上三个属性,且值必须与该Activity在清单文件中对三个属性的定义匹配。谁启动其他应用的activity就要在intent中设置与被启动activity清单文件中的intent-filter全部匹配。
    • intent-filter节点及其子节点都可以同时定义多个,隐式启动时只需与任意一个匹配即可
    获取通过setData传递的数据
        //获取启动此Activity的intent对象
        Intent intent = getIntent();
        Uri uri = intent.getData();
    

    显式意图和隐式意图的应用场景

    • 显式意图用于启动同一应用中的Activity
    • 隐式意图用于启动不同应用中的Activity
      • 如果系统中存在多个Activity的intent-filter同时与你的intent匹配,那么系统会显示一个对话框,列出所有匹配的Activity,由用户选择启动哪一个

    Activity跳转时的数据传递

    • Activity通过Intent启动时,可以通过Intent对象携带数据到目标Activity

      Intent intent = new Intent(this, SecondActivity.class);
      intent.putExtra("maleName", maleName);
      intent.putExtra("femaleName", femaleName);
      startActivity(intent);
      
    • 在目标Activity中取出数据

      Intent intent = getIntent();
      String maleName = intent.getStringExtra("maleName");
      String femaleName = intent.getStringExtra("femaleName");
      

    Activity生命周期

    void onCreate()

    • Activity已经被创建完毕

    void onStart()

    • Activity已经显示在屏幕,但没有得到焦点

    void onResume()

    • Activity得到焦点,可以与用户交互

    void onPause()

    • Activity失去焦点,无法再与用户交互,但依然可见

    void onStop()

    • Activity不可见,进入后台

    void onDestroy()

    • Activity被销毁

    void onRestart()

    • Activity从不可见变成可见时会执行此方法

    使用场景

    • Activity创建时需要初始化资源,销毁时需要释放资源;或者播放器应用,在界面进入后台时需要自动暂停

    完整生命周期(entire lifetime)

    onCreate-->onStart-->onResume-->onPause-->onStop-->onDestory

    可视生命周期(visible lifetime)

    onStart-->onResume-->onPause-->onStop

    前台生命周期(foreground lifetime)

    onResume-->onPause


    Activity的四种启动模式

    每个应用会有一个Activity任务栈,存放已启动的Activity

    Activity的启动模式,修改任务栈的排列情况

    • standard 标准启动模式
    • singleTop 单一顶部模式
      • 如果任务栈的栈顶存在这个要开启的activity,不会重新的创建activity,而是复用已经存在的activity。保证栈顶如果存在,不会重复创建。
      • 应用场景:浏览器的书签
    • singeTask 单一任务栈,在当前任务栈里面只能有一个实例存在

      • 当开启activity的时候,就去检查在任务栈里面是否有实例已经存在,如果有实例存在就复用这个已经存在的activity,并且把这个activity上面的所有的别的activity都清空,复用这个已经存在的activity。保证整个任务栈里面只有一个实例存在
      • 应用场景:浏览器的activity
      • 如果一个activity的创建需要占用大量的系统资源(cpu,内存)一般配置这个activity为singletask的启动模式。webkit内核 c代码
    • singleInstance启动模式非常特殊, activity会运行在自己的任务栈里面,并且这个任务栈里面只有一个实例存在

      • 如果你要保证一个activity在整个手机操作系统里面只有一个实例存在,使用singleInstance
      • 应用场景: 电话拨打界面

    横竖屏切换的生命周期

    默认情况下 ,横竖屏切换, 销毁当前的activity,重新创建一个新的activity

    快捷键ctrl+F11

    在一些特殊的应用程序常见下,比如游戏,不希望横竖屏切换activity被销毁重新创建 需求:禁用掉横竖屏切换的生命周期 1. 横竖屏写死 android:screenOrientation="landscape" android:screenOrientation="portrait"

    1. 让系统的环境 不再去敏感横竖屏的切换。

       android:configChanges="orientation|screenSize|keyboardHidden"
      

    掌握开启activity获取返回值

    从A界面打开B界面, B界面关闭的时候,返回一个数据给A界面

    步骤: 1. 开启activity并且获取返回值

        startActivityForResult(intent, 0);
    
    1. 在新开启的界面里面实现设置数据的逻辑

      Intent data = new Intent();
      data.putExtra("phone", phone);
      //设置一个结果数据,数据会返回给调用者
      setResult(0, data);
      finish();//关闭掉当前的activity,才会返回数据
      
    2. 在开启者activity里面实现方法 onActivityResult(int requestCode, int resultCode, Intent data) 通过data获取返回的数据

    3. 根据请求码和结果码确定业务逻辑


  • 相关阅读:
    VOA 转
    DataTable中动态的赋值 转
    哈希表 转
    利用Hook技术实现键盘监控 转
    sql 里的 order by 和 group by 的区别 转
    DES加密算法 转
    Windows的消息机制 转
    “赢在中国”点评人给80后年轻人的30个忠告 转
    ASCII码对照表 转
    以太网 转
  • 原文地址:https://www.cnblogs.com/wanghang/p/6299678.html
Copyright © 2011-2022 走看看