前言:
Apple developers 上閱讀,以及自己對(duì)NFC的理解。
IOS11 開(kāi)放了 讀取EDEF標(biāo)準(zhǔn)格式的NFC,只限制iPhone 7 以上的機(jī)型。
1.iPhone NFC與Android NFC
android 一直有這個(gè)NFC功能,而且還支持各種自定義格式的NFC,IOS只支持標(biāo)準(zhǔn)的NFC換句話來(lái)說(shuō),IOS掃不出公交卡,以及以前自定義格式的NFC,這個(gè)局限性很大。Android 還可以寫(xiě)入,IOS根本沒(méi)有開(kāi)放這個(gè)功能,系統(tǒng)也不提供像Android那樣,系統(tǒng)直接給你開(kāi)發(fā)NFC功能,(這里指的是,Android有NFC打開(kāi)按鈕就可以識(shí)別NFC),Apple pay 也是得打開(kāi)NFC出現(xiàn)圖標(biāo),才能使用根本不會(huì)像Android那樣,所以說(shuō)NFC開(kāi)發(fā)是很局限的。
2.開(kāi)發(fā)NFC core 這個(gè)框架 難易
NFC core 是一個(gè)輕量級(jí)的框架,相對(duì)比IOS新推出的任何框架都簡(jiǎn)單!標(biāo)準(zhǔn)的Apple API,一個(gè)基類 使用子類模式。
Reader Sessions 基類
NFCNDEFReaderSession NDEF格式的子類
具體操作如下:
使用sessions, 先實(shí)例化出來(lái),sessions 實(shí)例化,直接帶代理和在那個(gè) 線程讀取NFC,一般都是寫(xiě)主線程,然后使用 begin 方法開(kāi)啟,這樣就可以開(kāi)啟NFC識(shí)別了!數(shù)據(jù)在代理回調(diào)方法里獲取數(shù)據(jù),然后取值。
3.IOS NFC在我們生活中有什么作用呢
Apple pay 這個(gè)在中國(guó)根本是行不通,微信支付,支付寶支付,目前普遍流行使用。
NFC在Android 手機(jī)已經(jīng)存在很長(zhǎng)時(shí)間了,但是這項(xiàng)技術(shù)功能一直是不溫不火。
這項(xiàng)技術(shù)沒(méi)有什么突破性,沒(méi)有什么實(shí)質(zhì)性的作用,但是他有很實(shí)在的傳輸功能,類似藍(lán)牙都是雞肋。
Core NFC包含以下內(nèi)容
Reader Sessions 這個(gè)是基類!
NFCNDEFReaderSession 子類,只能讀取NDEF的NFC,什么公交卡 什么自定義格式的想都別想了,要標(biāo)準(zhǔn)的NDEF!目前我測(cè)試 除了標(biāo)準(zhǔn)的,其他的不可以。我們開(kāi)發(fā)就是用這個(gè)類。
1.下面我來(lái)說(shuō)下NFCReaderSession.h文件。
@protocol NFCReaderSession <NSObject>
這個(gè)就是用來(lái)判讀是否讀取,成功!
@property (nonatomic, getter=isReady, readonly) BOOL ready;
這個(gè)用來(lái)提示文字用的,在nuf上方的提示字體!
@property (nonatomic, copy) NSString *alertMessage;
開(kāi)始讀取數(shù)據(jù)
- (void)beginSession;
關(guān)閉NFC讀取功能。
- (void)invalidateSession;
@end
NFCReaderSession 代理
判讀是否已經(jīng)激活NFC,用session isready判讀
- (void)readerSessionDidBecomeActive:(NFCReaderSession *)session;
掃描到數(shù)據(jù)。Tags是數(shù)據(jù)源
- (void)readerSession:(NFCReaderSession *)session didDetectTags:(NSArray<__kindof id<NFCTag>> *)tags;
掃描錯(cuò)誤的代理,回調(diào)
- (void)readerSession:(NFCReaderSession *)session didInvalidateWithError:(NSError *)error;
@end
@interface NFCReaderSession : NSObject<NFCReaderSession>
//屬性設(shè)置代理
@property (nonatomic, weak, readonly) id delegate;
設(shè)置NFC回調(diào)在哪里線程
@property (nonatomic, readonly) dispatch_queue_t sessionQueue;
//實(shí)例方法
- (instancetype)init NS_UNAVAILABLE;
@end
以上就是NFC基類的AIP
現(xiàn)在說(shuō)下使用的EDEFReaderSession ,這個(gè)類跟父類沒(méi)有多大的區(qū)別!
import <Foundation/Foundation.h>
@class NFCReaderSession;
@class NFCNDEFReaderSession;
@property (nonatomic, assign) NFCTypeNameFormat typeNameFormat; 是對(duì)應(yīng)這個(gè)的 ,那個(gè)枚舉對(duì)應(yīng),你可以在獲取數(shù)據(jù)的時(shí)候打印,對(duì)應(yīng)著每個(gè)枚舉,具體枚舉是什么意思,我不知道apple developers,也沒(méi)找到。用的話
NFCTypeNameFormat typeName = NFCNDEFPayload.typeNameFormat;
typedef NS_ENUM(uint8_t, NFCTypeNameFormat) {
NFCTypeNameFormatEmpty = 0x00,
NFCTypeNameFormatNFCWellKnown = 0x01,
NFCTypeNameFormatMedia = 0x02,
NFCTypeNameFormatAbsoluteURI = 0x03,
NFCTypeNameFormatNFCExternal = 0x04,
NFCTypeNameFormatUnknown = 0x05,
NFCTypeNameFormatUnchanged = 0x06
};
這個(gè)是NFC的讀取出來(lái)的屬性!
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;
//實(shí)例化
- (instancetype)init NS_UNAVAILABLE;
@end
*@class NFCNDEFMessage
*消息類,這個(gè)里面有一個(gè)屬性,就是NFC的屬性。
@interface NFCNDEFMessage : NSObject<NSSecureCoding>
//這個(gè)是每次讀取后的NFC,可以打印的
@property (nonatomic, copy) NSArray<NFCNDEFPayload > records;
// 實(shí)例化
- (instancetype)init NS_UNAVAILABLE;
@end
API_AVAILABLE(ios(11.0)) API_UNAVAILABLE(watchos, macos, tvos)
@protocol NFCNDEFReaderSessionDelegate <NSObject>
@required
是否錯(cuò)誤的,如果錯(cuò)誤自行打印判斷
- (void)readerSession:(NFCNDEFReaderSession *)session didInvalidateWithError:(NSError *)error;
讀取成功時(shí)候返回的FNC,都在這個(gè)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;
//實(shí)例化
- (instancetype)init NS_UNAVAILABLE;
實(shí)例化方法跟父類,的幾個(gè)屬性基本上一致!
- (instancetype)initWithDelegate:(id<NFCNDEFReaderSessionDelegate>)delegate queue:(nullable dispatch_queue_t)queue invalidateAfterFirstRead:(BOOL)invalidateAfterFirstRead NS_DESIGNATED_INITIALIZER;
@end