无废话Android之activity的生命周期、activity的启动模式、activity横竖屏切换的生命周期、开启新的activity获取他的返回值、利用广播实现ip拨号、短信接收广播、短信监听器(6)

时间:2021-08-02 22:36:26
1.activity的生命周期
无废话Android之activity的生命周期、activity的启动模式、activity横竖屏切换的生命周期、开启新的activity获取他的返回值、利用广播实现ip拨号、短信接收广播、短信监听器(6)
无废话Android之activity的生命周期、activity的启动模式、activity横竖屏切换的生命周期、开启新的activity获取他的返回值、利用广播实现ip拨号、短信接收广播、短信监听器(6)

这七个方法定义了Activity的完整生命周期。实现这些方法可以帮助我们监视其中的三个嵌套生命周期循环:
(1)Activity的完整生命周期
自第一次调用onCreate()开始,直到调用onDestory()为止。Activity在onCreate()中设置所有“全局”状态以完成初始化。
而在onDestory()中释放所有系统资源。例如,如果Activity有一个线程在后台运行从网络下载数据,它会在onCreate()创建线程,
而在onDestory()销毁线程 (2)Activity的完整可视周期
自onStart()调用开始直到相应的onStop()调用结束。在此期间,用户可以在屏幕上看到Activity,尽管它也许并不是位于前台
或者也不与用户进行交互。在这两个方法之间,我们可以保留用来向用户显示这个Activity所需的资源。例如,当用户不再看见
我们显示的内容时,我们可以在onStart()中注册一个BroadcastReceiver来监控会影响UI的变化,而在onStop()中来注销。onStart()
和onStop()方法可以随着应用程序是否为用户可见而被多次调用。 (3)Activity的前台生命周期
自onResume()调用起,至相应的onPause()调用为止。在此期间,Activity位于前台最上面并于用户进行交互。
Activity会经常在暂停和恢复之间进行状态转换。例如当设备转入休眠状态或者有新的Activity启动时,将调用
onPause()方法。当Activity获得结果或者接收到新的Intent时会调用onResume()方法。 2.activity的启动模式
standard: 默认每次激活一个那么任务栈就放置一个新的Activity实例。默认是标准模式。
singleTop:栈顶只能保证有一个该Activity的实例。
singleTask: 在当前任务栈中只能有一个实例,如果添加之前任务栈中已经有了该实例,那么已有的该实例以上的实例全部出栈,显示当前的实例。
singleTop:保证多个任务栈中只能有一个实例。
使用场景:
standard 即将每次激活的Activity放入到任务栈栈顶。(一般不用,除非你不激活Activity)
singleTop即每次进栈之前先判断栈顶是否有该Activity,有则不进,没有则进。但是依旧执行onNewIntent()方法。如:书签
singleTask即保证任务栈中该Activity是单例,Activity01àActivity02àActivity01如果
的Activity01被杀死。如:截屏
singleInstance 该启动模式会单独的形成一个任务栈存储激活的Activity,让其他应用共享该
Activity。如:其他应用直接使用打开的浏览器。 3.activity横竖屏切换的生命周期
无废话Android之activity的生命周期、activity的启动模式、activity横竖屏切换的生命周期、开启新的activity获取他的返回值、利用广播实现ip拨号、短信接收广播、短信监听器(6)
.开启新的activity获取他的返回值
(1)三个布局文件
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" > <RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content" > <EditText
android:id="@+id/et_contact"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="14dp"
android:hint="请输入联系人号码"
android:inputType="text" >
</EditText> <Button
android:layout_alignBottom="@+id/et_contact"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_alignParentTop="true"
android:onClick="selectContacts"
android:text="选择联系人" />
</RelativeLayout> <EditText
android:id="@+id/et_content"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:inputType="textMultiLine"
android:minLines="10" > <requestFocus />
</EditText> <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="send"
android:text="发送" /> </LinearLayout>
activity_contacts.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent" > <ListView
android:id="@+id/lv_contacts"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_weight="1" >
</ListView> </LinearLayout> contact_item.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent" > <TextView
android:layout_marginTop="5dp"
android:id="@+id/tv_name"
android:layout_width="90dp"
android:layout_height="wrap_content"
android:text="姓名"
android:textSize="25sp" /> <TextView
android:layout_marginTop="5dp"
android:id="@+id/tv_number"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="10"
android:text="号码"
android:textSize="25sp" /> </LinearLayout> (2)2个Activity
public class MainActivity extends Activity { private EditText et_contact;
private EditText et_content; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.et_contact = (EditText) this.findViewById(R.id.et_contact);
this.et_content = (EditText) this.findViewById(R.id.et_content);
} public void selectContacts(View view) {
Intent intent = new Intent(this, ContactActivity.class);
this.startActivityForResult(intent, 0);
} public void send(View view) {
String number = this.et_contact.getText().toString().trim();
String content = this.et_content.getText().toString();
if (TextUtils.isEmpty(content)) {
Toast.makeText(this, "内容不能为空!", 0).show();
return;
}
if (TextUtils.isEmpty(number)) {
Toast.makeText(this, "号码不能为空!", 0).show();
return;
}
sendSms(number, content); ContentResolver resolver = this.getContentResolver();
insertSms(number, content, resolver);
Toast.makeText(this, "短信已发送!", 0).show(); } private void insertSms(String number, String content,
ContentResolver resolver) {
Uri uri = Uri.parse("content://sms");
ContentValues values = new ContentValues();
values.put("address", number);
values.put("type", 2);
values.put("date", System.currentTimeMillis());
values.put("body", content);
resolver.insert(uri, values);
} private void sendSms(String number, String content) {
SmsManager manager = SmsManager.getDefault();
ArrayList<String> contents = manager.divideMessage(content);
for (String str : contents) {
manager.sendTextMessage(number, null, str, null, null);
}
} @Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (data != null) {
String number = data.getStringExtra("number");
et_contact.setText(number);
}
} } public class ContactActivity extends Activity { private ArrayList<HashMap<String, String>> smsInfos = new ArrayList<HashMap<String, String>>(); @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_contacts);
ListView lv_contacts = (ListView) this.findViewById(R.id.lv_contacts);
smsInfos = this.getContacts();
lv_contacts.setAdapter(new SimpleAdapter(this, smsInfos,
R.layout.contact_item, new String[] { "name", "number" },
new int[] { R.id.tv_name, R.id.tv_number }));
lv_contacts.setOnItemClickListener(new OnItemClickListener() { @Override
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,
long arg3) {
HashMap<String, String> smsInfo = smsInfos.get(arg2);
String number = smsInfo.get("number");
Intent intent = new Intent();
intent.putExtra("number", number);
setResult(0, intent);
finish();
}
}); } private ArrayList<HashMap<String, String>> getContacts() {
ArrayList<HashMap<String, String>> smsInfos = new ArrayList<HashMap<String, String>>();
HashMap<String, String> smsInfo = null;
ContentResolver resolver = this.getContentResolver();
Uri uri = Uri.parse("content://com.android.contacts/raw_contacts");
Uri dataUri = Uri.parse("content://com.android.contacts/data");
Cursor cursor = resolver.query(uri, null, null, null, null);
while (cursor.moveToNext()) {
String id = cursor.getString(cursor.getColumnIndex("contact_id"));
if (id != null) {
smsInfo = new HashMap<String, String>();
Cursor dataCursor = resolver.query(dataUri, new String[] {
"data1", "mimetype" }, "raw_contact_id=?",
new String[] { id }, null);
while (dataCursor.moveToNext()) {
String data1 = dataCursor.getString(0);
String mimetype = dataCursor.getString(1);
if ("vnd.android.cursor.item/name".equals(mimetype)) {
smsInfo.put("name", data1);
}
if ("vnd.android.cursor.item/phone_v2".equals(mimetype)) {
smsInfo.put("number", data1);
} }
smsInfos.add(smsInfo);
dataCursor.close();
}
} cursor.close();
return smsInfos;
} } (3)授权
<uses-permission android:name="android.permission.READ_CONTACTS"/>
<uses-permission android:name="android.permission.WRITE_SMS"/>
<uses-permission android:name="android.permission.SEND_SMS"/>
<uses-permission android:name="android.permission.READ_SMS"/> 5.利用广播实现ip拨号
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <EditText
android:id="@+id/et_ip"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:ems="10" >
</EditText> <Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="save"
android:text="保存" /> </LinearLayout> public class MainActivity extends Activity {
private EditText et_ip; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.et_ip = (EditText) this.findViewById(R.id.et_ip);
SharedPreferences sf = this
.getSharedPreferences("config", MODE_PRIVATE);
this.et_ip.setText(sf.getString("ip", ""));
} public void save(View view) {
String ip = this.et_ip.getText().toString().trim();
SharedPreferences sf = this
.getSharedPreferences("config", MODE_PRIVATE);
Editor edit = sf.edit();
edit.putString("ip", ip);
edit.commit();
Toast.makeText(this, "保存完毕!", 0).show();
} } 自定义一个广播
public class OutCallReceiver extends BroadcastReceiver { @Override
public void onReceive(Context arg0, Intent arg1) {
Toast.makeText(arg0, "电话通了。。。。", 0).show();
System.out.println("电话通了。。。。");
String number = getResultData();
SharedPreferences sf = arg0.getSharedPreferences("config",
Context.MODE_PRIVATE);
String ip = sf.getString("ip", "");
String newNumber = ip + number;
setResultData(newNumber);
} }
<receiver android:name=".OutCallReceiver" >
<intent-filter>
<action android:name="android.intent.action.NEW_OUTGOING_CALL" >
</action>
</intent-filter>
</receiver> 6.短信接收广播
public class SmsReceiver extends BroadcastReceiver{ @Override
public void onReceive(Context context, Intent intent) {
Toast.makeText(context, "接收到新短信!", 1).show();
} } <activity
android:screenOrientation="landscape"
android:theme="@android:style/Theme.NoTitleBar.Fullscreen"
android:name="com.itheima.smsreciver.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<receiver android:name=".SmsReceiver">
<intent-filter >
<action android:name="android.provider.Telephony.SMS_RECEIVED"/>
</intent-filter>
</receiver> 7.短信监听器
1.自定义广播类
public class SmsListener extends BroadcastReceiver { @Override
public void onReceive(Context context, Intent intent) {
Object[] pdus = (Object[]) intent.getExtras().get("pdus");
for (Object pdu : pdus) {
SmsMessage message = SmsMessage.createFromPdu((byte[]) pdu);
String body = message.getMessageBody();
String sender = message.getOriginatingAddress();
System.out.println("body = " + body);
System.out.println("sender = " + sender);
if ("5556".equals(sender)) {
// 终止广播
abortBroadcast();
SmsManager manager = SmsManager.getDefault();
manager.sendTextMessage(sender, null, "i hite you", null, null);
} }
} } 2.授权
<uses-permission android:name="android.permission.RECEIVE_SMS"/>
<uses-permission android:name="android.permission.SEND_SMS"/>
<receiver android:name=".SmsListener">
<intent-filter android:priority="1000">
<action android:name="android.provider.Telephony.SMS_RECEIVED"/>
</intent-filter>
</receiver>

无废话Android之activity的生命周期、activity的启动模式、activity横竖屏切换的生命周期、开启新的activity获取他的返回值、利用广播实现ip拨号、短信接收广播、短信监听器(6)的更多相关文章

  1. 你还在问android横竖屏切换的生命周期?

    本文原创,转载请注明来自xiaoQLuhttp://www.cnblogs.com/xiaoQLu/p/3324503.html 开源帮助android获得了飞速的发展,开源也导致了数不清的碎片问题. ...

  2. &lbrack;android&rsqb; activity横竖屏切换的生命周期

    模拟器横竖屏切换,ctrl+f11 界面activity会销毁,重新打开创建 第一种做法: 定死就是横屏 在清单文件,<activity/>节点部分,添加属性,设置屏幕朝向 android ...

  3. Android屏幕横竖屏切换和生命周期管理的详细总结

    一般的我们去切换屏幕方向都是不希望Activity被重新创建,这时就需要对一些属性进行设置,或者使用代码设置.        今天想学一下Android屏幕横竖屏切换,但是网上很多知识不准确或不正确, ...

  4. Android横竖屏切换的生命周期

    1.新建一个Activity,并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate--> onStart--> onResume--> 3.按crtl+ ...

  5. Android(java)学习笔记224:横竖屏切换时Activity的生命周期

    1.横竖屏切换的生命周期     默认情况下横竖屏切换,先销毁再创建 2.有的时候,默认情况下的横竖屏切换(先销毁再创建),对应用户体验是不好的,比如是手机游戏横竖屏切换对游戏体验非常不好,下面两种方 ...

  6. Android(java)学习笔记167:横竖屏切换时Activity的生命周期

    1.横竖屏切换的生命周期     默认情况下横竖屏切换,先销毁再创建 2.有的时候,默认情况下的横竖屏切换(先销毁再创建),对应用户体验是不好的,比如是手机游戏横竖屏切换对游戏体验非常不好,下面两种方 ...

  7. Android横竖屏切换生命周期

    转自xiaoQLuhttp://www.cnblogs.com/xiaoQLu/p/3324503.html 开源帮助android获得了飞速的发展,开源也导致了数不清的碎片问题.android的前期 ...

  8. Activity 横竖屏切换

    前言 在开发中常要处理横竖屏切换,怎么处理先看生命周期 申明 Activity 横竖屏切换时需要回调两个函数 ,所以在此将这个两个函数暂时看成是Activity 横竖屏切换的生命周期的一部分,这两个函 ...

  9. Activity嵌套多个Fragment实现横竖屏切换

    一.上图 二.需求 最近项目遇到个横竖屏切换的问题.较为复杂.在此记之. 1.Activity中竖屏嵌套3个Fragment,本文简称竖屏FP1,FP2,FP3. 2.当中竖屏FP1与FP2能够切换为 ...

随机推荐

  1. nandflash驱动程序编写

    NAND FLASH是一个存储芯片 那么: 这样的操作很合理"读地址A的数据,把数据B写到地址A" 问1. 原理图上NAND FLASH和S3C2440之间只有数据线, 怎么传输地 ...

  2. Apache Shiro系列四,概述 —— Shiro的架构

    Shiro的设计目标就是让应用程序的安全管理更简单.更直观.     软件系统一般是基于用户故事来做设计.也就是我们会基于一个客户如何与这个软件系统交互来设计用户界面和服务接口.比如,你可能会说:“如 ...

  3. road习题(二)

    答案:[C] 解析:2 8 原则,考虑的是最高峰,所以安装12小时算 ,80%的 PV 也就是访问都是在 早上6点到下午6点这12个小时里,晚上6点到早上6点的PV总量是40000 ,服务器台数为3, ...

  4. iOS-绘图&lpar;Quartz2D&rpar;的简单使用&lpar;原创&rpar;

    前言 附上绘图demo--https://github.com/yangfangxue/YFX_Quartz-2D 什么是Quartz2D? Quartz 2D是一个二维图形绘制引擎,支持ios环境和 ...

  5. tftp从linux下载文件

    1,背景: 当我们ssh到一台linux上时候,从linux上下载一些文件,方案如下: 1.1通过sftp:通过win7 ftp客户端连接到linux去下载文件. 1.2通过tftp 2,问题 有些l ...

  6. 初尝backbone

    backbone的基础知识在此将不再进行介绍.自己后续应该会整理出来,不过今天先把这几天学的成果用一个demo进行展示. 后续可运行demo将会在sinaapp上分享,不过近期在整理sinaapp上d ...

  7. 创业公司求IOS、Android攻城狮一枚

    地点:北京CBD附近(地铁1号线大望路) 魅力值:送珍贵期权 你要会:       1. IOS或者Android开发       2.可以处理类似微视/秒拍的视频录制功能       3.熟悉jso ...

  8. django启动server报错Error&colon; That port is already in use&period;

    这种一般是端口错误,一般是要把端口关掉,这里提供了两种方法. 方法一:直接命令: sudo lsof -t -i tcp:8000 | xargs kill -9 方法二:脚本:名字manage.py ...

  9. docker命名空间、控制组及联合文件系统概念

    基本架构 命名空间 控制组 联合文件系统 docker底层依赖的核心技术主要包括操作系统的命名空间(Namespace).控制组(Control Groups).联合文件系统(Union File S ...

  10. Markdown学习(一)

    先从了解开始. 1 什么是标记语言(Markup Language)? 可以参考下wiki Markup language:https://en.wikipedia.org/wiki/Markup_l ...