Blame view

HDFwear/OTA/OTAUpdateViewController.m 7.34 KB
78069d6a   jason   feat:lettransceiv...
1
2
3
4
5
6
7
  //
  //  OTAUpdateViewController.m
  //  HDFwear
  //
  //  Created by admin on 2024/1/24.
  //
  
60a29b2c   jason   feat:ota viewcont...
8
  #import "HDFwear-Bridging-Header.h"
78069d6a   jason   feat:lettransceiv...
9
  #import "OTAUpdateViewController.h"
60a29b2c   jason   feat:ota viewcont...
10
11
  #import "OTAManager.h"
  #import "MBProgressHUD.h"
78069d6a   jason   feat:lettransceiv...
12
13
14
15
16
  
  @interface OTAUpdateViewController ()
  
  @end
  
60a29b2c   jason   feat:ota viewcont...
17
18
19
20
21
  @implementation OTAUpdateViewController{
      NSDate *beginTime;
      
      BOOL isUpgrading;
  }
78069d6a   jason   feat:lettransceiv...
22
23
  - (void)viewDidLoad {
      [super viewDidLoad];
60a29b2c   jason   feat:ota viewcont...
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
      // Do any additional setup after loading the view, typically from a nib.
      
      isUpgrading = NO;
  
      _buttonStart.layer.borderWidth = 1.0f;
      _buttonStart.layer.cornerRadius = 4.0f;
      _buttonStart.layer.masksToBounds = YES;
      _buttonPrepare.layer.borderWidth = 1.0f;
      _buttonPrepare.layer.cornerRadius = 4.0f;
      _buttonPrepare.layer.masksToBounds = YES;
  
      
      if (self.currentPeripheral) {
          _labelBluetoothState.text = @"已连接";
          [_buttonPrepare setEnabled:YES];
      } else {
          _labelBluetoothState.text = @"N/A";
          [_buttonPrepare setEnabled:NO];
          [_buttonStart setEnabled:NO];
      }
  
      NSNotificationCenter *nc = [NSNotificationCenter defaultCenter];
      [nc addObserver:self
             selector:@selector(handleGlobalMessage:)
                 name:kMsgPeripheralConnected
               object:nil];
      [nc addObserver:self
             selector:@selector(handleGlobalMessage:)
                 name:kMsgPeripheralDisconnected
               object:nil];
      [nc addObserver:self
             selector:@selector(handleGlobalMessage:)
                 name:kMsgOTAStatus
               object:nil];
      [nc addObserver:self
             selector:@selector(handleGlobalMessage:)
                 name:kMsgAudioPackageRecevied
               object:nil];
      [nc addObserver:self
             selector:@selector(handleGlobalMessage:)
                 name:kMsgAudioSpeedRecevied
               object:nil];
      [nc addObserver:self
             selector:@selector(handleGlobalMessage:)
                 name:kMsgRemoteStatusRecevied
               object:nil];
      
  }
  
  - (void)viewWillDisappear:(BOOL)animated {
      [super viewWillDisappear:animated];
      if (self.closeBlock) {
          self.closeBlock();
      }
  }
  
  - (void)handleGlobalMessage:(NSNotification *)note{
      NSString* name = note.name;
      NSLog(@"nick_name:%@", name);
      NSDictionary* dict = note.userInfo;
      
      if ([name isEqualToString:kMsgPeripheralConnected]){
          if (self.currentPeripheral) {
              _labelBluetoothState.text = @"已连接";
              [_buttonPrepare setEnabled:YES];
              NSInteger mtu = [self.currentPeripheral maximumWriteValueLengthForType:CBCharacteristicWriteWithoutResponse];
              NSLog(@"mtu view:%d", mtu);
              [self.otaManager setMaxMtu:mtu];
          }
      } else if ([name isEqualToString:kMsgPeripheralDisconnected]){
          _labelBluetoothState.text = @"N/A";
          isUpgrading = NO;
          [_buttonPrepare setEnabled:NO];
          [_buttonStart setEnabled:NO];
          [_buttonStart setTitle:@"START" forState:UIControlStateNormal];
      } else if ([name isEqualToString:kMsgOTAStatus]){
          NSInteger state = ((NSNumber *)[dict objectForKey:@"status"]).integerValue;
          
          NSString *msg = @"UNKNOWN";
          switch (state) {
              case STATE_IDLE:
                  msg = @"IDLE";
                  break;
                  
              case STATE_PREPARING:
                  msg = @"PREPARING";
                  break;
                  
              case STATE_PREPARED:
                  msg = @"PREPARED";
                  break;
                  
              case STATE_TRANSFERRING:
                  msg = @"TRANSFERRING";
                  beginTime = [NSDate date];
                  NSLog(@"nick_time:%@", beginTime);
                  break;
                  
              case STATE_TRANSFERRED:
                  msg = @"TRANSFERRED";
                  isUpgrading = NO;
                  [_buttonStart setEnabled:YES];
                  [_buttonStart setTitle:@"START" forState:UIControlStateNormal];
                  
                  [self.otaManager confirmUpdateAndReboot];
                  break;
                  
              default:
                  msg = @"UNKNOWN";
                  isUpgrading = NO;
                  [_buttonStart setEnabled:YES];
                  [_buttonStart setTitle:@"START" forState:UIControlStateNormal];
                  break;
          }
          
          NSLog(@"onStatus: %ld %@", state, msg);
          _labelBluetoothState.text = msg;
      } else if ([name isEqualToString:kMsgAudioPackageRecevied]) {
          NSInteger psn = ((NSNumber *)[dict objectForKey:@"psn"]).integerValue;
          NSData *data = [dict objectForKey:@"data"];
          NSLog(@"nick_speed");
          
      } else if ([name isEqualToString:kMsgRemoteStatusRecevied]) {
          RemoteStatus *status = [dict objectForKey:@"status"];
  
          [_buttonStart setEnabled:YES];
      } else if ([name isEqualToString:kMsgAudioSpeedRecevied]) {
          NSInteger writeByte = ((NSNumber *)[dict objectForKey:@"speed"]).integerValue;
e3bf0573   jason   feat:log and run
152
          NSLog(@"writeByte is :%d", writeByte);
60a29b2c   jason   feat:ota viewcont...
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
          NSDate *now = [[NSDate alloc] init];
          now = [NSDate date];
          NSDateComponents *compt = [[NSCalendar currentCalendar] components:NSCalendarUnitMinute| NSCalendarUnitSecond fromDate:beginTime   toDate:now  options:0];
          int min = compt.minute;
          int sec = compt.second;
          int time = min * 60 + sec;
          double speed = writeByte / time / 1000;
          NSLog(@"nick_now:%d", sec);
      }
  }
  
  - (NSString *)convertDataToHexStr:(NSData *)data {
      if (!data || [data length] == 0) {
          return @"";
      }
      
      NSMutableString *string = [[NSMutableString alloc] initWithCapacity:[data length]];
      [data enumerateByteRangesUsingBlock:^(const void *bytes, NSRange byteRange, BOOL *stop) {
          unsigned char *dataBytes = (unsigned char*)bytes;
          for (NSInteger i = 0; i < byteRange.length; i++) {
              NSString *hexStr = [NSString stringWithFormat:@"%x", (dataBytes[i]) & 0xff];
              if ([hexStr length] == 2) {
                  [string appendString:hexStr];
              } else {
                  [string appendFormat:@"0%@", hexStr];
              }
          }
      }];
      
      return string;
78069d6a   jason   feat:lettransceiv...
183
184
  }
  
60a29b2c   jason   feat:ota viewcont...
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
  - (void)showTextHUD:(NSString *) text {
      dispatch_async(dispatch_get_main_queue(), ^{
          // 快速显示一个提示信息
          MBProgressHUD *hud = [MBProgressHUD showHUDAddedTo:self.view animated:YES];
          hud.label.text = text;
          
          hud.label.textColor = [UIColor whiteColor];
          hud.label.font = [UIFont systemFontOfSize:17.0];
          hud.userInteractionEnabled = NO;
          
          hud.mode = MBProgressHUDModeCustomView;
          hud.removeFromSuperViewOnHide = YES;
          [hud hideAnimated:YES afterDelay:1.5];
      });
  }
  
  - (IBAction)didButtonStartClicked:(UIButton *)sender {
      if (isUpgrading) {
          [self showTextHUD:@"正在升级中,请稍候!"];
          return;
      }
      [self.otaManager upgrade];
      isUpgrading = YES;
      [_buttonStart setEnabled:NO];
      [_buttonStart setTitle:@"UPGRADING" forState:UIControlStateNormal];
  }
78069d6a   jason   feat:lettransceiv...
211
  
60a29b2c   jason   feat:ota viewcont...
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
  - (IBAction)didButtonPrepareClicked:(UIButton *)sender {
      if (isUpgrading) {
          [self showTextHUD:@"正在升级中,请稍候!"];
          return;
      }
      
      
      NSLog(@"OTA path: %@", self.path);
      
      isUpgrading = NO;
      [self.otaManager setOTAFile:self.path];
      
      NSString *version = [self.otaManager getOTAVersion];
      [_labelOTAVersion setText:version];
      
      [self.otaManager prepare];
78069d6a   jason   feat:lettransceiv...
228
  }
60a29b2c   jason   feat:ota viewcont...
229
  
78069d6a   jason   feat:lettransceiv...
230
231
  
  @end