__block int timeout=60;
dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
dispatch_source_t _timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0,queue);
dispatch_source_set_timer(_timer,dispatch_walltime(NULL, 0),1.0*NSEC_PER_SEC, 0); //每秒执行
dispatch_source_set_event_handler(_timer, ^{
if(timeout<=0){
dispatch_source_cancel(_timer);
dispatch_async(dispatch_get_main_queue(), ^{
[self.validBtn setTitle:@"获取短信验证码" forState:UIControlStateNormal];
//self.validBtn.backgroundColor=RGB(120, 0, 103);
[self.validBtn setBackgroundImage:[UIImage imageNamed:@"获取验证码"] forState:UIControlStateNormal];
self.validBtn.userInteractionEnabled = YES;
});
}else{
int seconds = timeout;
NSString *strTime = [NSString stringWithFormat:@"%.2d", seconds];
dispatch_async(dispatch_get_main_queue(), ^{
[self.validBtn setTitle:[NSString stringWithFormat:@"%@秒",strTime] forState:UIControlStateNormal];
//self.validBtn.backgroundColor=RGB(207, 207, 207);
[self.validBtn setBackgroundImage:[UIImage imageNamed:@"获取验证码-不可点击"] forState:UIControlStateNormal];
self.validBtn.userInteractionEnabled = NO;
});
timeout--;
}
});
dispatch_resume(_timer);
怪我咯2017-04-17 17:53:26
백그라운드로 이동한 후 백그라운드에서 실행할 수 있는 프로그램으로 선언되지 않은 경우 NSTimer는 사라지지 않아야 합니다.
나라면:
1. 백그라운드 진입 전 타이머를 정지하고, appdelegate의 applicationDidEnterBackground에 시간을 기록하고, 포그라운드 진입 시의 시간을 비교하여 차이를 계산하고, 인증코드 값 표시를 새로고침하고, 그런 다음 타이머를 시작하십시오.
2. 백그라운드로 진입하기 전에 타이머를 중지하거나 백그라운드에서 몇 초마다 backgroundTask를 사용하여 인증 코드 번호를 감소시킨 후 프론트 데스크로 돌아온 후 타이머를 시작하세요. (너무 지루해요...)
3. 앱을 백그라운드에서 실행할 수 있는 프로그램으로 선언하세요.
저는 첫 번째 옵션을 선택하겠습니다. . .
PHP中文网2017-04-17 17:53:26
제 계획은 다음과 같습니다.
시작 시간을 기록하세요.
매초마다 인터페이스의 표시를 업데이트합니다. 当前时间 - 开始时间
을 사용하여 인터페이스에 표시되는 시간(초)을 가져옵니다
GCD Timer
을 사용하고 있습니다. 배경에 들어갔다가 앞으로 돌아올 때의 상황을 처리할 필요는 없습니다. 물론 다른 것을 사용해도 문제는 없습니다.
大家讲道理2017-04-17 17:53:26
GreedTimer는 귀하가 언급한 문제를 해결할 수 있습니다. GRTimer를 사용할 때 timeInBackground
를 YES
ringa_lee2017-04-17 17:53:26
위에서 언급한 방법 중 어느 것도 간단하고 실행 가능한 방법을 찾지 못했습니다.
http://www.jianshu.com/p/8e61...