前言:
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