swiftに関する質問です。
現在、NSTimerを使用してLabelに20秒から0秒までカウントダウンするような表示をしている状態です。
その表示とは別のUIViewでanimateWithDurationを用いて20秒間アニメーションを行っているのですが、NStimerの表示とanimateWithDurationの終了が一致しない状況です。
デバックエリアを見る限りでは、重たいアニメーションをするとNSTimerの進みが遅くなっているように感じます。
タイトルどおりですがNSTimerの時間とanimateWithDurationの秒数同期させることは可能でしょうか。
また、どのように同期させればよいでしょうか。
ご教示のほどよろしくお願いいたします。
下記にコードを記載しました。また、詳細を記載させていただきます。
内容としてはtimeFormat()で制限時間が20.00から0.00までカウントダウンするものにNStimerを使用しており、timerbar()で制限時間バーが20秒かけて減少するようにしております。
これとは別にアニメーション(問題表示)をおこなっておりその時間が数秒に渡る場合カウントダウンが0になる前にバーが減少しきってしまいます。そのアニメーション(問題表示)が1秒以内であればあまり気にならない程度なのですが、数秒の場合カウントダウンが0になるのとバーの減少に1秒以上の差が出てきてしまいます。
swift
1 2//制限時間の数字表示 3private var timerLabel: UILabel! 4//制限時間バー 5private var myImageView: UIImageView! 6 7var timer = NSTimer() 8var countNum = 0 9 10 // スクリーン画面のサイズを取得 11 let scWid: CGFloat = UIScreen.mainScreen().bounds.width //画面の幅 12 let scHei: CGFloat = UIScreen.mainScreen().bounds.height //画面の高さ 13 14 //制限時間の表示 15 func timerLimit(){ 16 17 // UILabelを作成する. 18 timerLabel = UILabel(frame: CGRectMake(scWid*0.79 ,scHei*0.4375 ,scWid*0.11 ,scHei*0.025)) 19 timerLabel.font = UIFont.boldSystemFontOfSize(scHei*0.018) 20 timerLabel.textColor = UIColor.whiteColor() 21 self.view.addSubview(timerLabel) 22 } 23 24 func update() { 25 countNum += 1 26 timeFormat(countNum) 27 } 28 29 //制限時間の数字の表示 30 func timeFormat(countNum:Int) { 31 32 let ms = countNum % 100 33 let s = countNum / 100 34 timerLabel.text = String(format: "%02d.%02d", 19-s, 100-ms) 35 36 } 37 38 //制限時間追加メソッド 39 func timermethod(){ 40 countNum = 0 41 timer = NSTimer.scheduledTimerWithTimeInterval(0.01, target: self, selector: #selector(KenteiViewController.update), userInfo: nil, repeats: true) 42 // Run loopに登録する 43 NSRunLoop.currentRunLoop().addTimer(timer, forMode: NSRunLoopCommonModes) 44 } 45 46 //制限時間を止めるメソッド 47 func timerStop(){ 48 timer.invalidate() 49 } 50 51 52 53//制限時間バー(オレンジ色のバー)の表示 54 func timerbar(){ 55 let barHeight = scHei*0.02 56 let barWidth = scWid*0.66 57 let barXPosition = scWid*0.08 58 let barYPosition = scHei*0.44 59 let barXPositionEnd = barXPosition + barWidth 60 // UIImageViewを作成する. 61 myImageView = UIImageView() 62 // 表示する画像を設定する. 63 let myImage = UIImage(named: "timebar.png") 64 // 画像をUIImageViewに設定する. 65 myImageView.image = myImage 66 // 画像の表示する座標を指定する. 67 myImageView.frame = CGRectMake(barXPosition ,barYPosition ,barWidth ,barHeight) 68 // UIImageViewをViewに追加する. 69 self.view.addSubview(myImageView) 70 71 UIView.animateWithDuration(20, delay: 0.0, options : UIViewAnimationOptions.CurveLinear, animations: {() -> Void in 72 self.myImageView.frame = CGRectMake(barXPositionEnd, barYPosition, 0, barHeight) 73 }, 74 completion: {(finished: Bool) -> Void in 75 // アニメーション終了後の処理 76 print("制限時間バーは\(finished)") 77 }) 78 79 } 80 81 82 override func viewDidLoad() { 83 super.viewDidLoad() 84 85 //制限時間ラベルの表示 86 timerLimit() 87 //制限時間をつけるメソッドを呼び出す 88 timermethod() 89 }
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/08/01 02:45
2016/08/01 04:13
2016/08/01 11:41