安卓四大组件之Activity

          一. Activity

          二. Service

          三. ContentProvider

          四. BroadCast Receiver

    

Activity

    官方文档:https://developer.android.google.cn/guide/components/activities

 

生命周期图:


                              

创建第二个Activity

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

    
          
          
    1. <intent-filter>
    2. <action android:name="android.intent.action.MAIN" />
    3. <category android:name="android.intent.category.LAUNCHER" />
    4. </intent-filter>
    5. <application
    6. android:allowBackup= "true"
    7. android:icon= "@drawable/ic_launcher"
    8. android:label= "@string/app_name"
    9. android:theme= "@style/AppTheme" >
    10. <activity
    11. android:name= "com.itheima.createactivity.MainActivity"
    12. android:icon= "@drawable/photo2"
    13. android:label= "主界面" >
    14. <intent-filter>
    15. <action android:name="android.intent.action.MAIN" />
    16. <category android:name="android.intent.category.LAUNCHER" />
    17. </intent-filter>
    18. </activity>
    19. <activity android:name="com.itheima.createactivity.SecondActivity"
    20. android:icon= "@drawable/photo3"
    21. android:label= "第二个界面"
    22. >
    23. <intent-filter>
    24. <action android:name="android.intent.action.MAIN" />
    25. <category android:name="android.intent.category.LAUNCHER" />
    26. </intent-filter>
    27. </activity>

     

  • 一个应用程序可以在桌面创建多个快捷图标。

  • activity的名称、图标可以和应用程序的名称、图标不相同

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

Activity的跳转

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

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

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

显式意图

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

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

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

隐式意图

  • 隐式意图跳转至指定Activity

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

    
          
          
    1. <intent-filter >
    2. <action android:name="com.itheima.second"/>
    3. <data android:scheme="asd" android:mimeType="aa/bb"/>
    4. <category android:name="android.intent.category.DEFAULT"/>
    5. </intent-filter>
    • action 指定动作(可以自定义,可以使用系统自带的)
    • data 指定数据(操作什么内容)
    • category 类别 (默认类别,机顶盒,车载电脑)
  • 隐式意图启动Activity,需要为intent设置以上三个属性,且值必须与该Activity在清单文件中对三个属性的定义匹配
  • intent-filter节点及其子节点都可以同时定义多个,隐式启动时只需与任意一个匹配即可

获取通过setData传递的数据


    
    
  1. //获取启动此Activity的intent对象
  2. Intent intent = getIntent();
  3. Uri uri = intent.getData();

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

  • 显式意图用于启动同一应用中的Activity
  • 隐式意图用于启动不同应用中的Activity

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

    实例代码: 

    
          
          
    1. <intent-filter >
    2. <action android:name="com.itheima.sa2"/>
    3. <data android:scheme="heima2" android:mimeType="text/username"/>
    4. <category android:name="android.intent.category.DEFAULT"/>
    5. </intent-filter>
    6. </activity>
    7. Java文件:
    8. MainActivity. java:
    9. /**
    10. * 跳转至打电话activity
    11. * 跳转至其他应用的activity
    12. * 隐式跳转:通过指定action和data
    13. * @param v
    14. */
    15. public void click1( View v){
    16. Intent intent = new Intent();
    17. //隐式意图
    18. intent. setAction( Intent. ACTION_CALL);
    19. intent. setData( Uri. parse( "tel:110"));
    20. //跳转
    21. startActivity(intent);
    22. }
    23. /**
    24. * 跳转至secondActivity
    25. * 在本应用中跳转
    26. * 显示跳转:直接指定目标Activity的包名和类名
    27. * @param v
    28. */
    29. public void click2( View v){
    30. Intent intent = new Intent();
    31. //cls:直接指定目标Activity的类名
    32. //显示意图
    33. intent. setClass( this, SecondActivity. class);
    34. startActivity(intent);
    35. }
    36. /**
    37. * 显示跳转至拨号器
    38. */
    39. public void click3( View v){
    40. Intent intent = new Intent();
    41. //指定目标Activity的包名和类名
    42. intent. setClassName( "com.android.dialer", "com.android.dialer.DialtactsActivity");
    43. startActivity(intent);
    44. }
    45. /**
    46. * 隐式跳转至拨号器
    47. */
    48. public void click4( View v){
    49. Intent intent = new Intent();
    50. //隐式设置拨号器的动作
    51. intent. setAction( Intent. ACTION_DIAL);
    52. startActivity(intent);
    53. }
    54. /**
    55. * 隐式跳转至secondActivity
    56. * @param v
    57. */
    58. public void click5( View v){
    59. Intent intent = new Intent();
    60. intent. setAction( "com.itheima.sa2");
    61. //intent.setData(Uri.parse("heima2:qwe"));
    62. //intent.setType("text/username");
    63. //intent.setData(Uri.parse("heima2:qwe123"));
    64. intent. setDataAndType( Uri. parse( "heima2:qwe123"), "text/username");
    65. //系统会自动添加默认的category
    66. intent. addCategory( Intent. CATEGORY_DEFAULT);
    67. startActivity(intent);
    68. }
    69. /**
    70. * 显式跳转至浏览器
    71. */
    72. public void click6( View v){
    73. Intent intent = new Intent();
    74. intent. setClassName( "com.android.browser", "com.android.browser.BrowserActivity");
    75. startActivity(intent);
    76. }
    77. /**
    78. * 隐式跳转至浏览器
    79. * @param v
    80. */
    81. public void click7( View v){
    82. Intent intent = new Intent();
    83. intent. setAction( Intent. ACTION_VIEW);
    84. intent. setData( Uri. parse( "http://www.baidu.com"));
    85. startActivity(intent);
    86. }
    87. SecondActivity. java
    88. 接收 MainActivity传递过来的数据:
    89. Intent intent = getIntent();
    90. Uri uri = intent. getData();
    91. System. out. println(uri. toString());
  • 清单文件: 

    


    
    
  1. <activity android:name=".SecondActivity">
  2. <intent-filter > <action android:name="com.itheima.sa"/>
  3. <action android:name="com.itheima.sa3"/>
  4. <data android:scheme="heima"/>
  5. <data android:scheme="heima3"/>
  6. <category android:name="android.intent.category.DEFAULT"/>
  7. </intent-filter>

Activity跳转时的数据传递

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

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

    
          
          
    1. Intent intent = getIntent();
    2. String maleName = intent.getStringExtra( "maleName");
    3. String femaleName = intent.getStringExtra( "femaleName");
  • 通过Bundle传递数据

    
          
          
    1. public void click (View v){
    2. Intent intent = new Intent( this, SecondActivity.class);
    3. //把数据封装至intent对象中
    4. //intent.putExtra("malename", "李志");
    5. //intent.putExtra("femalename", "芙蓉姐姐");
    6. //把数据封装至bundle对象中
    7. Bundle bundle = new Bundle();
    8. bundle.putString( "malename", "李志");
    9. bundle.putString( "femalename", "芙蓉姐姐");
    10. //把bundle对象封装至intent对象中
    11. intent.putExtras(bundle);
    12. startActivity(intent);
    13. }
    14. 接收数据:
    15. Intent intent = getIntent();
    16. //String maleName = intent.getStringExtra("malename");
    17. //String feMaleName = intent.getStringExtra("femalename");
    18. Bundle bundle = intent.getExtras();
    19. String maleName = bundle.getString( "malename");
    20. String feMaleName = bundle.getString( "femalename");

掌握开启activity获取返回值

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

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

    startActivityForResult(intent, 0);

    
    
  1. 在新开启的界面里面实现设置数据的逻辑

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

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

Activity获取返回值


    
    
  1. public void click (View c){
  2. //跳转至选择联系人Activity
  3. Intent intent = new Intent( this, ContactActivity.class);
  4. //用这个api启动的Activity,在销毁时,系统会回调onActivityResult
  5. startActivityForResult(intent, 10);
  6. }
  7. public void click2 (View v){
  8. //跳转至选择快捷回复的Activity
  9. Intent intent = new Intent( this, CallbackActivity.class);
  10. startActivityForResult(intent, 20);
  11. }
  12. //如果有Activity在销毁时返回了数据,那么就会调用此方法来接收数据
  13. //requestCode:用来区分数据来自于哪一个Activity
  14. //resultCode:用来区分返回的数据是什么类型的
  15. @Override
  16. protected void onActivityResult (int requestCode, int resultCode, Intent data) {
  17. // TODO Auto-generated method stub
  18. super.onActivityResult(requestCode, resultCode, data);
  19. String name = data.getStringExtra( "name");
  20. if(requestCode == 10){
  21. EditText et = (EditText)findViewById(R.id.et);
  22. et.setText(name);
  23. }
  24. else if(requestCode == 20){
  25. EditText et_content = (EditText)findViewById(R.id.et_content);
  26. et_content.setText(name);
  27. }
  28. }
  29. //Activity返回时传递数据,也是通过意图对象
  30. Intent data = new Intent();
  31. //把要传递的数据封装至意图对象中
  32. data.putExtra( "name", objects[position]);
  33. //当前Activity销毁时,data这个意图就会传递给启动当前Activity的那个Activity
  34. setResult( 1, data);
  35. //销毁当前Activity
  36. finish();

Activity生命周期

void onCreate()

  • Activity已经被创建完毕

void onStart()

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

void onResume()

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

void onPause()

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

void onStop()

  • Activity不可见,进入后台

void onDestroy()

  • Activity被销毁

void onRestart()

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

前台Activity(有焦点)当执行finish()后,会一次执行onpause-->onStop-->onDestroy

启动应用到获取焦点:oncreat-->onstart-->onresume

前台Activity(有焦点)点击home键:onpause-->onstop,再次启动onrestart-->onstart-->onresume

 

使用场景

  • 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"
    
          
          
  2. 设置当前Activity的方向,使用代码控制横竖屏

    setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
          
          

 

常用方法: 

  • 删除title,在onCreat方法调用 requestWindowFeature(Window.FEATURENOTITLE);

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值