ios NFC API

前言:
Apple developers 上阅读,以及自己对NFC的理解。
IOS11 开放了 读取EDEF标准格式的NFC,只限制iPhone 7 以上的机型。

1.iPhone NFC与Android NFC
android 一直有这个NFC功能,而且还支持各种自定义格式的NFC,IOS只支持标准的NFC换句话来说,IOS扫不出公交卡,以及以前自定义格式的NFC,这个局限性很大。Android 还可以写入,IOS根本没有开放这个功能,系统也不提供像Android那样,系统直接给你开发NFC功能,(这里指的是,Android有NFC打开按钮就可以识别NFC),Apple pay 也是得打开NFC出现图标,才能使用根本不会像Android那样,所以说NFC开发是很局限的。

2.开发NFC core 这个框架 难易
NFC core 是一个轻量级的框架,相对比IOS新推出的任何框架都简单!标准的Apple API,一个基类 使用子类模式。
Reader Sessions 基类
NFCNDEFReaderSession NDEF格式的子类
具体操作如下:
使用sessions, 先实例化出来,sessions 实例化,直接带代理和在那个 线程读取NFC,一般都是写主线程,然后使用 begin 方法开启,这样就可以开启NFC识别了!数据在代理回调方法里获取数据,然后取值。

3.IOS NFC在我们生活中有什么作用呢
Apple pay 这个在中国根本是行不通,微信支付,支付宝支付,目前普遍流行使用。
NFC在Android 手机已经存在很长时间了,但是这项技术功能一直是不温不火。
这项技术没有什么突破性,没有什么实质性的作用,但是他有很实在的传输功能,类似蓝牙都是鸡肋。

Core NFC包含以下内容
Reader Sessions 这个是基类!
NFCNDEFReaderSession 子类,只能读取NDEF的NFC,什么公交卡 什么自定义格式的想都别想了,要标准的NDEF!目前我测试 除了标准的,其他的不可以。我们开发就是用这个类。
1.下面我来说下NFCReaderSession.h文件。
@protocol NFCReaderSession <NSObject>
这个就是用来判读是否读取,成功!

这个用来提示文字用的,在nuf上方的提示字体!

开始读取数据

关闭NFC读取功能。

@end

判读是否已经激活NFC,用session isready判读

扫描到数据。Tags是数据源

扫描错误的代理,回调

@end

@interface NFCReaderSession : NSObject<NFCReaderSession>
//属性设置代理
@property (nonatomic, weak, readonly) id delegate;

设置NFC回调在哪里线程
@property (nonatomic, readonly) dispatch_queue_t sessionQueue;
//实例方法

@end
以上就是NFC基类的AIP

@class NFCReaderSession;
@class NFCNDEFReaderSession;

@property (nonatomic, assign) NFCTypeNameFormat typeNameFormat; 是对应这个的 ,那个枚举对应,你可以在获取数据的时候打印,对应着每个枚举,具体枚举是什么意思,我不知道apple developers,也没找到。用的话
NFCTypeNameFormat typeName = NFCNDEFPayload.typeNameFormat;

};

这个是NFC的读取出来的属性!
API_AVAILABLE(ios(11.0)) API_UNAVAILABLE(watchos, macos, tvos)
@interface NFCNDEFPayload : NSObject<NSSecureCoding>

@property (nonatomic, assign) NFCTypeNameFormat typeNameFormat;
@property (nonatomic, copy) NSData *type;
@property (nonatomic, copy) NSData *identifier;
@property (nonatomic, copy) NSData *payload;
//实例化

@end

*@class NFCNDEFMessage
*消息类,这个里面有一个属性,就是NFC的属性。

@interface NFCNDEFMessage : NSObject<NSSecureCoding>
//这个是每次读取后的NFC,可以打印的
@property (nonatomic, copy) NSArray<NFCNDEFPayload > records;
// 实例化

@end

API_AVAILABLE(ios(11.0)) API_UNAVAILABLE(watchos, macos, tvos)
@protocol NFCNDEFReaderSessionDelegate <NSObject>

@required

是否错误的,如果错误自行打印判断

读取成功时候返回的FNC,都在这个messages 里面,读取消息类

@end

@interface NFCNDEFReaderSession : NFCReaderSession

*是否支持NFC

@property (class, nonatomic, readonly) BOOL readingAvailable;
//实例化

实例化方法跟父类,的几个属性基本上一致!

@end



扩展阅读:apple免费网站 ... iphone14录入nfc门禁卡 ... 苹果官网正品查询入口 ... 俏佳人怎么进入 ... 苹果手机官方旗舰店官网 ... 苹果官网登录入口 ... app 手机软件 ... iphone nfc功能怎么打开 ... mifare classic tool ...

本站交流只代表网友个人观点,与本站立场无关
欢迎反馈与建议,请联系电邮
2024© 车视网