前言:
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>
这个就是用来判读是否读取,成功!
@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<NFCTag>> *)tags;
扫描错误的代理,回调
- (void)readerSession:(NFCReaderSession *)session didInvalidateWithError:(NSError *)error;
@end
@interface NFCReaderSession : NSObject<NFCReaderSession>
//属性设置代理
@property (nonatomic, weak, readonly) id delegate;
设置NFC回调在哪里线程
@property (nonatomic, readonly) dispatch_queue_t sessionQueue;
//实例方法
- (instancetype)init NS_UNAVAILABLE;
@end
以上就是NFC基类的AIP
现在说下使用的EDEFReaderSession ,这个类跟父类没有多大的区别!
import <Foundation/Foundation.h>
@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<NSSecureCoding>
@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<NSSecureCoding>
//这个是每次读取后的NFC,可以打印的
@property (nonatomic, copy) NSArray<NFCNDEFPayload > records;
// 实例化
- (instancetype)init NS_UNAVAILABLE;
@end
API_AVAILABLE(ios(11.0)) API_UNAVAILABLE(watchos, macos, tvos)
@protocol NFCNDEFReaderSessionDelegate <NSObject>
@required
是否错误的,如果错误自行打印判断
- (void)readerSession:(NFCNDEFReaderSession *)session didInvalidateWithError:(NSError *)error;
读取成功时候返回的FNC,都在这个messages 里面,读取消息类
- (void)readerSession:(NFCNDEFReaderSession *)session didDetectNDEFs:(NSArray<NFCNDEFMessage *> *)messages;
@end
pragma mark - NDEF reader session
@interface NFCNDEFReaderSession : NFCReaderSession
*是否支持NFC
@property (class, nonatomic, readonly) BOOL readingAvailable;
//实例化
- (instancetype)init NS_UNAVAILABLE;
实例化方法跟父类,的几个属性基本上一致!
- (instancetype)initWithDelegate:(id<NFCNDEFReaderSessionDelegate>)delegate queue:(nullable dispatch_queue_t)queue invalidateAfterFirstRead:(BOOL)invalidateAfterFirstRead NS_DESIGNATED_INITIALIZER;
@end