Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/maxkonovalov/mkringprogressview
⭕️ Ring progress view similar to Activity app on Apple Watch
https://github.com/maxkonovalov/mkringprogressview
activity apple circle conical-gradient gradient ios progress progress-bar progress-circle progress-ring progress-view ring swift
Last synced: 4 days ago
JSON representation
⭕️ Ring progress view similar to Activity app on Apple Watch
- Host: GitHub
- URL: https://github.com/maxkonovalov/mkringprogressview
- Owner: maxkonovalov
- License: mit
- Created: 2015-10-22T15:26:51.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2023-05-04T21:46:36.000Z (over 1 year ago)
- Last Synced: 2024-10-29T17:43:26.837Z (3 months ago)
- Topics: activity, apple, circle, conical-gradient, gradient, ios, progress, progress-bar, progress-circle, progress-ring, progress-view, ring, swift
- Language: Swift
- Homepage:
- Size: 1.04 MB
- Stars: 1,567
- Watchers: 29
- Forks: 136
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# MKRingProgressView
[![Language](http://img.shields.io/badge/language-swift-orange.svg?style=flat)](https://developer.apple.com/swift)
[![Platform](https://img.shields.io/cocoapods/p/MKRingProgressView.svg?style=flat)](http://cocoapods.org/pods/MKRingProgressView)
[![License](https://img.shields.io/cocoapods/l/MKRingProgressView.svg?style=flat)](http://cocoapods.org/pods/MKRingProgressView)
[![Version](https://img.shields.io/cocoapods/v/MKRingProgressView.svg?style=flat)](http://cocoapods.org/pods/MKRingProgressView)
[![Carthage compatible](https://img.shields.io/badge/Carthage-compatible-4BC51D.svg?style=flat)](https://github.com/Carthage/Carthage)
[![SPM compatible](https://img.shields.io/badge/Swift_Package_Manager-compatible-brightgreen.svg?style=flat)](https://swift.org/package-manager)Ring progress view similar to Activity app on Apple Watch
## Features
- Progress animation
- Customizable start/end and backdrop ring colors
- Customizable ring width
- Customizable progress line end style
- Customizable shadow under progress line end
- Progress values above 100% (or 360°) can also be displayed## Installation
### CocoaPods
To install `MKRingProgressView` via [CocoaPods](http://cocoapods.org), add the following line to your Podfile:
```
pod 'MKRingProgressView'
```### Carthage
To install `MKRingProgressView` via [Carthage](https://github.com/Carthage/Carthage#if-youre-building-for-ios-tvos-or-watchos), add the following line to your Cartfile:
```
github "maxkonovalov/MKRingProgressView"
```### Swift Package Manager
_Note: Instructions below are for using **SwiftPM** without the Xcode UI. It's the easiest to go to your Project Settings -> Swift Packages and add MKRingProgressView from there._
To integrate using Apple's Swift package manager, without Xcode integration, add the following as a dependency to your `Package.swift`:
```swift
.package(url: "https://github.com/maxkonovalov/MKRingProgressView.git", .upToNextMajor(from: "2.3.0"))
```## Usage
See the example Xcode project. It contains 2 targets:
- **ProgressRingExample** - a simple example containing a single progress ring with adjustable parameters.
- **ActivityRingsExample** - an advanced usage example replicating Activity app by Apple. It also contains additional classes for convenient grouping of 3 ring progress views together.### Interface Builder
`MKRingProgressView` can be set up in Interface Builder. To use it, set the custom view class to `MKRingProgressView`. Most of the control's parameters can be customized in Interface Builder.
### Code
```swift
let ringProgressView = RingProgressView(frame: CGRect(x: 0, y: 100, width: 100, height: 100))
ringProgressView.startColor = .red
ringProgressView.endColor = .magenta
ringProgressView.ringWidth = 25
ringProgressView.progress = 0.0
view.addSubview(ringProgressView)
```The `progress` value can be animated the same way you would normally animate any property using `UIView`'s block-based animations:
```swift
UIView.animate(withDuration: 0.5) {
ringProgressView.progress = 1.0
}
```## Performance
To achieve better performance the following options are possible:
- Set `gradientImageScale` to lower values like `0.5` (defaults to `1.0`)
- Set `startColor` and `endColor` to the same value
- Set `shadowOpacity` to `0.0`
- Set `allowsAntialiasing` to `false`## Requirements
- iOS 9.0
- tvOS 9.0## License
`MKRingProgressView` is available under the MIT license. See the LICENSE file for more info.