Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/TextureGroup/Texture
Smooth asynchronous user interfaces for iOS apps.
https://github.com/TextureGroup/Texture
asyncdisplaykit pinterest rendering texture uikit
Last synced: 6 days ago
JSON representation
Smooth asynchronous user interfaces for iOS apps.
- Host: GitHub
- URL: https://github.com/TextureGroup/Texture
- Owner: TextureGroup
- License: other
- Created: 2017-02-10T01:44:38.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-10-18T22:04:08.000Z (about 2 months ago)
- Last Synced: 2024-10-24T06:31:57.755Z (about 2 months ago)
- Topics: asyncdisplaykit, pinterest, rendering, texture, uikit
- Language: Objective-C++
- Homepage: https://texturegroup.org/
- Size: 130 MB
- Stars: 8,016
- Watchers: 177
- Forks: 1,289
- Open Issues: 617
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-ios-star - Texture - Smooth asynchronous user interfaces for iOS apps. (UI / Font)
- Awesome-iOS - Texture - Texture is an iOS framework built on top of UIKit that keeps even the most complex user interfaces smooth and responsive. (UI Frameworks)
- awesome-ios - Texture - Smooth asynchronous user interfaces for iOS apps. (UI / Font)
README
## Coming from AsyncDisplayKit? Learn more [here](https://medium.com/@Pinterest_Engineering/introducing-texture-a-new-home-for-asyncdisplaykit-e7c003308f50)
![Texture](https://github.com/texturegroup/texture/raw/master/docs/static/images/logo.png)
[![Apps Using](https://img.shields.io/cocoapods/at/Texture.svg?label=Apps%20Using%20Texture&colorB=28B9FE)](http://cocoapods.org/pods/Texture)
[![Downloads](https://img.shields.io/cocoapods/dt/Texture.svg?label=Total%20Downloads&colorB=28B9FE)](http://cocoapods.org/pods/Texture)[![Platform](https://img.shields.io/badge/platforms-iOS%20%7C%20tvOS-orange.svg)](http://texturegroup.org)
[![Languages](https://img.shields.io/badge/languages-ObjC%20%7C%20Swift-orange.svg)](http://texturegroup.org)[![Version](https://img.shields.io/cocoapods/v/Texture.svg)](http://cocoapods.org/pods/Texture)
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-59C939.svg?style=flat)](https://github.com/Carthage/Carthage)
[![License](https://img.shields.io/cocoapods/l/Texture.svg)](https://github.com/texturegroup/texture/blob/master/LICENSE)## Installation
Texture is available via CocoaPods or Carthage. See our [Installation](http://texturegroup.org/docs/installation.html) guide for instructions.
## Performance Gains
Texture's basic unit is the `node`. An ASDisplayNode is an abstraction over `UIView`, which in turn is an abstraction over `CALayer`. Unlike views, which can only be used on the main thread, nodes are thread-safe: you can instantiate and configure entire hierarchies of them in parallel on background threads.
To keep its user interface smooth and responsive, your app should render at 60 frames per second — the gold standard on iOS. This means the main thread has one-sixtieth of a second to push each frame. That's 16 milliseconds to execute all layout and drawing code! And because of system overhead, your code usually has less than ten milliseconds to run before it causes a frame drop.
Texture lets you move image decoding, text sizing and rendering, layout, and other expensive UI operations off the main thread, to keep the main thread available to respond to user interaction.
## Advanced Developer Features
As the framework has grown, many features have been added that can save developers tons of time by eliminating common boilerplate style structures common in modern iOS apps. If you've ever dealt with cell reuse bugs, tried to performantly preload data for a page or scroll style interface or even just tried to keep your app from dropping too many frames you can benefit from integrating Texture.
## Learn More
* Read the our [Getting Started](http://texturegroup.org/docs/getting-started.html) guide
* Get the [sample projects](https://github.com/texturegroup/texture/tree/master/examples)
* Browse the [API reference](http://texturegroup.org/appledocs.html)## Getting Help
We use Slack for real-time debugging, community updates, and general talk about Texture. [Signup](https://asdk-slack-auto-invite.herokuapp.com) yourself or email [email protected] to get an invite.
## Release process
For the release process see the [RELEASE](https://github.com/texturegroup/texture/blob/master/RELEASE.md) file.
## Contributing
We welcome any contributions. See the [CONTRIBUTING](https://github.com/texturegroup/texture/blob/master/CONTRIBUTING.md) file for how to get involved.
## License
The Texture project is available for free use, as described by the [LICENSE](https://github.com/texturegroup/texture/blob/master/LICENSE) (Apache 2.0).