SnapTimer:定制 UIView 模仿 Snapchat's stories 定时器效果

1,152 阅读1分钟
原文链接: github.com

SnapTimer is a custom UIView that behaves exactly the same as the one on Snapchat's stories.

  • Two different timers, 'outer' and 'inner'.
  • Independent animations for each of the timers.
  • Customizable colors.
  • Completion handlers.
  • Fully Swift.

A picture is worth a thousand words

samples

You can just clone the repo and copy the SnapTimer folder to your project or you can use one of the following options:

CocoaPods

pod 'SnapTimer'

Then:

import SnapTimer

And you are all set!

Carthage

  • TODO

  1. Add a UIView to your Storyboard.
  2. Select the view, go to the Identity Inspector and set the class to SnapTimerView

    identity-inspector

  3. Create an @IBOutlet in your view controller and that's it.

    SnapTimerView implements @IBDesignable so the view should automatically render in your Interface Builder. Also it implements @IBInspectable for the view properties:

    properties

  4. That's it!

innerValue and outerValue ranges go from 0 to 100.

  • To set values without animations you just have to:

    self.snapTimerView.outerValue = 25
    self.snapTimerView.innerValue = 50

    ej1

  • To animate values:

    self.snapTimerView.animateOuterValue(50)
    self.snapTimerView.animateInnerValue(25)

    ej1

  • To animate values setting the time and a completion handler:

    self.snapTimerView.animateOuterToValue(50, duration: 30) {
        puts("Done!")
    }
    
    self.snapTimerView.animateInnerToValue(100, duration: 30) {
        puts("Done!")
    }

if your app goes to background or the Notifications/Control center are opened you may want to pause the animations, to do that SnapTimer has two handy methods:

self.snapTimerView.resumeAnimation()
self.snapTimerView.pauseAnimation()

samples

Hey, If you have cool ideas to add to this please feel free to send a PR! Also if you are using this in your app and what to let me know I'll be happy to add a section here with the apps currently using this!

  • Swift 2.3 and 3 👌