关于NFC(近场通信)的三种响应模式(二)

在之前的《NFCactivity响应模式(一)》中我们讲过,前台发布系统的优先级高于intent发布系统,也就是说当一个正在前台运行的程序可以处理被扫描到的tag时,系统将不会跳出应用列表让用户选择,而直接由前台的activity来处理tagintent请求。

运行在前台的activity不会默认成为前台发布系统,按照activity的生命周期,我们如果覆盖了activityonCreate()、onNewIntent()、onPause()和onResume()这几个方法(其中实现一个activity类必须要覆盖的方法是onCreate方法),我们会发现:1、当第一次启动一个应用程序的时候,会调用onCreate()和onResume()方法,其中onResume()方法使该activity成为前台发布系统。

2、当一个tag被扫描时,系统会调用onPause()暂停掉当前的activity,而处理tag发出来的intent请求,这时该activity已经不再是前台发布系统了。

如果想要当前的应用程序能直接处理tag,那么必须打开前台发布系统,思路如下:

1、  一个前台发布程序activity从启动检测tag所要经历的生命周期:

onCreate()->onResume()-> onPause()->onNewIntent()-> onResume()

2、 覆盖掉activityonNewIntent()、onPause()和onResume()三个方法

3、  在主线程中调用enableForegroundDispatch(Activity, PendingIntent, IntentFilter[], String[][]),其中“主线程”我的理解是activity所要经历的生命周期中,由于变成前台发布程序onResume是必经的方法,所以一般把enableForegroundDispatch(Activity, PendingIntent, IntentFilter[], String[][])是写在onResume()方法里面。

4、  按照android帮助文档的说法,一旦在onResume()中调用了enableForegroundDispatch方法,那么必须在onPause()中调用disableForegroundDispatch方法。其实我认为应该在onStop()和onDestroy()中也调用disableForegroundDispatch方法,系统只考虑了正常情况下的退出,我刚试过直接杀掉该进程, activity仍一直处于前台发布系统,拿tag来扫描还是会默认由其来处理。没有看过android的源码,难道在onStop()和onDestroy()中没有调用onPause()方法?这点我很奇怪,等以后再证实吧!

5、  所有对卡片的交互处理全部写在一个单独的方法中,供onCreate()和onNewIntent()调用。当弹出列表让用户选择时,假设用户选择了该activity,则会调用onCreate()方法,当该activitye为前台发布程序时,检测到tag,并且符合intent过滤规则,则会调用onNewIntent()方法。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值