安卓基础干货(六):安卓Activity的学习

AndroidManifest文件中的几个细节

结论:

1、一个应用程序可以创建多个桌面图标

2、创建快捷图标的方法:

<intent-filter>
    //应用程序的入口
    <action android:name="android.intent.action.MAIN" />
    //启动器
    <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>

3、activity的label标签的值就它的界面的标题

4、activity的label标签的值就它的桌面快捷图标的名称

5、application中的label标签和activity中的label标签不是一个概念,application中的label表示应用程序的名称,activity中的label标签表示的是它的界面的名称。

action:动作 可以自定义,可以使用系统定义
category:类型
android.intent.category.LAUNCHER 启动器,DEFAULT 默认类型,一般都是使用这个默认类型,
android.intent.category.CAR_DOCK、
android.intent.category.CAR_MODE 车载电脑使用的模式,
android.intent.category.TV

意图设置动作激活新的界面(重点)

Intent 意图:做一件事情的想法。

吃饭,打人,喝茶

动作:action

数据:data

intent的作用:激活组件和携带参数。

跳转的步骤:

//创建一个意图对象
Intent intent = new Intent();
//目标activity在配置文件配置的action的值
intent.setAction("android.intent.action.SECONDSHOW");
//使用目标activity在配置文件配置的data的scheme
intent.setData(Uri.parse("itheima://sdfdslkjk"));

//使用目标activity在配置文件配置的data的category
intent.addCategory("android.intent.category.DEFAULT");

//开启一个activity,跳转到另一个activity的界面上
startActivity(intent);

在第二activity中得到第一个activity传过来的intent:

Intent intent = this.getIntent();
Uri uri = intent.getData();

意图设计的目的

  • 意图设计的目的:解耦,实现应用程序的高内聚、低耦合。保证应用程序之间能够相互独立运行,又能彼此相互调用。
  • 保证自己写代码能够重复使用。
  • 架构师:保证项目 多快好省的把项目做完。

隐式意图和显式意图(重点)

  • 隐式意图:开启activity的时候不需要直接指定activity的名称,通过指定一组动作和数据,让系统来找到这个特定的activity。

应用场景:

1、让外部应用程序开启自己应用程序里面的activity;

2、开启外部应用程序的activity;

代码:

//创建一个意图对象
Intent intent = new Intent();
//目标activity在配置文件配置的action的值
intent.setAction("android.intent.action.SECONDSHOW");
//使用目标activity在配置文件配置的data的scheme
intent.setData(Uri.parse("itheima://game=天天酷跑"));  
intent.addCategory("android.intent.category.DEFAULT");

//开启一个activity,跳转到另一个activity的界面上
startActivity(intent);
  • 显示意图:开启activity的时候直接指定activity的名称;

应用场景:应用程序内部调用。

代码:

Intent intent = new Intent(this,SecondActivity.class);
//封装数据
//intent.putExtra("name", "itheima");
//intent.putExtra("age", 6);
Bundle b = new Bundle();
b.putString("name", "itheima");
b.putInt("age", 6);
intent.putExtras(b);
startActivity(intent);

意图传递数据(重点)

可以数据类型:

1、8大基本数据类型、数组;

2、Bundle类似于map的数据结构;

3、Parcelable 序列化到内存;

4、Serializable 序列化到文件;

代码:

使用显示意图:

Intent intent = new Intent(this,SecondActivity.class);
//封装数据
//intent.putExtra("name", "itheima");
//intent.putExtra("age", 6);
Bundle b = new Bundle();
b.putString("name", "itheima");
b.putInt("age", 6);
intent.putExtras(b);
startActivity(intent);

使用隐式意图:

//创建一个意图对象
Intent intent = new Intent();

intent.setAction(Intent.action.view);
intent.setData(Uri.parse("tel://"+123);  
intent.addCategory("android.intent.category.DEFAULT");

//开启一个activity,跳转到另一个activity的界面上
startActivity(intent);

开启activity获取返回值的步骤(重点)

步骤:

1、在开启activity时调用
    //开启一个activity并等待返回结果
    startActivityForResult(intent, 200);
2、在目标activity中设置返回的数据
    Intent intent = new Intent();
    intent.putExtra("username", username);
    //设置界面关闭时返回数据
    setResult(0, intent);
3、关闭目标activity
    //自动关闭界面
    finish();
4、重写onActivityResult方法接收返回的数据:

代码:

/**
* requestCode 开启activity时设置的请求吗
* resultCode 在目标activity中设置的结果码
* data 第二个界面返回的数据
*/
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    //      
    //  if(resultCode==0){
    //      String username = data.getStringExtra("username");
    //          
    //      Toast.makeText(this, username, 0).show();
    //      }
    //      
    // if(resultCode==1){
    //      String thirdInfo = data.getStringExtra("thirdInfo");
    //          
    //      Toast.makeText(this, thirdInfo, 0).show();
    //      }
    //      
    //使用requestCode,resultCode来判断是哪个业务逻辑界面返回的数据

    if(requestCode==200){
        String username = data.getStringExtra("username");

        Toast.makeText(this, username, 0).show();
    }

    if(requestCode==300){
        String thirdInfo = data.getStringExtra("thirdInfo");

        Toast.makeText(this, thirdInfo, 0).show();
    }           
}

请求码和结果码的作用(重点)

  • 使用requestCode,resultCode来判断是哪个业务逻辑界面返回的数据.

代码:

/**
 * requestCode 开启activity时设置的请求吗
 * resultCode 在目标activity中设置的结果码
 * data 第二个界面返回的数据
 */
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    //      
    //      if(resultCode==0){
    //          String username = data.getStringExtra("username");
    //          
    //          Toast.makeText(this, username, 0).show();
    //      }
    //      
    //      if(resultCode==1){
    //          String thirdInfo = data.getStringExtra("thirdInfo");
    //          
    //          Toast.makeText(this, thirdInfo, 0).show();
    //      }
    //      
    //使用requestCode,resultCode来判断是哪个业务逻辑界面返回的数据
    if(requestCode==200){
        String username = data.getStringExtra("username");

        Toast.makeText(this, username, 0).show();
    }

    if(requestCode==300){
        String thirdInfo = data.getStringExtra("thirdInfo");

        Toast.makeText(this, thirdInfo, 0).show();
    }
}

activity的生命周期(重点)

什么是生命周期:

被生下来、幼年、童年、青年、中年、老年

从被创建到销毁经历几个阶段,每个阶段就表示一个方法,这些方法就是生命周期的回调。

生命周期:

onCreate:在activity被创建的时候调用这个方法,初始化界面。
onStart:当界面可见的时候调用
onResume 按钮可以被点击的时候 

onPause 按钮失去焦点的时候:

onStop 界面不可见的时候调用:

onDestroy 销毁activity实例,做一些扫尾工作

1、activity创建时调用onCreate、onStart、onResume;
2、关闭activity时调用:onPause、onStop、onDestroy;
3、最小化activity时调用:onPause、onStop;
4、最小后重新打时调用:onRestart、onStart、onResume;

读文档查看activity的生命周期

横竖屏切换的生命周期(重点)

禁用横竖自适应的方式:

1、screenOrientation:

landspace横屏、 portrait竖屏、
横竖屏切换:先销毁当前的activity实例,再创建一个新activity实例。

2、在activity中设置

android:configChanges="orientation|keyboardHidden|screenSize"

任务栈的概念

队列:

先进先出

栈:

先进后出

任务:

打开一个activity界面;

任务栈:

设计任务栈的目的:用来维护用户的体验,记录打开界面和关闭界面的信息。

1、打开一个activity界面表示在栈中存放了一个任务,关闭一个界面表示清除了一个任务;
2、栈里面的任务清除完毕后,应用程序退出;

singletop启动模式

singletop 单一顶部模式 在activity的配置文件中设置

android:launchMode="singleTop"

如果任务栈的栈顶存在这个要开启的activity,不会重新的创建activity,而是复用已经存在的activity。保证栈顶如果存在,不会重复创建。

应用场景:浏览器的书签

singletask和singleinstance启动模式

singetask

单一任务栈,在当前任务栈里面只能有一个实例存在

当开启activity的时候,就去检查在任务栈里面是否有实例已经存在,如果有实例存在就复用这个已经存在的activity,并且把这个activity上面的所有的别的activity都清空,复用这个已经存在的activity。保证整个任务栈里面只有一个实例存在

应用场景:浏览器的activity

singletask

如果一个activity的创建需要占用大量的系统资源(cpu,内存)一般配置这个activity为singletask的启动模式。

webkit内核 c代码

singleInstance启动模式非常特殊, activity会运行在自己的任务栈里面,并且这个任务栈里面只有一个实例存在

如果你要保证一个activity在整个手机操作系统里面只有一个实例存在,使用singleInstance

应用场景: 来电页面 有道词典

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏北京马哥教育

Vim自动补全神器:YouCompleteMe

第一次听说这个插件还是在偶然的情况下看到别人的博客,听说了这个插件的大名。本来打算在实训期间来完成安装的,无奈网实在不给力,也就拖到了回家的时候。在开始准备工作...

7416
来自专栏前端小叙

daterangepicker日历插件使用参数注意问题

显示具体时间时分秒: timePicker设置为true,//有些资料写的pickerTime不太对 重点大坑:修改时间默认展示格式,把fomat写在local...

3275
来自专栏小樱的经验随笔

【批处理学习笔记】第十四课:常用DOS命令(4)

系统管理 at 安排在特定日期和时间运行命令和程序 shutdown立即或定时关机或重启 taskkill结束进程(WinXPHome版中无该命令) taskl...

2513
来自专栏xingoo, 一个梦想做发明家的程序员

关于jboss的线程问题+java.lang.outofmemoryError

    近日来,用Jmeter做压力测试。发现,每台客户机使用800个线程组压力倍增。昨天的测试,到了今天下午都没有跑完。 仔细观察了下Jboss的错误日志,发...

2178
来自专栏向治洪

android 线程那点事

在操作系统中,线程是操作系统调度的最小单元,同时线程又是一种受限的系统资源,即线程不可能无限制的产生,并且线程的创建和销毁都会有相应的开销,当系统中存在大量的线...

2635
来自专栏安恒网络空间安全讲武堂

赛前福利①最新2018HITB国际赛writeup

FIRST 距离“西湖论剑杯”全国大学生网络空间安全技能大赛只有10天啦! 要拿大奖、赢offer,那必须得来点赛前练习定定心啊~这不,讲武堂就拿到了2018H...

4645
来自专栏GopherCoder

『No18: Go 实现世界杯后台管理系统』

趁着周末更新一期,上一期讲到 如何快速熟悉一个项目, 文章的最后讲到,最好的方法是借用相同的技术栈重新实现一个项目。

1731
来自专栏我就是马云飞

RxJava2 实战知识梳理(3) - 优化搜索联想功能

应用场景 几乎每个应用程序都提供了搜索功能,某些应用还提供了搜索联想。对于一个搜索联想功能,最基本的实现流程为:客户端通过EditText的addTextCha...

2657
来自专栏刘望舒

Android包管理机制(一)PackageInstaller的初始化

3023
来自专栏Kubernetes

原 荐 深度解析Kubernetes Pod

Author: xidianwangtao@gmail.com PDB的应用场景 大概在Kubernetes 1.4新增了PodDisruptionBudge...

1.2K13

扫码关注云+社区

领取腾讯云代金券