1. Declare control
There are two styles of progress bars
- bar
- default
The two styles work as follows:
self.view.backgroundColor = UIColor.red progressView = UIProgressView(progressViewStyle: .default) progressView.frame = CGRect(x: 0, y: 0, width: 200, height: 10) progressView.layer.position = CGPoint(x: self.view.frame.width/2, y: 90) progressView.progress = 0.5 self.view.addSubview(progressView) progressView2 = UIProgressView(progressViewStyle: .bar) progressView2.frame = CGRect(x: 0, y: 0, width: 200, height: 20) progressView2.layer.position = CGPoint(x: self.view.frame.width/2, y: 110) progressView2.progress = 0.5 self.view.addSubview(progressView2)
Operation effect:
data:image/s3,"s3://crabby-images/13811/1381134972481300d0f914575b80953ba632f1e6" alt=""
Progress bar style
2. Enable progress bar loading animation
progressView.setProgress(0.5, animated: true)
3. Change the progress bar color
progressView.progressTintColor = UIColor.green //Progress color progressView.trackTintColor = UIColor.yellow //Remaining progress colors
data:image/s3,"s3://crabby-images/11b3a/11b3a1ed9482e21fe9bbf09ea1fa07dc92c8f55a" alt=""
Set progress bar color
4. Set the height of progressView
In fact, careful partners should have found that when declaring controls, the height of the first height:10 and the second height: 20 have no difference from the screenshot, so setting the height of progressView cannot achieve the goal, but we can change the scale of progressView to achieve the height change
progressView = UIProgressView(progressViewStyle: .default) progressView.frame = CGRect(x: 0, y: 0, width: 200, height: 10) progressView.layer.position = CGPoint(x: self.view.frame.width/2, y: 90) progressView.setProgress(0.5, animated: true) progressView.progressTintColor = UIColor.green //Progress color progressView.trackTintColor = UIColor.yellow //Remaining progress colors //By changing the height of the progress bar (the width remains the same, and the height becomes twice the default) progressView.transform = CGAffineTransform(scaleX: 1.0, y: 2.0) self.view.addSubview(progressView) progressView2 = UIProgressView(progressViewStyle: .bar) progressView2.frame = CGRect(x: 0, y: 0, width: 200, height: 20) progressView2.layer.position = CGPoint(x: self.view.frame.width/2, y: 110) progressView2.progress = 0.5 self.view.addSubview(progressView2)
data:image/s3,"s3://crabby-images/f8eb8/f8eb8b4f37be3c5639934e7ebcf77a529696c9e0" alt=""
Change progress bar height
5. Others
Recommend a custom progress bar style: http://www.code4app.com/thread-6304-1-1.html It is implemented in OC. You may need to be familiar with the use of OC control in swift first
data:image/s3,"s3://crabby-images/88ae6/88ae6299c0bdde5e3b6506029fa295bb841b47f4" alt=""
Progress bar with small label