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
这个就是用来判读是否读取,成功!

@property (nonatomic, getter=isReady, readonly) BOOL ready;

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

@property (nonatomic, copy) NSString *alertMessage;

开始读取数据

- (void)beginSession;

关闭NFC读取功能。

- (void)invalidateSession;

@end

NFCReaderSession 代理

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

  • (void)readerSessionDidBecomeActive:(NFCReaderSession *)session;

扫描到数据。Tags是数据源

  • (void)readerSession:(NFCReaderSession *)session didDetectTags:(NSArray<__kindof id> *)tags;

扫描错误的代理,回调

  • (void)readerSession:(NFCReaderSession *)session didInvalidateWithError:(NSError *)error;

@end

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

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

  • (instancetype)init NS_UNAVAILABLE;

@end
以上就是NFC基类的AIP

现在说下使用的EDEFReaderSession ,这个类跟父类没有多大的区别!

import

@class NFCReaderSession;
@class NFCNDEFReaderSession;

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

typedef NS_ENUM(uint8_t, NFCTypeNameFormat) {
NFCTypeNameFormatEmpty             = 0x00,
NFCTypeNameFormatNFCWellKnown      = 0x01,
NFCTypeNameFormatMedia             = 0x02,
NFCTypeNameFormatAbsoluteURI       = 0x03,
NFCTypeNameFormatNFCExternal       = 0x04,
NFCTypeNameFormatUnknown           = 0x05,
NFCTypeNameFormatUnchanged         = 0x06

};

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

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

  • (instancetype)init NS_UNAVAILABLE;

@end

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

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

  • (instancetype)init NS_UNAVAILABLE;

@end

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

@required

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

  • (void)readerSession:(NFCNDEFReaderSession *)session didInvalidateWithError:(NSError *)error;

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

  • (void)readerSession:(NFCNDEFReaderSession *)session didDetectNDEFs:(NSArray *)messages;

@end

pragma mark - NDEF reader session

@interface NFCNDEFReaderSession : NFCReaderSession

*是否支持NFC

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

  • (instancetype)init NS_UNAVAILABLE;

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

  • (instancetype)initWithDelegate:(id)delegate queue:(nullable dispatch_queue_t)queue invalidateAfterFirstRead:(BOOL)invalidateAfterFirstRead NS_DESIGNATED_INITIALIZER;

@end

你可能感兴趣的:(ios NFC API)