Android NFC一般使用方法

2024-01-10 20:18
文章标签 android 使用 方法 一般 nfc

本文主要是介绍Android NFC一般使用方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android NFC一般使用方法

  • Android NFC官网文档地址:[官网文档1](https://developer.android.google.cn/guide/topics/connectivity/nfc )、[官网地址2](https://developer.android.google.cn/reference/kotlin/android/nfc/package-summary?hl=en)
  • 一般使用方法:
    • 1、 AndroidManifest配置(可不配置):
    • 2、 NfcAdapter.getDefaultAdapter(this)获取nfc adapter实列,isEnabled可判断nfc是否可用;
    • 3、 Activity的onNewIntent会回调nfc读取的相应intent内容, NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action判断来自什么类型的vfc内容。
    • 4、 val pendingIntent = PendingIntent.getActivity( this, PENDING_RESULT, intent, PendingIntent.FLAG_UPDATE_CURRENT)
    • 5、 支持的标签技术:
    • 可选择支持的标签技术:
    • 6、代码相关:

Android NFC官网文档地址:官网文档1、官网地址2

一般使用方法:

1、 AndroidManifest配置(可不配置):

  <action android:name="android.nfc.action.TAG_DISCOVERED" />
  • 1> (ACTION_NDEF_DISCOVERED:如果扫描到包含 NDEF 负载的标签,并且可识别其类型,则使用此 Intent 启动 Activity。这是优先级最高的 Intent,标签调度系统会尽可能尝试使用此 Intent 启动 Activity,在行不通时才会尝试使用其他 Intent。
  • 2> ACTION_TECH_DISCOVERED:如果没有登记要处理 ACTION_NDEF_DISCOVERED Intent 的 Activity,则标签调度系统会尝试使用此 Intent 来启动应用。此外,如果扫描到的标签包含无法映射到 MIME 类型或 URI 的 NDEF 数据,或者该标签不包含 NDEF 数据,但它使用了已知的标签技术,那么也会直接启动此 Intent(无需先启动 ACTION_NDEF_DISCOVERED)。
  • 3> ACTION_TAG_DISCOVERED:如果没有处理 ACTION_NDEF_DISCOVERED 或者 ACTION_TECH_DISCOVERED Intent 的 Activity,则使用此 Intent 启动 Activity。

2、 NfcAdapter.getDefaultAdapter(this)获取nfc adapter实列,isEnabled可判断nfc是否可用;

3、 Activity的onNewIntent会回调nfc读取的相应intent内容, NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action判断来自什么类型的vfc内容。

4、 val pendingIntent = PendingIntent.getActivity( this, PENDING_RESULT, intent, PendingIntent.FLAG_UPDATE_CURRENT)

NfcAdapter.getDefaultAdapter(this).enableForegroundDispatch –使用前台调度,这种方式不用AndroidManifest注册intent-filter

5、 支持的标签技术:

说明
TagTechnology这是所有标签技术类都必须实现的接口。
NfcA提供对 NFC-A (ISO 14443-3A) 属性和 I/O 操作的访问权限。
NfcB提供对 NFC-B (ISO 14443-3B) 属性和 I/O 操作的访问权限。
NfcF提供对 NFC-F (JIS 6319-4) 属性和 I/O 操作的访问权限。
NfcV提供对 NFC-V (ISO 15693) 属性和 I/O 操作的访问权限。
IsoDep提供对 ISO-DEP (ISO 14443-4) 属性和 I/O 操作的访问权限。
Ndef提供对 NDEF 格式的 NFC 标签上的 NDEF 数据和操作的访问权限。
NdefFormatable为可设置为 NDEF 格式的标签提供格式化操作。

可选择支持的标签技术:

说明
MifareClassic提供对 MIFARE Classic 属性和 I/O 操作的访问权限(如果此 Android 设备支持 MIFARE)。
MifareUltralight提供对 MIFARE Ultralight 属性和 I/O 操作的访问权限(如果此 Android 设备支持 MIFARE)。

6、代码相关:

  • 1>当前是否支持NFC功能:
    AndroidManifest(permission):
    <uses-permission android:name="android.permission.NFC" /><uses-permission android:name="android.permission.NFC_PREFERRED_PAYMENT_INFO" />
    // Initialize the NFC adapterprivate fun initNfc() {// Gets the default NFC adapter for the systemmNfcAdapter = NfcAdapter.getDefaultAdapter(this)textBtn?.apply {text = if (mNfcAdapter == null) {"The current phone does not support NFC"} else if (!mNfcAdapter?.isEnabled!!) {"Please enable NFC in System Settings first"} else {"Mobile phones currently support NFC"}}}
  • 2>注册当前页面接收的NFC类型(IsoDepNfcANfcB…):
      override fun onResume() {super.onResume()Log.d("$TAG==", "onResume")mNfcAdapter?.let {if (!it.isEnabled) {return}val intent =Intent(this, MainActivity::class.java).addFlags(Intent.FLAG_ACTIVITY_SINGLE_TOP)val pendingIntent = PendingIntent.getActivity(this,PENDING_RESULT,intent,PendingIntent.FLAG_UPDATE_CURRENT)//It can define more than one here, but pay attention to the collocation, or there will be no callbacksval techLists = arrayOf(arrayOf(IsoDep::class.java.name
//                    ,
//                    NfcA::class.java.name,
//                    NfcB::class.java.name,
//                    NfcF::class.java.name,
//                    Ndef::class.java.name,
//                    NdefFormatable::class.java.name))try {val filters = arrayOf(IntentFilter(NfcAdapter.ACTION_TECH_DISCOVERED, "*/*"))it.enableForegroundDispatch(this, pendingIntent, filters, techLists)} catch (e: Exception) {e.printStackTrace()}}}
  • 3>接收当前页面感应到的NFC信息,通过intent接收传递的信息,action来区分:
  override fun onNewIntent(intent: Intent) {Log.d("$TAG== onNewIntent==","$TAG ${intent.action} " +"    ${intent.extras} " +" ${intent.flags} ")super.onNewIntent(intent)Toast.makeText(this, "$TAG ${intent.action} $intent", Toast.LENGTH_LONG).show()Log.d("$TAG== onNewIntent==","NfcAdapter.ACTION_NDEF_DISCOVERED => ${NfcAdapter.ACTION_NDEF_DISCOVERED}")if (NfcAdapter.ACTION_NDEF_DISCOVERED == intent.action) {intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES)?.also { rawMessages ->val messages: List<NdefMessage> = rawMessages.map { it as NdefMessage }// Process the messages array.Log.d("==nfc message==", messages.toString())}} else if (NfcAdapter.ACTION_TECH_DISCOVERED == intent.action) {val extraTag = intent.getParcelableExtra<Tag>(NfcAdapter.EXTRA_TAG)Log.d("$TAG==", "${intent.getParcelableExtra<Tag>(NfcAdapter.EXTRA_TAG)}"+ ",ACTION_NDEF_DISCOVERED==${intent.getParcelableArrayExtra(NfcAdapter.ACTION_NDEF_DISCOVERED)}"+ ",EXTRA_NDEF_MESSAGES==${intent.getParcelableArrayExtra(NfcAdapter.EXTRA_NDEF_MESSAGES)}")extraTag?.let {Log.d("$TAG==", "id:${extraTag.id},techList:${extraTag.techList}")}}}
  • 4>发送NFC信息example:
  //nfcv processprivate fun processTagNfcV(tag: Tag?) {val nfcV = NfcA.get(tag)Log.d("$TAG==NfcA ", "${nfcV}")if (nfcV != null) {// Create a connectionnfcV.connect()val data = ByteArray(20)// Send a messageval response: ByteArray = nfcV.transceive(data)Log.d("$TAG==response ", "${response.let {NdefRecord(TNF_ABSOLUTE_URI,"https://developer.android.com/index.html".toByteArray(Charset.forName("US-ASCII")),it,it)}}")// close junctionnfcV.close()}}
  • 4.1>读写NFC信息(官网示例):
   class MifareUltralightTagTester {//write fun writeTag(tag: Tag, tagText: String) {MifareUltralight.get(tag)?.use { ultralight ->ultralight.connect()Charset.forName("US-ASCII").also { usAscii ->ultralight.writePage(4, "abcd".toByteArray(usAscii))ultralight.writePage(5, "efgh".toByteArray(usAscii))ultralight.writePage(6, "ijkl".toByteArray(usAscii))ultralight.writePage(7, "mnop".toByteArray(usAscii))}}fun readTag(tag: Tag): String? {return MifareUltralight.get(tag)?.use { mifare ->mifare.connect()val payload = mifare.readPages(4)String(payload, Charset.forName("US-ASCII"))}}}}
  • 5>当前页面停止接收:
    override fun onPause() {super.onPause()//forbidden nfcmNfcAdapter?.isEnabled.takeIf { it != true }?: mNfcAdapter?.disableForegroundDispatch(this)Log.d("$TAG", "onPause")}


end

这篇关于Android NFC一般使用方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/591949

相关文章

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Java 方法重载Overload常见误区及注意事项

《Java方法重载Overload常见误区及注意事项》Java方法重载允许同一类中同名方法通过参数类型、数量、顺序差异实现功能扩展,提升代码灵活性,核心条件为参数列表不同,不涉及返回类型、访问修饰符... 目录Java 方法重载(Overload)详解一、方法重载的核心条件二、构成方法重载的具体情况三、不构