iOS AILinkBleSDK - 蓝牙SDK
Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

MultipleMeatProbeBoxVC.m 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334
  1. //
  2. // MultipleMeatProbeBoxVC.m
  3. // AILinkBleSDK_Example
  4. //
  5. // Created by LarryZhang on 2024/9/7.
  6. // Copyright © 2024 zhengzida. All rights reserved.
  7. //
  8. #import "MultipleMeatProbeBoxVC.h"
  9. #import <AILinkBleSDK/ELAILinkBleManager.h>
  10. #import <AILinkBleSDK/NSData+AILinkBle.h>
  11. #import "ELMeatProbeBoxMultipleBleParser.h"
  12. #import "ELMeatProbeBoxMultipleBleCmdTool.h"
  13. #import "ELMeatProbeBoxMultipleBleBBQParamModel.h"
  14. @interface MultipleMeatProbeBoxVC () <ELAILinkBleManagerDelegate, ELMeatProbeBoxMultipleBleParserDelegate>
  15. @property (weak, nonatomic) IBOutlet UILabel *bleStatusLabel;
  16. @property (weak, nonatomic) IBOutlet UITextView *logTextView;
  17. @property (nonatomic, strong) ELAILinkBleManager *bleManager;
  18. @property (nonatomic, assign) NELBleManagerConnectState bleConnectState;
  19. @property (nonatomic, strong) ELMeatProbeBoxMultipleBleParser *bleParser;
  20. @property (nonatomic, strong) ELMeatProbeBoxMultipleStatusModel *boxStatus;
  21. @property (nonatomic, strong) NSMutableDictionary<NSString *, ELMeatProbeBoxMultipleBleBBQParamModel *> *paramDic;
  22. @end
  23. @implementation MultipleMeatProbeBoxVC
  24. - (void)viewDidLoad {
  25. [super viewDidLoad];
  26. // Do any additional setup after loading the view from its nib.
  27. self.paramDic = [NSMutableDictionary dictionary];
  28. [self initBle];
  29. }
  30. - (void)dealloc {
  31. [self deinitBle];
  32. }
  33. #pragma mark - Action
  34. - (IBAction)requestParamsAction:(id)sender {
  35. NSData *payload = [ELMeatProbeBoxMultipleBleCmdTool requestParams:self.bleManager];
  36. NSString *log = [NSString stringWithFormat:@"发: payload: %@", payload];
  37. [self addLog:log];
  38. }
  39. - (IBAction)setupParamsAction:(id)sender {
  40. if (self.boxStatus == nil) {
  41. return;
  42. }
  43. if (self.boxStatus.probeStatusArray == nil || self.boxStatus.probeStatusArray.count != 2) {
  44. return;
  45. }
  46. ELMeatProbeBoxMultipleProbeStatusModel *status = self.boxStatus.probeStatusArray.firstObject;
  47. if (status == nil) {
  48. return;
  49. }
  50. ELMeatProbeBoxMultipleBleBBQParamModel *param = self.paramDic[status.macString];
  51. if (param == nil) {
  52. return;
  53. }
  54. param.foodType = 1;
  55. param.targetTemperatureRaw_C = 70;
  56. param.targetTemperatureRaw_F = 212;
  57. param.foodRawness = 1;
  58. param.alarmTemperaturePercent = 0.95;
  59. param.cookingId = [NSDate date].timeIntervalSince1970;
  60. NSData *payload = [ELMeatProbeBoxMultipleBleCmdTool setupParam:param supportProbe:1 manager:self.bleManager];
  61. NSString *log = [NSString stringWithFormat:@"发: payload: %@", payload];
  62. [self addLog:log];
  63. }
  64. - (IBAction)switchUnitAction:(id)sender {
  65. if (self.boxStatus.unit == 1) {
  66. NSData *payload = [ELMeatProbeBoxMultipleBleCmdTool switchUnit:0 manager:self.bleManager];
  67. NSString *log = [NSString stringWithFormat:@"发: payload: %@ -- 切换单位 to ℃", payload];
  68. [self addLog:log];
  69. } else {
  70. NSData *payload = [ELMeatProbeBoxMultipleBleCmdTool switchUnit:1 manager:self.bleManager];
  71. NSString *log = [NSString stringWithFormat:@"发: payload: %@ -- 切换单位 to ℉", payload];
  72. [self addLog:log];
  73. }
  74. }
  75. - (IBAction)clearAction:(id)sender {
  76. self.logTextView.text = @"";
  77. }
  78. - (IBAction)shareLogAction:(id)sender {
  79. }
  80. #pragma mark - ELAILinkBleManagerDelegate
  81. - (void)initBle {
  82. self.bleManager = [[ELAILinkBleManager alloc] init];
  83. self.bleManager.ailinkDelegate = self;
  84. self.bleParser = [[ELMeatProbeBoxMultipleBleParser alloc] init];
  85. self.bleParser.delegate = self;
  86. self.bleParser.mac = self.per.macAddressString;
  87. }
  88. - (void)scanBle {
  89. [self.bleManager scanFilterWithCidArray:@[@(self.per.cid)]];
  90. }
  91. - (void)connect:(ELAILinkPeripheral *)peripheral {
  92. [self.bleManager connectAILinkPeripheral:peripheral];
  93. [self updateBleStatusView:NELBleManagerConnectStateConnecting];
  94. }
  95. - (void)deinitBle {
  96. [self.bleManager stopScan];
  97. self.bleManager.ailinkDelegate = nil;
  98. [self.bleManager disconnectPeripheral];
  99. }
  100. - (void)updateBleStatusView:(NELBleManagerConnectState)state {
  101. if (self.bleManager.central.state == CBManagerStatePoweredOff) {
  102. self.bleStatusLabel.text = @"蓝牙关闭";
  103. [self addLog:self.bleStatusLabel.text];
  104. return;
  105. }
  106. switch (state) {
  107. case NELBleManagerConnectStateDisconnected:
  108. self.bleStatusLabel.text = @"断开连接";
  109. break;
  110. case NELBleManagerConnectStateFailed:
  111. case NELBleManagerConnectStateFailedValidation:
  112. self.bleStatusLabel.text = @"连接失败";
  113. break;
  114. case NELBleManagerConnectStateConnecting:
  115. self.bleStatusLabel.text = @"正在连接...";
  116. break;
  117. case NELBleManagerConnectStatePassed:
  118. self.bleStatusLabel.text = @"连接成功";
  119. [self requestDeviceData];
  120. // read RSSI
  121. // [self readRSSI];
  122. break;
  123. case NELBleManagerConnectStateCentralScanning:
  124. self.bleStatusLabel.text = @"正在扫描...";
  125. break;
  126. default:
  127. break;
  128. }
  129. [self addLog:self.bleStatusLabel.text];
  130. }
  131. - (void)requestDeviceData {
  132. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, 1.0), dispatch_get_main_queue(), ^{
  133. });
  134. }
  135. // 设备状态变更
  136. - (void)managerDidUpdateState:(CBCentralManager *)central {
  137. NSLog(@"%s state:%@", __func__, @(central.state));
  138. if (central.state == CBManagerStatePoweredOn) {
  139. [self scanBle];
  140. } else if (central.state == CBManagerStatePoweredOff) {
  141. self.bleConnectState = NELBleManagerConnectStateCentralPowerOff;
  142. [self updateBleStatusView:NELBleManagerConnectStateCentralPowerOff];
  143. }
  144. }
  145. - (void)managerScanState:(BOOL)scanning {
  146. NSLog(@"%s scanning:%@", __func__, @(scanning));
  147. if (scanning) {
  148. [self updateBleStatusView:NELBleManagerConnectStateCentralScanning];
  149. }
  150. }
  151. // 扫描到设备
  152. - (void)managerDidDiscoverPeripheral:(ELAILinkPeripheral *)peripheral {
  153. NSLog(@"managerDidDiscoverPeripheral cid:%02x vid:%02x pid:%02x mac:%@", peripheral.cid, peripheral.vid, peripheral.pid, peripheral.macAddressString);
  154. if ([peripheral.macAddressString isEqualToString:self.per.macAddressString]) {
  155. [self.bleManager stopScan];
  156. [self connect:peripheral];
  157. }
  158. }
  159. - (void)managerDidUpdateConnect:(NELBleManagerConnectState)state {
  160. NSLog(@"%s NELBleManagerConnectState:%@", __func__, @(state));
  161. [self updateBleStatusView:state];
  162. }
  163. //A7数据
  164. - (void)aiLinkBleReceiveA7Data:(NSData *)payload {
  165. NSLog(@"%s #### payload:%@", __func__, payload.elHexString);
  166. NSString *log = [NSString stringWithFormat:@"收: payload: %@", payload.elHexString];
  167. [self addLog:log];
  168. [self.bleParser parseA7Payload:payload];
  169. }
  170. //A6数据
  171. - (void)aiLinkBleReceiveA6Data:(NSData *)packet {
  172. NSLog(@"%s ##### packet:%@", __func__, packet.elHexString);
  173. Byte *bytes = (Byte *)packet.bytes;
  174. Byte cmd = bytes[2];
  175. if (cmd == ELInetGetCmdTypeGetBMVersion) {
  176. NSString *bmVersion = self.bleManager.bmVersion;
  177. NSLog(@"##### bmVersion: %@", bmVersion);
  178. }
  179. if (cmd == ELInetGetCmdTypeGetBMVersionPro) {
  180. NSString *bmVersionPro = self.bleManager.bmVersionPro;
  181. NSLog(@"##### bmVersionPro: %@", bmVersionPro);
  182. }
  183. }
  184. #pragma mark - ELMeatProbeBoxMultipleBleParserDelegate
  185. //MCU 上报设备状态数据(Type:02)
  186. - (void)meatProbeBoxMultipleBleParser:(ELMeatProbeBoxMultipleBleParser *)parser boxStatus:(ELMeatProbeBoxMultipleStatusModel *)boxStatus { NSLog(@"##### boxStatus(): %@ ", boxStatus.debugDescription);
  187. self.boxStatus = boxStatus;
  188. NSString *log = [NSString stringWithFormat:@"boxStatus: { mac:%@, probeMaxCount:%hhu, probeCount:%hhu, batteryStatus:%hhu batteryPercent:%hhu, unit:%ld }", parser.mac, boxStatus.probeMaxCount, boxStatus.probeCount, boxStatus.batteryStatus, boxStatus.batteryPercent, boxStatus.unit];
  189. [self addLog:log];
  190. ELMeatProbeBoxMultipleProbeStatusModel *probeStatus = boxStatus.probeStatusArray.firstObject;
  191. NSString *log2 = [NSString stringWithFormat:@"probeStatus: { connectState:%@ macString:%hhu, internalTemperature_C:%ld ℃, ambientTemperature_C:%ld ℃ batteryStatus:%hhu batteryPercent:%hhu }", probeStatus.macString, probeStatus.connectState, probeStatus.internalTemperature_C, probeStatus.ambientTemperature_C, probeStatus.batteryStatus, probeStatus.batteryPercent];
  192. [self addLog:log2];
  193. }
  194. //切换单位(Type:04)
  195. - (void)meatProbeBoxMultipleBleParser:(ELMeatProbeBoxMultipleBleParser *)parser unit:(ELDeviceTemperatureUnit)unit {
  196. NSLog(@"##### unit(): %@", @(unit));
  197. NSString *log = [NSString stringWithFormat:@"unit(): %@", unit == 0 ? @"℃" : @"°F"];
  198. [self addLog:log];
  199. }
  200. //报警状态数据(Type:06)//state: bit0:食物目标温度到达时置1
  201. - (void)meatProbeBoxMultipleBleParser:(ELMeatProbeBoxMultipleBleParser *)parser startAlarmWithState:(Byte)state macData:(NSData *)macData mac:(NSString *)mac {
  202. NSLog(@"##### box:%@ startAlarmWithState(): probe:%@ state:%@", parser.mac, mac, @(state));
  203. NSString *log = [NSString stringWithFormat:@"box:%@ startAlarmWithState(): probe:%@ state:%@", parser.mac, mac, @(state)];
  204. [self addLog:log];
  205. }
  206. //取消报警(Type:08)
  207. - (void)meatProbeBoxMultipleBleParser:(ELMeatProbeBoxMultipleBleParser *)parser stopAlarmWithMacData:(NSData *)macData mac:(NSString *)mac {
  208. NSLog(@"##### box:%@ stopAlarmWithMacData(): probe:%@ ", parser.mac, mac);
  209. NSString *log = [NSString stringWithFormat:@"box:%@ stopAlarmWithMacData(): probe:%@ ", parser.mac, mac];
  210. [self addLog:log];
  211. }
  212. //烧烤任务参数(Type:0A)//Op:0x00:设置任务参数(设置时需要一个针一个针设定任务) 0x01:获取任务参数(返回所有的针任务,如果包长度超MTU时,会分包发) 0x02:结束烧烤任务
  213. - (void)meatProbeBoxMultipleBleParser:(ELMeatProbeBoxMultipleBleParser *)parser option:(UInt8)option supportProbe:(UInt8)supportProbe param:(ELMeatProbeBoxMultipleBleBBQParamModel *)param {
  214. NSLog(@"##### box:%@ meatProbeScreenBoxBleParser(): option:%@ supportProbe:%@ ", parser.mac, @(option), @(supportProbe));
  215. NSLog(@"##### param:%@ state:%@ foodType:%@", param.macString, @(param.state), @(param.foodType));
  216. self.paramDic[param.macString] = param;
  217. NSString *log = [NSString stringWithFormat:@"box:%@ meatProbeScreenBoxBleParser(): option:%@ supportProbe:%@ ", parser.mac, @(option), @(supportProbe)];
  218. NSString *log2 = [NSString stringWithFormat:@"param:%@ state:%@ foodType:%@", param.macString, @(param.state), @(param.foodType)];
  219. [self addLog:log];
  220. [self addLog:log2];
  221. }
  222. //color info
  223. - (void)meatProbeBoxMultipleBleParser:(ELMeatProbeBoxMultipleBleParser *)parser colorInfos:(NSArray<ELMeatProbeBoxMultipleColorInfoModel *> *)colorInfos {
  224. NSLog(@"##### colorInfos(): %@", colorInfos);
  225. if (colorInfos == nil || colorInfos.count == 0) {
  226. return;
  227. }
  228. ELMeatProbeBoxMultipleColorInfoModel *colorInfo = colorInfos.firstObject;
  229. NSString *log = [NSString stringWithFormat:@"colorInfos(): count:%@ probeIndex:%@ colorIndex:%@", @(colorInfos.count), @(colorInfo.probeIndex), @(colorInfo.colorIndex)];
  230. [self addLog:log];
  231. }
  232. - (void)peripheralDidReadRSSI:(nonnull NSNumber *)RSSI {
  233. NSLog(@"%s peripheralDidReadRSSI: %@", __FUNCTION__, RSSI);
  234. // main thread
  235. dispatch_async(dispatch_get_main_queue(), ^{
  236. [self addLog:[NSString stringWithFormat:@"peripheralDidReadRSSI: %@", RSSI]];
  237. });
  238. [self readRSSI];
  239. }
  240. - (void)readRSSI {
  241. // delay
  242. dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(4.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
  243. // Read RSSI
  244. [self.bleManager readRSSI];
  245. });
  246. }
  247. #pragma mark - addLog
  248. - (void)addLog:(NSString *)log {
  249. [self addLog:log newline:YES];
  250. }
  251. - (void)addWithoutNewlineLog:(NSString *)log {
  252. [self addLog:log newline:NO];
  253. }
  254. - (void)addLog:(NSString *)log newline:(BOOL)newline {
  255. NSDateFormatter *format = [[NSDateFormatter alloc] init];
  256. format.dateFormat = @"HH:mm:ss.SSS";
  257. NSString *time = [format stringFromDate:[NSDate date]];
  258. if (newline) {
  259. self.logTextView.text = [self.logTextView.text stringByAppendingFormat:@"%@ %@\n", time, log];
  260. } else {
  261. self.logTextView.text = [self.logTextView.text stringByAppendingFormat:@"%@ %@", time, log];
  262. }
  263. [self.logTextView scrollRangeToVisible:NSMakeRange(self.logTextView.text.length, 1)];
  264. }
  265. @end