2015-01-23 01:02:08 +01:00
|
|
|
/// Keeps a reference to an `UIImage` instance and its duration as a GIF frame.
|
2014-12-12 15:29:17 -05:00
|
|
|
struct AnimatedFrame {
|
2016-04-24 11:28:09 +02:00
|
|
|
/// The image that should be used for this frame.
|
2014-12-12 15:29:17 -05:00
|
|
|
let image: UIImage?
|
2016-04-24 11:28:09 +02:00
|
|
|
/// The duration that the frame image should be displayed.
|
2014-12-12 15:29:17 -05:00
|
|
|
let duration: NSTimeInterval
|
2015-06-09 14:28:11 -07:00
|
|
|
|
2016-04-24 11:28:09 +02:00
|
|
|
/// A placeholder frame with no image assigned.
|
|
|
|
/// Used to replace frames that are no longer needed in the animation.
|
|
|
|
var placeholderFrame: AnimatedFrame {
|
|
|
|
return AnimatedFrame(image: nil, duration: duration)
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Whether the AnimatedFrame instance contains an image or not.
|
|
|
|
var isPlaceholder: Bool {
|
|
|
|
return image == .None
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Takes an optional image and returns an non-placeholder `AnimatedFrame`.
|
|
|
|
///
|
|
|
|
/// - parameter image: An optional `UIImage` instance to be assigned to the new frame.
|
|
|
|
/// - returns: A non-placeholder `AnimatedFrame` instance.
|
|
|
|
func frameWithImage(image: UIImage?) -> AnimatedFrame {
|
|
|
|
return AnimatedFrame(image: image, duration: duration)
|
2015-06-09 14:28:11 -07:00
|
|
|
}
|
2014-12-12 15:29:17 -05:00
|
|
|
}
|
2015-06-09 14:28:11 -07:00
|
|
|
|