RetroProgress
  • October 3, 2023

Description


Do you miss the 90s? We know you do. Dial-up internet, flickering screens, brightly colored websites and, of course, this annoyingly slow progress bar that has been invented to test your patience. Yes, it was a while ago, but we don’t want it to be forgotten. Meet RetroProgress, a progress bar made to cure your 90s nostalgia.

  •  Easy to use and customizable progress bar.
  •  Support for both progress value (0…1) and number of steps.
  •  Progress animations.
  •  No external dependencies.
  •  Playgrounds.
  •  Demo project.

Table of Contents


Usage


Are you excited to bring this thing back from the dead? So are we. Let’s use default configuration and see what we get out-of-the-box:

let progressView = ProgressView(frame: CGRect(x: 0, y: 0, width: 360, height: 30))
progressView.animateProgress(to: 0.8)

Do you think it’s way too retro? Let’s try to make it more modern:

let progressView = ProgressView(frame: CGRect(x: 0, y: 0, width: 360, height: 30))

// Configure
progressView.layer.cornerRadius = 10
progressView.layer.borderColor = UIColor.black.cgColor
progressView.trackColor = .white
progressView.separatorColor = .black
progressView.progressColor = UIColor(
red: 218/255,
green: 236/255,
blue: 255/255,
alpha: 1
)

// Set progress
progressView.animateProgress(to: 0.8)

Not a fan of those separators? Let’s try without them:

let progressView = ProgressView(frame: CGRect(x: 0, y: 0, width: 360, height: 30))

// Configure
progressView.numberOfSteps = 0
progressView.progressInset = .zero
progressView.layer.cornerRadius = 15
progressView.layer.borderColor = UIColor.white.cgColor
progressView.trackColor = .black
progressView.progressColor = .white

// Set progress
progressView.animateProgress(to: 0.8)

The options are limitless. Think big, now it’s your turn to make the progress bar great again.

Public properties


  • numberOfSteps – Maximum number of steps. Set to 0 to remove separators.
  • step – Number of separators (0…numberOfSteps). Values outside are pinned.
  • progress – 0…1, default is 0. Values outside are pinned.
  • progressInset – The inner inset for progress bar and separators.
  • trackColor – The color shown for the portion of the progress bar that is not filled.
  • progressColor – The color shown for the portion of the progress bar that is filled.
  • separatorColor – The color used for the step separators.
  • fullProgressAnimationDuration – The duration for progress animation from 0 to 1.
  • separatorWidth – The width of step separators.

Public methods


  • animateProgress(to:duration:) – Animates progress bar to the specified value (0…1).
  • animateSteps(to:duration:) – Animates progress bar to the specified value (0…numberOfSteps).

Installation


RetroProgress is available through CocoaPods. To install it, simply add the following line to your Podfile:

pod ‘RetroProgress’

RetroProgress is also available through Carthage. To install just write into your Cartfile:

github “vadymmarkov/RetroProgress”

RetroProgress can also be installed manually. Just download and drop Sources folders in your project.

GitHub


View Github

#animation #loadingindicator #progresscircle #progressview #swift
YOU MIGHT ALSO LIKE...
CameraBackground

Features Both front and back camera supported. Flash modes: auto, on, off. Countdown timer. Tap to focus. Pinch to zoom. Usage  

DKCamera

Description A light weight & simple & easy camera for iOS by Swift. It uses CoreMotion framework to detect device orientation, so ...

HorizonSDK-iOS

Horizon SDK is a state of the art real-time video recording / photo shooting iOS library. Some of the features ...

LLSimpleCamera

LLSimpleCamera: A simple customizable camera - video recorder control LLSimpleCamera is a library for creating a customized camera - video ...

RSBarcodes_Swift

RSBarcodes allows you to read 1D and 2D barcodes using the metadata scanning capabilities introduced with iOS 7 and generate ...