Clarify that UIImageView is not animatable as-is
This commit is contained in:
parent
193e8219fb
commit
9ecb4b63e1
14
README.md
14
README.md
@ -2,7 +2,7 @@
|
|||||||
|
|
||||||
[data:image/s3,"s3://crabby-images/ded7e/ded7e2d4e306349b109c5461096580f4ae59b2f1" alt="GitHub release"](https://github.com/kaishin/Gifu/releases/latest) [data:image/s3,"s3://crabby-images/1033c/1033c7edb0c9fb472c11b6b2fbbfe1812c0192b0" alt="Travis"](https://travis-ci.org/kaishin/Gifu) [data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage compatible"](https://github.com/Carthage/Carthage) [data:image/s3,"s3://crabby-images/d44f1/d44f1a697d5a052e89045dc52fb2fe3aa1eee407" alt="Join the chat at https://gitter.im/kaishin/gifu"](https://gitter.im/kaishin/gifu) data:image/s3,"s3://crabby-images/10b5a/10b5a01219eb7aa067ee7338763e2535faef45d7" alt="Swift 3.0.x" data:image/s3,"s3://crabby-images/d914e/d914ecddae32565c5cf927e6c7f6494b4cb862ec" alt="platforms"
|
[data:image/s3,"s3://crabby-images/ded7e/ded7e2d4e306349b109c5461096580f4ae59b2f1" alt="GitHub release"](https://github.com/kaishin/Gifu/releases/latest) [data:image/s3,"s3://crabby-images/1033c/1033c7edb0c9fb472c11b6b2fbbfe1812c0192b0" alt="Travis"](https://travis-ci.org/kaishin/Gifu) [data:image/s3,"s3://crabby-images/2d180/2d1801ae7805458b91e18c5ac4d97d63da45be3a" alt="Carthage compatible"](https://github.com/Carthage/Carthage) [data:image/s3,"s3://crabby-images/d44f1/d44f1a697d5a052e89045dc52fb2fe3aa1eee407" alt="Join the chat at https://gitter.im/kaishin/gifu"](https://gitter.im/kaishin/gifu) data:image/s3,"s3://crabby-images/10b5a/10b5a01219eb7aa067ee7338763e2535faef45d7" alt="Swift 3.0.x" data:image/s3,"s3://crabby-images/d914e/d914ecddae32565c5cf927e6c7f6494b4cb862ec" alt="platforms"
|
||||||
|
|
||||||
Gifu adds protocol-based, performance-aware animated GIF support to UIKit, without forcing you to use a `UIImageView` subclass. (It's also a [prefecture in Japan](https://goo.gl/maps/CCeAc)).
|
Gifu adds protocol-based, performance-aware animated GIF support to UIKit. (It's also a [prefecture in Japan](https://goo.gl/maps/CCeAc)).
|
||||||
|
|
||||||
⚠ **Swift 2.3** support is on the [swift2.3](https://github.com/kaishin/Gifu/tree/swift2.3) branch. **This branch will not be getting any future updates**.
|
⚠ **Swift 2.3** support is on the [swift2.3](https://github.com/kaishin/Gifu/tree/swift2.3) branch. **This branch will not be getting any future updates**.
|
||||||
|
|
||||||
@ -25,7 +25,7 @@ for up to date installation instructions.
|
|||||||
|
|
||||||
## How It Works
|
## How It Works
|
||||||
|
|
||||||
`Gifu` does not rely on subclassing `UIImageView`. The `Animator` class does the heavy-lifting, while the `GIFAnimatable` protocol exposes the functionality to the view classes that conform to it, using protocol extensions.
|
`Gifu` does not force you to use a specific subclass `UIImageView`. The `Animator` class does the heavy-lifting, while the `GIFAnimatable` protocol exposes the functionality to the view classes that conform to it, using protocol extensions.
|
||||||
|
|
||||||
The `Animator` has a `FrameStore` that only keeps a limited number of frames in-memory, effectively creating a buffer for the animation without consuming all the available memory. This approach makes loading large GIFs a lot more resource-friendly.
|
The `Animator` has a `FrameStore` that only keeps a limited number of frames in-memory, effectively creating a buffer for the animation without consuming all the available memory. This approach makes loading large GIFs a lot more resource-friendly.
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ containing 10 frames, Gifu will load the current frame (red), buffer the next tw
|
|||||||
There are two options that should cover any situation:
|
There are two options that should cover any situation:
|
||||||
|
|
||||||
- Use the built-in `GIFImageView` subclass.
|
- Use the built-in `GIFImageView` subclass.
|
||||||
- Make `UIImageView` or any of its subclasses conform to `GIFAnimatable`.
|
- Make any class conform to `GIFAnimatable`. Subclassing `UIImageView` is the easiest since you get most of the required properties for free.
|
||||||
|
|
||||||
### GIFImageView
|
### GIFImageView
|
||||||
|
|
||||||
@ -70,6 +70,14 @@ That's it. Now `MyImageView` is fully GIF-compatible, and any of these methods c
|
|||||||
- `prepareForReuse()` to free up resources.
|
- `prepareForReuse()` to free up resources.
|
||||||
- `updateImageIfNeeded()` to update the image property if necessary.
|
- `updateImageIfNeeded()` to update the image property if necessary.
|
||||||
|
|
||||||
|
This approach is especially powerful when you want to combine the functionality of different image libraries.
|
||||||
|
|
||||||
|
~~~swift
|
||||||
|
class MyImageView: OtherImageClass, GIFAnimatable {}
|
||||||
|
~~~
|
||||||
|
|
||||||
|
Keep in mind that you need to have control over the class implementing `GIFAnimatable` since you cannot add the stored `Animator` property in an extension.
|
||||||
|
|
||||||
### Examples
|
### Examples
|
||||||
|
|
||||||
The simplest way to get started is initializing a `GIFAnimatable` class in code or in a storyboard, then calling `animate(:)` on it.
|
The simplest way to get started is initializing a `GIFAnimatable` class in code or in a storyboard, then calling `animate(:)` on it.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user