RingProgressViewStyle
data:image/s3,"s3://crabby-images/0a0cd/0a0cd6eb5760d7febe0c2cff63134020b3edbf18" alt="License"
RingProgressViewStyle is a library that adds a ring style to SwiftUI’s ProgressViewStyle
. The default apperance is based on the .linear
style of ProgressViewStyle
, but you can customize colors and a stroke style.
Example
Example.swiftpm can be opened in Swift Playgrounds app or Xcode.
data:image/s3,"s3://crabby-images/d6742/d67428150cfb1655dbbcafda752db6cb278ba5f8" alt="preview"
Motivation
The .circular
style already exists in ProgressViewStyle
, but it’s just an indicator, not a progress bar. So basically, you have to implement that by yourself.
Fortunately, if you google “SwiftUI progress ring”, you can find a number of code examples. Almost all of them looks like:
Circle()
.trim(from: 0, to: value)
.stroke(...)
.rotationEffect(.degrees(-90))
However, when you try to specify its size by .frame(width: ..., height: ...)
, its stroke line overflows its frame.
To prevent this, I often use strokeBorder
instead of stroke
.
Circle()
.trim(from: 0, to: value)
.strokeBorder(...)
.rotationEffect(.degrees(-90))
But it occurs a compilation error because trim
returns some Shape
that doesn’t conform to InsettableShape
but strokeBorder
is a method of InsettableShape
.
So I created a solution.
How to Use
Add this repository to your package dependencies in your app.
- iOS 14+
- iPadOS 14+
- macOS 11+
RingProgressViewStyle
RingProgressViewStyle is a library that adds a ring style to SwiftUI’s
ProgressViewStyle
. The default apperance is based on the.linear
style ofProgressViewStyle
, but you can customize colors and a stroke style.Example
Example.swiftpm can be opened in Swift Playgrounds app or Xcode.
Motivation
The
.circular
style already exists inProgressViewStyle
, but it’s just an indicator, not a progress bar. So basically, you have to implement that by yourself.Fortunately, if you google “SwiftUI progress ring”, you can find a number of code examples. Almost all of them looks like:
However, when you try to specify its size by
.frame(width: ..., height: ...)
, its stroke line overflows its frame.To prevent this, I often use
strokeBorder
instead ofstroke
.But it occurs a compilation error because
trim
returnssome Shape
that doesn’t conform toInsettableShape
butstrokeBorder
is a method ofInsettableShape
.So I created a solution.
How to Use
Add this repository to your package dependencies in your app.
Supported Platforms