android四大组件之Activity(一)

本文深入解析Android中的Activity组件,包括其基本概念、常见应用场景如拨打电话、发送短信等,以及Activity的生命周期和回调方法。同时,文章还介绍了多个Activity间的跳转方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本节引言:

本节开始讲解Android的四大组件之一的Activity(活动),先来看下官方对于Activity的介绍: PS:官网文档:Activity

介绍如下:  大概意思:

Activity是一个应用程序的组件,他在屏幕上提供了一个区域,允许用户在上面做一些交互性的操作, 比如打电话,照相,发送邮件,或者显示一个地图!Activity可以理解成一个绘制用户界面的窗口, 而这个窗口可以填满整个屏幕,也可能比屏幕小或者浮动在其他窗口的上方!

从上面这段话,我们可以得到以下信息:

1. Activity用于显示用户界面 

2.用户通过Activity交互完成相关操作 

3. 一个App允许有多个Activity

好了,大概的引言就介绍到这里,想深入了解可以继续看API,开始本节内容

系统给我们提供的常见的Activity:

//1.拨打电话
// 给移动客服10086拨打电话
Uri uri = Uri.parse("tel:10086");
Intent intent = new Intent(Intent.ACTION_DIAL, uri);
startActivity(intent);
运行将直接打开拨打电话的界面,并且能够将号码拨上。

2、开始发送短信。

        Uri uri = Uri.parse("smsto:10086"); // Uri表示的是通用的资源标识符,需要操作的数据
        Intent intent = new Intent(Intent.ACTION_SENDTO, uri);// Intend是不同组件之间通讯的纽带
        intent.putExtra("sms_body", "hello it is me"); // 添加额外的参数
        startActivity(intent);
打开短信界面,并且能够将内容填好,并且将收件人也填好。

3、发送彩信,这个没有成功,因为他提示需要登录谷歌浏览器才能成功,也不知道是怎么回事,后面有需要再去研究。

//3.发送彩信(相当于发送带附件的短信)
Intent intent = new Intent(Intent.ACTION_SEND);
intent.putExtra("sms_body", "Hello");
Uri uri = Uri.parse("content://media/external/images/media/23");
intent.putExtra(Intent.EXTRA_STREAM, uri);
intent.setType("image/png");
startActivity(intent);
4、打开百度浏览器

// 打开百度主页
Uri uri = Uri.parse("http://www.baidu.com");
Intent intent  = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);
后面的都没有一一去尝试了,暂时保留在这个地方。
//5.发送电子邮件:(阉割了Google服务的没戏!!!!)
// 给someone@domain.com发邮件
Uri uri = Uri.parse("mailto:someone@domain.com");
Intent intent = new Intent(Intent.ACTION_SENDTO, uri);
startActivity(intent);
// 给someone@domain.com发邮件发送内容为“Hello”的邮件
Intent intent = new Intent(Intent.ACTION_SEND);
intent.putExtra(Intent.EXTRA_EMAIL, "someone@domain.com");
intent.putExtra(Intent.EXTRA_SUBJECT, "Subject");
intent.putExtra(Intent.EXTRA_TEXT, "Hello");
intent.setType("text/plain");
startActivity(intent);
// 给多人发邮件
Intent intent=new Intent(Intent.ACTION_SEND);
String[] tos = {"1@abc.com", "2@abc.com"}; // 收件人
String[] ccs = {"3@abc.com", "4@abc.com"}; // 抄送
String[] bccs = {"5@abc.com", "6@abc.com"}; // 密送
intent.putExtra(Intent.EXTRA_EMAIL, tos);
intent.putExtra(Intent.EXTRA_CC, ccs);
intent.putExtra(Intent.EXTRA_BCC, bccs);
intent.putExtra(Intent.EXTRA_SUBJECT, "Subject");
intent.putExtra(Intent.EXTRA_TEXT, "Hello");
intent.setType("message/rfc822");
startActivity(intent);

//6.显示地图:
// 打开Google地图中国北京位置(北纬39.9,东经116.3)
Uri uri = Uri.parse("geo:39.9,116.3");
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);

//7.路径规划
// 路径规划:从北京某地(北纬39.9,东经116.3)到上海某地(北纬31.2,东经121.4)
Uri uri = Uri.parse("http://maps.google.com/maps?f=d&saddr=39.9 116.3&daddr=31.2 121.4");
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);

//8.多媒体播放:
Intent intent = new Intent(Intent.ACTION_VIEW);
Uri uri = Uri.parse("file:///sdcard/foo.mp3");
intent.setDataAndType(uri, "audio/mp3");
startActivity(intent);

//获取SD卡下所有音频文件,然后播放第一首=-= 
Uri uri = Uri.withAppendedPath(MediaStore.Audio.Media.INTERNAL_CONTENT_URI, "1");
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);

//9.打开摄像头拍照:
// 打开拍照程序
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); 
startActivityForResult(intent, 0);
// 取出照片数据
Bundle extras = intent.getExtras(); 
Bitmap bitmap = (Bitmap) extras.get("data");

//另一种:
//调用系统相机应用程序,并存储拍下来的照片
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); 
time = Calendar.getInstance().getTimeInMillis();
intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.fromFile(new File(Environment
.getExternalStorageDirectory().getAbsolutePath()+"/tucue", time + ".jpg")));
startActivityForResult(intent, ACTIVITY_GET_CAMERA_IMAGE);

//10.获取并剪切图片
// 获取并剪切图片
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
intent.setType("image/*");
intent.putExtra("crop", "true"); // 开启剪切
intent.putExtra("aspectX", 1); // 剪切的宽高比为1:2
intent.putExtra("aspectY", 2);
intent.putExtra("outputX", 20); // 保存图片的宽和高
intent.putExtra("outputY", 40); 
intent.putExtra("output", Uri.fromFile(new File("/mnt/sdcard/temp"))); // 保存路径
intent.putExtra("outputFormat", "JPEG");// 返回格式
startActivityForResult(intent, 0);
// 剪切特定图片
Intent intent = new Intent("com.android.camera.action.CROP"); 
intent.setClassName("com.android.camera", "com.android.camera.CropImage"); 
intent.setData(Uri.fromFile(new File("/mnt/sdcard/temp"))); 
intent.putExtra("outputX", 1); // 剪切的宽高比为1:2
intent.putExtra("outputY", 2);
intent.putExtra("aspectX", 20); // 保存图片的宽和高
intent.putExtra("aspectY", 40);
intent.putExtra("scale", true);
intent.putExtra("noFaceDetection", true); 
intent.putExtra("output", Uri.parse("file:///mnt/sdcard/temp")); 
startActivityForResult(intent, 0);

//11.打开Google Market 
// 打开Google Market直接进入该程序的详细页面
Uri uri = Uri.parse("market://details?id=" + "com.demo.app");
Intent intent = new Intent(Intent.ACTION_VIEW, uri);
startActivity(intent);

//12.进入手机设置界面:
// 进入无线网络设置界面(其它可以举一反三)  
Intent intent = new Intent(android.provider.Settings.ACTION_WIRELESS_SETTINGS);  
startActivityForResult(intent, 0);

//13.安装apk:
Uri installUri = Uri.fromParts("package", "xxx", null);   
returnIt = new Intent(Intent.ACTION_PACKAGE_ADDED, installUri);

//14.卸载apk:
Uri uri = Uri.fromParts("package", strPackageName, null);      
Intent it = new Intent(Intent.ACTION_DELETE, uri);      
startActivity(it); 

//15.发送附件:
Intent it = new Intent(Intent.ACTION_SEND);      
it.putExtra(Intent.EXTRA_SUBJECT, "The email subject text");      
it.putExtra(Intent.EXTRA_STREAM, "file:///sdcard/eoe.mp3");      
sendIntent.setType("audio/mp3");      
startActivity(Intent.createChooser(it, "Choose Email Client"));

//16.进入联系人页面:
Intent intent = new Intent();
intent.setAction(Intent.ACTION_VIEW);
intent.setData(People.CONTENT_URI);
startActivity(intent);

//17.查看指定联系人:
Uri personUri = ContentUris.withAppendedId(People.CONTENT_URI, info.id);//info.id联系人ID
Intent intent = new Intent();
intent.setAction(Intent.ACTION_VIEW);
intent.setData(personUri);
startActivity(intent);

Activity的生命周期和回调方法

之前给出的那个教程感觉明显比较笼统,光是去看还是比较吃力的,找了刘浩导师的书来看看还是讲解得比较清楚明白的。

    protected void onCreate(Bundle savedInstanceState) {//重写该方法
        System.out.println("onCreate函数被重写");
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    protected void onStart(){
        super.onStart();
        System.out.println("进入了onstart函数");
    }
    protected void onResume(){
        super.onResume();
        System.out.println("进入了onResume函数");
    }
实际上就是一个activity从启动到处于活动状态。此时该activity位于栈顶

/System.out: onCreate函数被重写
/com.goodix.myapplication I/System.out: 进入了onstart函数

/com.goodix.myapplication I/System.out: 进入了onResume函数

具体的流程如下图所示:



然后再来看看activity的销毁过程

    protected void onPause(){
        super.onPause();
        System.out.println("进入了onPause函数");
    }
    protected void onStop(){
        super.onStop();
        System.out.println("进入了onStop函数");//此时activity不再在栈顶,但是尚未从栈里面被销毁
    }
    protected void onDestroy(){
        super.onDestroy();
        System.out.println("进入了onDestory函数");
    }

实际上就是一个Activity从暂停到销毁的过程,但是这属于是系统的函数,我们不能控制,我们能调用的就只是finish()函数,该函数会执行上面三个函数。

    public void close_button(View view){
        // 下面这三个函数直接调用是不会生效的
        /*onPause();
        onStop();
        onDestroy();*/
        finish();
        return;
    }

还有就是我们点击back键的时候实际上是执行的是finish()也就是说会执行pause、stop、以及destory函数。

具体的流程如下图所示:


当我们执行home键值的时候,实际上执行的pause--->stop

通过app_selsect键值选中的时候,实际上执行了reStart函数,继续开始start---->resume

包括我们点击app_selsect键值的时候也是和home键值是一样的。

具体的走的就是Activity再次回到前台的路线。

具体流程如下图所示:


Activity销毁过程中的几个状态:

pause状态:

pause状态:activity仍然可见,只是失去了焦点,依然与窗口管理器相互关联,窗口管理器负责管理他的内部状态,但是由于失去焦点,所以无法与用户进行交互,在特殊情况下,系统会kill掉处于pause状态的Activity,来为活动状态的Activity提供资源。

stop状态:activity不可见,且失去焦点,无法和用户进行交互,但是系统仍然保存着他的状态和信息,可以通过restart来恢复。

destory状态:这个时候就是一切都结束了,应用程序也结束了,但是appselect函数可以找到以前的程序(这个也是一个奇怪的问题)。


多个activity之间的跳转
1、第一个activity--->oncreat----->onstart----->onresume------->onpause
2、调用startActivity创建另外一个activity
3、第二个activity--->oncreate---->onstart----->onresume
4、第一个activity执行onstop
新建的activity一定需要在mainfest.xml中申明,且申明是和前面一个activity平级的。否则无法跳转
1、首先是创建一个class来继承activity类
public class my_activity extends Activity{
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.my_activity);// 一定需要的是这个oncreat函数呢!
        System.out.println("creat第二个activity");
    }
}
和mainactivity一致,onstart等函数也可以被重写。
2、创建和my_activity对应的xml视图两个名称一致,并在其中放一个按钮
    <Button
        android:layout_height="wrap_content"
        android:layout_width="wrap_content"
        android:layout_alignParentTop ="true"
        android:layout_marginTop="178dp"
        android:layout_centerHorizontal="true"
        android:text="第二个activity"
        />
3、在mainfest.xml中添加我们的activity
        <activity android:name=".MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="my_activity"/>
4、在mainactivity中启动另外一个activity
    public void close_button(View view){
        // 下面这三个函数直接调用是不会生效的
        Intent intent = new Intent();
        intent.setClass(MainActivity.this,my_activity.class);
        startActivity(intent);
        return;
    }
流程大致如下:


当我在第二个activity里面设置一个按钮,执行finish函数的时候会怎么样呢!销毁过程如下:
第二个activity-------->onpause
第一个activity------>onrestart------->onstart------->onresume
第二个activity------->onstop----->ondestory

如果是直接在第二个activity的按钮里面执行跳转到第一个activity的操作,则最后不会执行destory
第二个activity-------->onpause
第一个activity------>onrestart------->onstart------->onresume
第二个activity------->onstop


完整的流程如下所示:

注意事项:

系统会为了给当前活动的窗口提供足够的资源,所以处于pause阶段的activity可能被kill掉,不一定会继续执行onstop函数

综上所述,需要在onpause函数的时候将所需要保存的数据保存起来。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值